/* =====================================================
   InternLoom — Production Design System v2.0
   Inspired by LinkedIn · Naukri · Glassdoor · Apna
   Aesthetic: Corporate Confidence × Youth Energy
   ===================================================== */

@import url('https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:ital,wght@0,300;0,400;0,500;0,600;0,700;0,800;1,400&family=Clash+Display:wght@400;500;600;700&display=swap');

/* Tokens */
:root {
  /* Brand */
  --il-blue: #0A66C2;
  /* LinkedIn-inspired trust blue */
  --il-blue-dark: #004182;
  --il-blue-mid: #1D7FE8;
  --il-blue-light: #EBF4FF;
  --il-teal: #00A0A0;
  /* differentiator accent */
  --il-teal-light: #E0F7F7;
  --il-orange: #F5820D;
  /* Naukri-inspired energy */
  --il-orange-light: #FFF3E3;

  /* Neutrals */
  --n-0: #FFFFFF;
  --n-50: #F8FAFC;
  --n-100: #F1F5F9;
  --n-200: #E2E8F0;
  --n-300: #CBD5E1;
  --n-400: #94A3B8;
  --n-500: #64748B;
  --n-600: #475569;
  --n-700: #334155;
  --n-800: #1E293B;
  --n-900: #0F172A;

  /* Semantic */
  --success: #16A34A;
  --success-bg: #DCFCE7;
  --warn: #D97706;
  --warn-bg: #FEF3C7;
  --danger: #DC2626;
  --danger-bg: #FEE2E2;
  --info: #0284C7;
  --info-bg: #E0F2FE;

  /* Shadows */
  --s1: 0 1px 3px rgba(15, 23, 42, .07), 0 1px 2px rgba(15, 23, 42, .05);
  --s2: 0 4px 12px rgba(15, 23, 42, .08), 0 2px 4px rgba(15, 23, 42, .05);
  --s3: 0 10px 32px rgba(15, 23, 42, .1), 0 4px 8px rgba(15, 23, 42, .06);
  --s4: 0 20px 60px rgba(15, 23, 42, .14), 0 8px 20px rgba(15, 23, 42, .08);
  --s-blue: 0 8px 32px rgba(10, 102, 194, .28);
  --s-teal: 0 8px 32px rgba(0, 160, 160, .22);

  /* Radius */
  --r4: 4px;
  --r8: 8px;
  --r12: 12px;
  --r16: 16px;
  --r20: 20px;
  --r24: 24px;
  --r-pill: 999px;

  /* Transitions */
  --ease: cubic-bezier(.4, 0, .2, 1);
  --t1: .15s var(--ease);
  --t2: .25s var(--ease);
  --t3: .35s var(--ease);
}

/* Reset & Base */
*,
*::before,
*::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

html {
  scroll-behavior: smooth;
  text-rendering: optimizeLegibility;
  -webkit-font-smoothing: antialiased;
}

body {
  font-family: 'Plus Jakarta Sans', system-ui, sans-serif;
  font-size: 15px;
  line-height: 1.6;
  color: var(--n-800);
  background: var(--n-50);
  min-height: 100vh;
  display: flex;
  flex-direction: column;
  overflow-x: hidden;
}

main {
  flex: 1;
}

h1,
h2,
h3,
h4,
h5,
h6 {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-weight: 700;
  line-height: 1.25;
  letter-spacing: -.02em;
  color: var(--n-900);
}

a {
  color: var(--il-blue);
  text-decoration: none;
  transition: color var(--t1);
}

a:hover {
  color: var(--il-blue-dark);
}

img {
  max-width: 100%;
}

/* Scrollbar */
::-webkit-scrollbar {
  width: 6px;
  height: 6px;
}

::-webkit-scrollbar-track {
  background: var(--n-100);
}

::-webkit-scrollbar-thumb {
  background: var(--n-300);
  border-radius: 3px;
}

::-webkit-scrollbar-thumb:hover {
  background: var(--n-400);
}

.il-nav {
  position: sticky;
  top: 0;
  z-index: 1040;
  background: var(--n-0);
  border-bottom: 1px solid var(--n-200);
  box-shadow: var(--s1);
  height: 64px;
  display: flex;
  align-items: center;
}

.il-nav .container {
  display: flex;
  align-items: center;
  gap: 1rem;
}

/* Logo */
.il-logo {
  display: flex;
  align-items: center;
  gap: .55rem;
  text-decoration: none;
  flex-shrink: 0;
}

.il-logo-img {
  height: 44px;
  width: auto;
  object-fit: contain;
  transition: transform var(--t2), filter var(--t2);
}

.il-logo:hover .il-logo-img {
  transform: scale(1.06);
  filter: drop-shadow(0 2px 8px rgba(10, 102, 194, .25));
}

.il-logo-mark {
  width: 38px;
  height: 38px;
  background: linear-gradient(135deg, var(--il-blue) 0%, var(--il-teal) 100%);
  border-radius: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  font-size: 1.1rem;
  box-shadow: var(--s-blue);
  transition: transform var(--t2), box-shadow var(--t2);
  position: relative;
  overflow: hidden;
}

.il-logo-mark::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(255, 255, 255, .25) 0%, transparent 60%);
}

.il-logo:hover .il-logo-mark {
  transform: scale(1.05) rotate(-2deg);
  box-shadow: var(--s-teal);
}

.il-logo-text {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 1.3rem;
  font-weight: 800;
  letter-spacing: -.04em;
  line-height: 1;
}

.il-logo-text .t1 {
  color: var(--il-blue);
}

.il-logo-text .t2 {
  color: var(--il-teal);
}


/* Nav links */
.il-nav-links {
  display: flex;
  align-items: center;
  gap: .15rem;
  list-style: none;
  margin: 0;
  padding: 0;
}

.il-nav-links .nl-item a,
.il-nav-links .nl-item button {
  display: flex;
  align-items: center;
  gap: .35rem;
  padding: .45rem .75rem;
  font-size: .875rem;
  font-weight: 500;
  color: var(--n-600);
  border-radius: var(--r8);
  transition: background var(--t1), color var(--t1);
  border: none;
  background: none;
  cursor: pointer;
  white-space: nowrap;
}

.il-nav-links .nl-item a:hover,
.il-nav-links .nl-item button:hover {
  background: var(--n-100);
  color: var(--il-blue);
}

.il-nav-links .nl-item a.active {
  color: var(--il-blue);
  background: var(--il-blue-light);
  font-weight: 600;
}

/* User menu */
.il-user-chip {
  display: flex;
  align-items: center;
  gap: .5rem;
  padding: .35rem .75rem .35rem .35rem;
  border-radius: var(--r-pill);
  border: 1.5px solid var(--n-200);
  background: var(--n-0);
  cursor: pointer;
  transition: border-color var(--t1), box-shadow var(--t1);
  font-size: .8125rem;
  font-weight: 600;
  color: var(--n-700);
}

.il-user-chip:hover {
  border-color: var(--il-blue);
  box-shadow: 0 0 0 3px var(--il-blue-light);
  color: var(--il-blue);
}

.il-user-avatar {
  width: 28px;
  height: 28px;
  background: linear-gradient(135deg, var(--il-blue), var(--il-teal));
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  font-size: .75rem;
  font-weight: 700;
  flex-shrink: 0;
}

.il-nav-toggler {
  display: none;
  background: none;
  border: 1.5px solid var(--n-200);
  border-radius: var(--r8);
  padding: .45rem .55rem;
  cursor: pointer;
  color: var(--n-600);
  transition: background var(--t1);
}

.il-nav-toggler:hover {
  background: var(--n-100);
}

/* Dropdown */
.il-dropdown {
  position: relative;
}

.il-dropdown-menu {
  position: absolute;
  right: 0;
  top: calc(100% + 8px);
  background: var(--n-0);
  border: 1px solid var(--n-200);
  border-radius: var(--r12);
  box-shadow: var(--s3);
  min-width: 200px;
  padding: .4rem;
  opacity: 0;
  visibility: hidden;
  transform: translateY(-6px) scale(.97);
  transition: opacity var(--t2), transform var(--t2), visibility var(--t2);
  z-index: 100;
}

.il-dropdown.open .il-dropdown-menu {
  opacity: 1;
  visibility: visible;
  transform: translateY(0) scale(1);
}

.il-dropdown-item {
  display: flex;
  align-items: center;
  gap: .6rem;
  padding: .55rem .85rem;
  border-radius: var(--r8);
  font-size: .875rem;
  color: var(--n-700);
  font-weight: 500;
  transition: background var(--t1), color var(--t1);
  cursor: pointer;
}

.il-dropdown-item:hover {
  background: var(--n-100);
  color: var(--il-blue);
}

.il-dropdown-item.danger {
  color: var(--danger);
}

.il-dropdown-item.danger:hover {
  background: var(--danger-bg);
  color: var(--danger);
}

.il-dropdown-divider {
  height: 1px;
  background: var(--n-200);
  margin: .4rem 0;
}

@media (max-width: 991px) {
  .il-nav-toggler {
    display: flex;
    align-items: center;
  }

  .il-nav-collapse {
    display: none;
    position: absolute;
    top: 64px;
    left: 0;
    right: 0;
    background: var(--n-0);
    border-top: 1px solid var(--n-200);
    border-bottom: 1px solid var(--n-200);
    box-shadow: var(--s3);
    padding: .75rem;
    z-index: 1039;
  }

  .il-nav-collapse.open {
    display: block;
  }

  .il-nav-links {
    flex-direction: column;
    align-items: stretch;
    gap: .25rem;
  }

  .il-nav-links .nl-item a {
    justify-content: flex-start;
  }
}

@media (min-width: 992px) {
  .il-nav-collapse {
    display: flex !important;
    align-items: center;
    gap: .5rem;
    flex: 1;
    justify-content: flex-end;
  }
}

.il-toast-wrap {
  padding: .75rem 0 0;
}

.il-toast {
  display: flex;
  align-items: center;
  gap: .75rem;
  padding: .85rem 1.1rem;
  border-radius: var(--r12);
  font-size: .875rem;
  font-weight: 500;
  box-shadow: var(--s2);
  animation: toastSlide .3s var(--ease) both;
  border: 1px solid transparent;
}

@keyframes toastSlide {
  from {
    opacity: 0;
    transform: translateY(-8px);
  }

  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.il-toast-success {
  background: var(--success-bg);
  color: #14532D;
  border-color: #86EFAC;
}

.il-toast-danger {
  background: var(--danger-bg);
  color: #7F1D1D;
  border-color: #FCA5A5;
}

.il-toast-warning {
  background: var(--warn-bg);
  color: #78350F;
  border-color: #FCD34D;
}

.il-toast-info {
  background: var(--info-bg);
  color: #0C4A6E;
  border-color: #7DD3FC;
}

.il-toast-icon {
  font-size: 1rem;
  flex-shrink: 0;
}

.il-toast-close {
  margin-left: auto;
  background: none;
  border: none;
  cursor: pointer;
  opacity: .5;
  font-size: .875rem;
  padding: .2rem;
  border-radius: 4px;
  transition: opacity var(--t1);
  color: inherit;
}

.il-toast-close:hover {
  opacity: 1;
}

.il-page {
  padding: 2rem 0 3rem;
}

.il-page-sm {
  padding: 1.5rem 0 2.5rem;
}

/* Page title row */
.il-page-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: .75rem;
  margin-bottom: 1.75rem;
  padding-bottom: 1.25rem;
  border-bottom: 1px solid var(--n-200);
}

.il-page-title {
  display: flex;
  align-items: center;
  gap: .65rem;
  font-size: 1.5rem;
  font-weight: 800;
  letter-spacing: -.03em;
  color: var(--n-900);
}

.il-page-icon {
  width: 40px;
  height: 40px;
  background: var(--il-blue-light);
  color: var(--il-blue);
  border-radius: var(--r12);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.1rem;
  flex-shrink: 0;
}

.il-page-icon.teal {
  background: var(--il-teal-light);
  color: var(--il-teal);
}

.il-page-icon.green {
  background: var(--success-bg);
  color: var(--success);
}

.il-page-icon.orange {
  background: var(--il-orange-light);
  color: var(--il-orange);
}

.il-card {
  background: var(--n-0);
  border: 1px solid var(--n-200);
  border-radius: var(--r16);
  box-shadow: var(--s1);
  transition: box-shadow var(--t2), border-color var(--t2), transform var(--t2);
  overflow: hidden;
}

.il-card:hover {
  box-shadow: var(--s2);
}

.il-card.hoverable:hover {
  transform: translateY(-2px);
  box-shadow: var(--s3);
  border-color: var(--n-300);
}

.il-card-head {
  display: flex;
  align-items: center;
  gap: .65rem;
  padding: 1rem 1.4rem;
  border-bottom: 1px solid var(--n-200);
  font-weight: 700;
  font-size: .9375rem;
  color: var(--n-800);
}

.il-card-head .ch-ico {
  width: 30px;
  height: 30px;
  border-radius: var(--r8);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: .875rem;
  flex-shrink: 0;
}

.ch-blue {
  background: var(--il-blue-light);
  color: var(--il-blue);
}

.ch-teal {
  background: var(--il-teal-light);
  color: var(--il-teal);
}

.ch-green {
  background: var(--success-bg);
  color: var(--success);
}

.ch-orange {
  background: var(--il-orange-light);
  color: var(--il-orange);
}

.ch-red {
  background: var(--danger-bg);
  color: var(--danger);
}

.ch-warn {
  background: var(--warn-bg);
  color: var(--warn);
}

.il-card-body {
  padding: 1.4rem;
}

.il-card-body.p0 {
  padding: 0;
}

.il-card-foot {
  padding: .9rem 1.4rem;
  border-top: 1px solid var(--n-200);
  background: var(--n-50);
  font-size: .875rem;
  color: var(--n-500);
}

/* Stat Cards */
.il-stat {
  border-radius: var(--r16) !important;
  border: none !important;
  overflow: hidden;
  position: relative;
  padding: 1.5rem;
  color: #fff;
  box-shadow: var(--s3);
  transition: transform var(--t2), box-shadow var(--t2);
}

.il-stat:hover {
  transform: translateY(-3px);
  box-shadow: var(--s4);
}

.il-stat::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(255, 255, 255, .15) 0%, transparent 55%);
  pointer-events: none;
}

.il-stat-ghost {
  position: absolute;
  right: -12px;
  bottom: -12px;
  font-size: 5.5rem;
  opacity: .12;
  line-height: 1;
}

.il-stat-label {
  font-size: .72rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .1em;
  opacity: .85;
  margin-bottom: .35rem;
}

.il-stat-val {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 2.5rem;
  font-weight: 800;
  line-height: 1;
  margin-bottom: .5rem;
  letter-spacing: -.04em;
}

.il-stat-link {
  font-size: .78rem;
  font-weight: 600;
  opacity: .8;
  text-decoration: none;
  color: inherit !important;
  display: inline-flex;
  align-items: center;
  gap: .3rem;
  transition: opacity var(--t1);
}

.il-stat-link:hover {
  opacity: 1;
}

.stat-blue {
  background: linear-gradient(135deg, #004182 0%, #0A66C2 100%);
}

.stat-teal {
  background: linear-gradient(135deg, #006B6B 0%, #00A0A0 100%);
}

.stat-orange {
  background: linear-gradient(135deg, #B85E05 0%, #F5820D 100%);
}

.stat-green {
  background: linear-gradient(135deg, #166534 0%, #16A34A 100%);
}

.stat-violet {
  background: linear-gradient(135deg, #5B21B6 0%, #7C3AED 100%);
}

.btn {
  display: inline-flex;
  align-items: center;
  gap: .4rem;
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-weight: 600;
  font-size: .875rem;
  padding: .55rem 1.25rem;
  border-radius: var(--r8);
  border: none;
  cursor: pointer;
  transition: background var(--t1), box-shadow var(--t1), transform var(--t1), color var(--t1), border-color var(--t1);
  white-space: nowrap;
  letter-spacing: -.01em;
  text-decoration: none !important;
}

.btn:active {
  transform: scale(.98);
}

.btn-primary {
  background: var(--il-blue);
  color: #fff;
  box-shadow: 0 2px 8px rgba(10, 102, 194, .3);
}

.btn-primary:hover {
  background: var(--il-blue-dark);
  box-shadow: 0 4px 18px rgba(10, 102, 194, .4);
  transform: translateY(-1px);
  color: #fff;
}

.btn-teal {
  background: var(--il-teal);
  color: #fff;
  box-shadow: 0 2px 8px rgba(0, 160, 160, .3);
}

.btn-teal:hover {
  background: #007D7D;
  box-shadow: 0 4px 18px rgba(0, 160, 160, .4);
  transform: translateY(-1px);
  color: #fff;
}

.btn-success {
  background: var(--success);
  color: #fff;
  box-shadow: 0 2px 8px rgba(22, 163, 74, .28);
}

.btn-success:hover {
  background: #166534;
  box-shadow: 0 4px 16px rgba(22, 163, 74, .38);
  transform: translateY(-1px);
  color: #fff;
}

.btn-danger {
  background: var(--danger);
  color: #fff;
  box-shadow: 0 2px 8px rgba(220, 38, 38, .28);
}

.btn-danger:hover {
  background: #991B1B;
  transform: translateY(-1px);
  color: #fff;
}

.btn-warning {
  background: var(--warn);
  color: #fff;
  box-shadow: 0 2px 8px rgba(217, 119, 6, .28);
}

.btn-warning:hover {
  background: #92400E;
  transform: translateY(-1px);
  color: #fff;
}

.btn-info {
  background: var(--info);
  color: #fff;
  box-shadow: 0 2px 8px rgba(2, 132, 199, .28);
}

.btn-info:hover {
  background: #075985;
  transform: translateY(-1px);
  color: #fff;
}

.btn-secondary {
  background: var(--n-100);
  color: var(--n-700);
  border: 1.5px solid var(--n-200);
}

.btn-secondary:hover {
  background: var(--n-200);
  color: var(--n-900);
}

/* Outline variants */
.btn-outline-primary {
  background: transparent;
  color: var(--il-blue);
  border: 1.5px solid var(--il-blue);
}

.btn-outline-primary:hover {
  background: var(--il-blue);
  color: #fff;
  transform: translateY(-1px);
}

.btn-outline-success {
  background: transparent;
  color: var(--success);
  border: 1.5px solid var(--success);
}

.btn-outline-success:hover {
  background: var(--success);
  color: #fff;
  transform: translateY(-1px);
}

.btn-outline-danger {
  background: transparent;
  color: var(--danger);
  border: 1.5px solid var(--danger);
}

.btn-outline-danger:hover {
  background: var(--danger);
  color: #fff;
  transform: translateY(-1px);
}

.btn-outline-secondary {
  background: transparent;
  color: var(--n-600);
  border: 1.5px solid var(--n-300);
}

.btn-outline-secondary:hover {
  background: var(--n-100);
  color: var(--n-800);
}

.btn-outline-info {
  background: transparent;
  color: var(--info);
  border: 1.5px solid var(--info);
}

.btn-outline-info:hover {
  background: var(--info);
  color: #fff;
}

.btn-outline-warning {
  background: transparent;
  color: var(--warn);
  border: 1.5px solid var(--warn);
}

.btn-outline-warning:hover {
  background: var(--warn);
  color: #fff;
}

.btn-lg {
  padding: .75rem 1.75rem;
  font-size: .9375rem;
  border-radius: var(--r12);
}

.btn-sm {
  padding: .3rem .7rem;
  font-size: .8rem;
  border-radius: var(--r8);
}

.btn-xs {
  padding: .2rem .55rem;
  font-size: .75rem;
  border-radius: 6px;
}

.btn:disabled,
.btn.disabled {
  opacity: .45;
  cursor: not-allowed;
  transform: none !important;
  box-shadow: none !important;
}

.btn-group .btn:hover {
  transform: none;
}

.form-label {
  font-size: .78rem;
  font-weight: 700;
  color: var(--n-600);
  text-transform: uppercase;
  letter-spacing: .065em;
  margin-bottom: .4rem;
  display: block;
}

.form-control,
.form-select {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: .9375rem;
  color: var(--n-800);
  background: var(--n-0);
  border: 1.5px solid var(--n-300);
  border-radius: var(--r8);
  padding: .6rem .9rem;
  transition: border-color var(--t1), box-shadow var(--t1);
  width: 100%;
}

.form-control:focus,
.form-select:focus {
  border-color: var(--il-blue);
  box-shadow: 0 0 0 3px rgba(10, 102, 194, .12);
  outline: none;
}

.form-control::placeholder {
  color: var(--n-400);
}

.form-control.is-invalid {
  border-color: var(--danger);
}

.form-control.is-invalid:focus {
  box-shadow: 0 0 0 3px rgba(220, 38, 38, .12);
}

.invalid-feedback {
  font-size: .8rem;
  color: var(--danger);
  margin-top: .3rem;
  display: block;
}

textarea.form-control {
  resize: vertical;
  min-height: 100px;
  line-height: 1.6;
}

.form-control-plaintext {
  font-weight: 600;
  color: var(--n-800);
  padding: .5rem 0;
  border-bottom: 1px dashed var(--n-300);
}

.form-text {
  font-size: .8rem;
  color: var(--n-400);
  margin-top: .3rem;
}

/* Input group with icon */
.il-input-group {
  position: relative;
}

.il-input-group .form-control {
  padding-left: 2.5rem;
}

.il-input-group .ig-icon {
  position: absolute;
  left: .75rem;
  top: 50%;
  transform: translateY(-50%);
  color: var(--n-400);
  font-size: .95rem;
  pointer-events: none;
}

.il-table-wrap {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}

.il-table {
  width: 100%;
  border-collapse: collapse;
  font-size: .9rem;
}

.il-table thead th {
  background: var(--n-50);
  padding: .8rem 1rem;
  font-size: .72rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .09em;
  color: var(--n-500);
  border-bottom: 2px solid var(--n-200);
  white-space: nowrap;
}

.il-table tbody td {
  padding: .85rem 1rem;
  border-bottom: 1px solid var(--n-100);
  color: var(--n-800);
  vertical-align: middle;
}

.il-table tbody tr {
  transition: background var(--t1);
}

.il-table tbody tr:last-child td {
  border-bottom: none;
}

.il-table tbody tr:hover {
  background: var(--n-50);
}

/* Bootstrap table compat */
.table {
  font-size: .9rem;
}

.table thead th {
  font-size: .72rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .09em;
  color: var(--n-500);
  background: var(--n-50);
  padding: .85rem 1rem;
  border-bottom: 2px solid var(--n-200);
}

.table tbody td {
  padding: .85rem 1rem;
  border-bottom: 1px solid var(--n-100);
  vertical-align: middle;
}

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

.table-hover tbody tr:hover {
  background: var(--n-50);
}

.il-badge {
  display: inline-flex;
  align-items: center;
  gap: .3rem;
  font-size: .7rem;
  font-weight: 700;
  padding: .25em .75em;
  border-radius: var(--r-pill);
  text-transform: uppercase;
  letter-spacing: .05em;
  white-space: nowrap;
}

.ib-blue {
  background: var(--il-blue-light);
  color: var(--il-blue-dark);
}

.ib-teal {
  background: var(--il-teal-light);
  color: #006B6B;
}

.ib-green {
  background: var(--success-bg);
  color: #166534;
}

.ib-orange {
  background: var(--il-orange-light);
  color: #92400E;
}

.ib-red {
  background: var(--danger-bg);
  color: #7F1D1D;
}

.ib-warn {
  background: var(--warn-bg);
  color: #78350F;
}

.ib-gray {
  background: var(--n-100);
  color: var(--n-600);
}

/* Bootstrap badge override */
.badge {
  font-size: .7rem;
  font-weight: 700;
  padding: .28em .72em;
  border-radius: var(--r-pill);
  letter-spacing: .04em;
  text-transform: uppercase;
}

.badge.bg-success {
  background: var(--success-bg) !important;
  color: #166534 !important;
}

.badge.bg-danger {
  background: var(--danger-bg) !important;
  color: #7F1D1D !important;
}

.badge.bg-warning {
  background: var(--warn-bg) !important;
  color: #78350F !important;
}

.badge.bg-info {
  background: var(--info-bg) !important;
  color: #0C4A6E !important;
}

.badge.bg-primary {
  background: var(--il-blue-light) !important;
  color: var(--il-blue-dark) !important;
}

.badge.bg-secondary {
  background: var(--n-100) !important;
  color: var(--n-600) !important;
}

.badge.bg-dark {
  background: var(--n-200) !important;
  color: var(--n-700) !important;
}

.badge.bg-light {
  background: var(--n-100) !important;
  color: var(--n-600) !important;
}

.alert {
  border: none;
  border-radius: var(--r12);
  padding: .85rem 1.1rem;
  font-size: .875rem;
  font-weight: 500;
  display: flex;
  align-items: flex-start;
  gap: .65rem;
}

.alert-success {
  background: var(--success-bg);
  color: #14532D;
  border: 1px solid #86EFAC;
}

.alert-danger {
  background: var(--danger-bg);
  color: #7F1D1D;
  border: 1px solid #FCA5A5;
}

.alert-warning {
  background: var(--warn-bg);
  color: #78350F;
  border: 1px solid #FCD34D;
}

.alert-info {
  background: var(--info-bg);
  color: #0C4A6E;
  border: 1px solid #7DD3FC;
}

.alert .btn-close {
  margin-left: auto;
  filter: none;
  opacity: .5;
}

.list-group-item {
  border: 1px solid var(--n-200) !important;
  border-radius: var(--r12) !important;
  margin-bottom: .5rem;
  padding: .9rem 1.1rem;
  background: var(--n-0);
  transition: background var(--t1), border-color var(--t1), transform var(--t1);
}

.list-group-item:hover {
  background: var(--n-50);
  border-color: var(--il-blue) !important;
  transform: translateX(2px);
}

.list-group-flush .list-group-item {
  border-radius: 0 !important;
  margin-bottom: 0;
  border-left: none !important;
  border-right: none !important;
  transform: none !important;
}

.list-group-flush .list-group-item:first-child {
  border-top: none !important;
}

.il-hero {
  position: relative;
  background: var(--n-0);
  border-radius: var(--r24);
  overflow: hidden;
  padding: 4.5rem 3.5rem;
  border: 1px solid var(--n-200);
  box-shadow: var(--s2);
}

/* Animated gradient orbs */
.il-hero-orb {
  position: absolute;
  border-radius: 50%;
  filter: blur(60px);
  opacity: .45;
  pointer-events: none;
  animation: orbFloat 8s ease-in-out infinite;
}

.il-hero-orb-1 {
  width: 380px;
  height: 380px;
  background: radial-gradient(circle, var(--il-blue) 0%, transparent 70%);
  top: -120px;
  right: -80px;
  animation-delay: 0s;
}

.il-hero-orb-2 {
  width: 280px;
  height: 280px;
  background: radial-gradient(circle, var(--il-teal) 0%, transparent 70%);
  bottom: -80px;
  left: -60px;
  animation-delay: -3s;
  opacity: .3;
}

.il-hero-orb-3 {
  width: 200px;
  height: 200px;
  background: radial-gradient(circle, var(--il-orange) 0%, transparent 70%);
  top: 50%;
  left: 40%;
  opacity: .15;
  animation-delay: -5s;
}

@keyframes orbFloat {

  0%,
  100% {
    transform: translate(0, 0) scale(1);
  }

  33% {
    transform: translate(12px, -18px) scale(1.04);
  }

  66% {
    transform: translate(-8px, 10px) scale(.97);
  }
}

/* Grid mesh overlay */
.il-hero::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(10, 102, 194, .04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(10, 102, 194, .04) 1px, transparent 1px);
  background-size: 40px 40px;
  mask-image: radial-gradient(ellipse 80% 80% at 50% 50%, black 40%, transparent 100%);
  pointer-events: none;
}

.il-hero-content {
  position: relative;
  z-index: 1;
}

.il-hero-pill {
  display: inline-flex;
  align-items: center;
  gap: .5rem;
  padding: .35rem 1rem;
  background: linear-gradient(135deg, var(--il-blue-light), var(--il-teal-light));
  border: 1px solid rgba(10, 102, 194, .2);
  border-radius: var(--r-pill);
  font-size: .78rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .08em;
  color: var(--il-blue-dark);
  margin-bottom: 1.5rem;
}

.il-hero-pill .dot {
  width: 7px;
  height: 7px;
  background: var(--il-teal);
  border-radius: 50%;
  animation: pulseDot 2s ease-in-out infinite;
}

@keyframes pulseDot {

  0%,
  100% {
    transform: scale(1);
    opacity: 1;
  }

  50% {
    transform: scale(1.4);
    opacity: .7;
  }
}

.il-hero-title {
  font-size: clamp(2.1rem, 5.5vw, 3.4rem);
  font-weight: 800;
  letter-spacing: -.04em;
  line-height: 1.08;
  color: var(--n-900);
  margin-bottom: 1.2rem;
}

.il-hero-title .hl {
  position: relative;
  display: inline-block;
}

.il-hero-title .hl::after {
  content: '';
  position: absolute;
  bottom: 2px;
  left: 0;
  right: 0;
  height: 5px;
  background: linear-gradient(90deg, var(--il-blue), var(--il-teal));
  border-radius: 3px;
  opacity: .35;
}

.il-hero-title .grad {
  background: linear-gradient(135deg, var(--il-blue) 0%, var(--il-teal) 60%, var(--il-orange) 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

.il-hero-sub {
  font-size: 1.08rem;
  color: var(--n-500);
  max-width: 560px;
  line-height: 1.75;
  margin-bottom: 2.25rem;
}

.il-hero-cta {
  display: flex;
  flex-wrap: wrap;
  gap: .75rem;
}

/* Stats strip inside hero */
.il-hero-stats {
  display: flex;
  flex-wrap: wrap;
  gap: 1.5rem;
  margin-top: 2.5rem;
  padding-top: 2rem;
  border-top: 1px solid var(--n-200);
}

.il-hero-stat-item {
  text-align: center;
}

.il-hero-stat-num {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 1.5rem;
  font-weight: 800;
  letter-spacing: -.04em;
  color: var(--il-blue);
  line-height: 1;
  margin-bottom: .25rem;
}

.il-hero-stat-lbl {
  font-size: .78rem;
  color: var(--n-500);
  font-weight: 500;
}

/* Feature cards below hero */
.il-feature-card {
  background: var(--n-0);
  border: 1px solid var(--n-200);
  border-radius: var(--r16);
  padding: 1.75rem 1.5rem;
  text-align: center;
  transition: transform var(--t2), box-shadow var(--t2), border-color var(--t2);
  position: relative;
  overflow: hidden;
}

.il-feature-card::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 3px;
  background: linear-gradient(90deg, var(--il-blue), var(--il-teal));
  transform: scaleX(0);
  transition: transform var(--t3);
  transform-origin: left;
}

.il-feature-card:hover {
  transform: translateY(-5px);
  box-shadow: var(--s3);
  border-color: rgba(10, 102, 194, .25);
}

.il-feature-card:hover::after {
  transform: scaleX(1);
}

.il-fcard-icon {
  width: 58px;
  height: 58px;
  border-radius: var(--r16);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.5rem;
  margin: 0 auto 1.1rem;
  position: relative;
}

.il-fcard-icon::after {
  content: '';
  position: absolute;
  inset: -3px;
  border-radius: inherit;
  border: 1.5px solid transparent;
  background: inherit;
  background-clip: border-box;
  -webkit-mask: linear-gradient(#fff 0 0) padding-box, linear-gradient(#fff 0 0);
  -webkit-mask-composite: xor;
  mask-composite: exclude;
}

.fi-blue {
  background: var(--il-blue-light);
  color: var(--il-blue);
}

.fi-teal {
  background: var(--il-teal-light);
  color: var(--il-teal);
}

.fi-orange {
  background: var(--il-orange-light);
  color: var(--il-orange);
}

.fi-green {
  background: var(--success-bg);
  color: var(--success);
}

.il-fcard-title {
  font-size: 1rem;
  font-weight: 700;
  margin-bottom: .5rem;
}

.il-fcard-desc {
  font-size: .875rem;
  color: var(--n-500);
  line-height: 1.6;
}

.il-auth-shell {
  min-height: calc(100vh - 64px);
  display: grid;
  place-items: center;
  padding: 2rem 1rem;
  background: var(--n-50);
  position: relative;
}

.il-auth-shell::before {
  content: '';
  position: fixed;
  inset: 0;
  background-image:
    linear-gradient(rgba(10, 102, 194, .03) 1px, transparent 1px),
    linear-gradient(90deg, rgba(10, 102, 194, .03) 1px, transparent 1px);
  background-size: 50px 50px;
  pointer-events: none;
  z-index: 0;
}

.il-auth-card {
  position: relative;
  z-index: 1;
  width: 100%;
  background: var(--n-0);
  border: 1px solid var(--n-200);
  border-radius: var(--r24);
  box-shadow: var(--s4);
  overflow: hidden;
  animation: authPop .4s var(--ease) both;
}

@keyframes authPop {
  from {
    opacity: 0;
    transform: translateY(20px) scale(.98);
  }

  to {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}

.il-auth-top {
  padding: 2rem 2rem 1.5rem;
  background: linear-gradient(135deg, var(--n-50) 0%, rgba(219, 234, 254, .4) 100%);
  border-bottom: 1px solid var(--n-200);
  text-align: center;
  position: relative;
  overflow: hidden;
}

.il-auth-top::before {
  content: '';
  position: absolute;
  top: -30px;
  right: -30px;
  width: 150px;
  height: 150px;
  background: radial-gradient(circle, rgba(10, 102, 194, .1), transparent 70%);
  border-radius: 50%;
}

.il-auth-logo {
  width: 54px;
  height: 54px;
  background: linear-gradient(135deg, var(--il-blue), var(--il-teal));
  border-radius: var(--r16);
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  font-size: 1.5rem;
  margin: 0 auto .85rem;
  box-shadow: var(--s-blue);
  position: relative;
  z-index: 1;
}

.il-auth-logo-img {
  height: 64px;
  width: auto;
  object-fit: contain;
  margin: 0 auto .85rem;
  display: block;
  position: relative;
  z-index: 1;
}

.il-auth-top h4 {
  font-size: 1.35rem;
  font-weight: 800;
  letter-spacing: -.03em;
  margin-bottom: .25rem;
  position: relative;
  z-index: 1;
}

.il-auth-top p {
  font-size: .875rem;
  color: var(--n-500);
  position: relative;
  z-index: 1;
}

.il-auth-body {
  padding: 1.75rem 2rem;
}

.il-auth-foot {
  padding: 1.1rem 2rem;
  background: var(--n-50);
  border-top: 1px solid var(--n-200);
  text-align: center;
  font-size: .875rem;
  color: var(--n-500);
}

.section-sep {
  font-size: .68rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .1em;
  color: var(--n-400);
  margin: 1.4rem 0 .75rem;
  padding-bottom: .5rem;
  border-bottom: 1px solid var(--n-200);
}

.il-job-card {
  background: var(--n-0);
  border: 1px solid var(--n-200);
  border-radius: var(--r16);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  transition: transform var(--t2), box-shadow var(--t2), border-color var(--t2);
  position: relative;
}

.il-job-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--s3);
  border-color: rgba(10, 102, 194, .3);
}

.il-job-card::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 3px;
  background: linear-gradient(90deg, var(--il-blue), var(--il-teal));
  transform: scaleX(0);
  transition: transform var(--t2);
  transform-origin: left;
}

.il-job-card:hover::before {
  transform: scaleX(1);
}

.il-job-top {
  padding: 1.2rem 1.3rem .85rem;
  border-bottom: 1px solid var(--n-100);
  background: var(--n-50);
}

.il-job-company {
  display: flex;
  align-items: center;
  gap: .4rem;
  font-size: .78rem;
  color: var(--n-500);
  font-weight: 600;
  margin-bottom: .3rem;
}

.il-job-company .co-dot {
  width: 6px;
  height: 6px;
  background: var(--il-teal);
  border-radius: 50%;
  flex-shrink: 0;
}

.il-job-title {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 1.05rem;
  font-weight: 800;
  color: var(--n-900);
  letter-spacing: -.02em;
}

.il-job-body {
  padding: 1.1rem 1.3rem;
  flex: 1;
}

.il-job-desc {
  font-size: .875rem;
  color: var(--n-500);
  line-height: 1.6;
  margin-bottom: .85rem;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.il-job-tags {
  display: flex;
  flex-wrap: wrap;
  gap: .4rem;
}

.il-job-tag {
  display: inline-flex;
  align-items: center;
  gap: .3rem;
  font-size: .76rem;
  font-weight: 600;
  padding: .25em .65em;
  border-radius: var(--r-pill);
  background: var(--n-100);
  color: var(--n-600);
  border: 1px solid var(--n-200);
}

.il-job-tag.deadline {
  background: #FEF2F2;
  color: #B91C1C;
  border-color: #FECACA;
}

.il-job-tag.ctc {
  background: #F0FDF4;
  color: #166534;
  border-color: #BBF7D0;
}

.il-job-tag.loc {
  background: var(--il-blue-light);
  color: var(--il-blue-dark);
  border-color: #BFDBFE;
}

.il-job-eligibility {
  margin-top: .75rem;
  padding: .65rem .85rem;
  background: var(--warn-bg);
  border: 1px solid #FDE68A;
  border-radius: var(--r8);
  font-size: .8rem;
  color: #78350F;
  line-height: 1.5;
}

.il-job-foot {
  padding: .9rem 1.3rem;
  border-top: 1px solid var(--n-100);
  background: var(--n-0);
  display: flex;
  align-items: center;
  gap: .5rem;
}

.il-empty {
  text-align: center;
  padding: 4rem 2rem;
}

.il-empty-icon {
  width: 72px;
  height: 72px;
  background: var(--n-100);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 2rem;
  color: var(--n-300);
  margin: 0 auto 1.25rem;
}

.il-empty h5 {
  font-size: 1.05rem;
  font-weight: 700;
  color: var(--n-700);
  margin-bottom: .4rem;
}

.il-empty p {
  font-size: .875rem;
  color: var(--n-400);
}

.il-info-row {
  display: flex;
  align-items: flex-start;
  gap: .75rem;
  padding: .65rem 0;
  border-bottom: 1px solid var(--n-100);
}

.il-info-row:last-child {
  border-bottom: none;
}

.il-info-lbl {
  font-size: .75rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .07em;
  color: var(--n-400);
  min-width: 130px;
  padding-top: .1rem;
  flex-shrink: 0;
}

.il-info-val {
  font-size: .9375rem;
  color: var(--n-800);
  font-weight: 500;
}

.il-pending-box {
  border-radius: var(--r12);
  padding: .9rem 1.1rem;
  display: flex;
  align-items: center;
  gap: 1rem;
  border: 1px solid;
}

.il-pending-box.warn {
  background: var(--warn-bg);
  border-color: #FCD34D;
  color: #78350F;
}

.il-pending-box.danger {
  background: var(--danger-bg);
  border-color: #FCA5A5;
  color: #7F1D1D;
}

.il-pending-box .pb-icon {
  font-size: 1.5rem;
  flex-shrink: 0;
}

.il-pending-box .pb-title {
  font-weight: 700;
  font-size: .9375rem;
}

.il-pending-box .pb-sub {
  font-size: .8125rem;
  opacity: .8;
}

footer.il-footer {
  background: var(--n-900);
  color: var(--n-400);
  padding: 2.5rem 0 1.5rem;
  margin-top: auto;
}

.il-footer-brand {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-weight: 800;
  font-size: 1.3rem;
  letter-spacing: -.04em;
  margin-bottom: .35rem;
  display: flex;
  align-items: center;
  gap: .65rem;
}

.il-footer-logo-img {
  height: 36px;
  width: auto;
  object-fit: contain;
}

.il-footer-brand-name {
  color: #fff;
  font-size: 1.25rem;
  font-weight: 800;
  letter-spacing: .04em;
}

.il-footer-brand .t1 {
  color: #fff;
}

.il-footer-brand .t2 {
  color: var(--il-teal);
}

.il-footer-tagline {
  font-size: .8125rem;
  color: var(--n-500);
}

.il-footer-copy {
  font-size: .8rem;
  color: var(--n-600);
  border-top: 1px solid var(--n-800);
  padding-top: 1rem;
  margin-top: 1.5rem;
  text-align: center;
}

.il-footer-links {
  display: flex;
  flex-wrap: wrap;
  gap: .5rem 1.5rem;
  margin-top: .75rem;
}

.il-footer-links a {
  font-size: .8125rem;
  color: var(--n-500);
  transition: color var(--t1);
}

.il-footer-links a:hover {
  color: var(--il-teal);
}

@keyframes fadeUp {
  from {
    opacity: 0;
    transform: translateY(20px);
  }

  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@keyframes fadeIn {
  from {
    opacity: 0;
  }

  to {
    opacity: 1;
  }
}

@keyframes scaleIn {
  from {
    opacity: 0;
    transform: scale(.93);
  }

  to {
    opacity: 1;
    transform: scale(1);
  }
}

.anim-up {
  animation: fadeUp .45s var(--ease) both;
}

.anim-in {
  animation: fadeIn .3s var(--ease) both;
}

.anim-scale {
  animation: scaleIn .4s var(--ease) both;
}

.d1 {
  animation-delay: .07s;
}

.d2 {
  animation-delay: .14s;
}

.d3 {
  animation-delay: .21s;
}

.d4 {
  animation-delay: .28s;
}

.d5 {
  animation-delay: .35s;
}

/* Gradient text util */
.grad-text {
  background: linear-gradient(135deg, var(--il-blue) 0%, var(--il-teal) 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

/* Legacy Bootstrap compat */
.bg-primary-dark,
.bg-success-dark,
.bg-info-dark,
.bg-warning-dark {
  background: transparent !important;
}

.shadow,
.shadow-sm {
  box-shadow: var(--s1) !important;
}

.card {
  background: var(--n-0);
  border: 1px solid var(--n-200);
  border-radius: var(--r16);
  box-shadow: var(--s1);
  transition: box-shadow var(--t2);
  overflow: hidden;
}

.card:hover {
  box-shadow: var(--s2);
}

.card-header {
  background: var(--n-0) !important;
  border-bottom: 1px solid var(--n-200);
  padding: .95rem 1.3rem;
  font-weight: 700;
  border-radius: var(--r16) var(--r16) 0 0 !important;
  display: flex;
  align-items: center;
  gap: .5rem;
  color: var(--n-800) !important;
}

.card-header.bg-primary,
.card-header.bg-success,
.card-header.bg-info,
.card-header.bg-warning,
.card-header.bg-danger {
  background: var(--n-0) !important;
  color: var(--n-800) !important;
}

.card-body {
  padding: 1.3rem;
}

.card-footer {
  border-top: 1px solid var(--n-200);
  background: var(--n-50) !important;
  padding: .85rem 1.3rem;
  border-radius: 0 0 var(--r16) var(--r16) !important;
}

/* Responsive */
@media (max-width: 768px) {
  .il-hero {
    padding: 2.5rem 1.5rem;
  }

  .il-hero-orb-1 {
    width: 200px;
    height: 200px;
  }

  .il-auth-body,
  .il-auth-top {
    padding: 1.25rem;
  }

  .il-auth-shell {
    padding: 1rem .75rem;
    align-items: flex-start;
    padding-top: 1.5rem;
  }

  .il-page-title {
    font-size: 1.25rem;
  }

  .il-stat-val {
    font-size: 2rem;
  }
}

@media (max-width: 576px) {

  .il-table thead th,
  .table thead th {
    font-size: .68rem;
  }

  .il-table tbody td,
  .table tbody td {
    font-size: .85rem;
    padding: .7rem .75rem;
  }

  .btn-lg {
    padding: .65rem 1.25rem;
    font-size: .875rem;
  }

  .il-hero-title {
    font-size: 1.85rem;
  }
}

/* Print */
@media print {

  .il-nav,
  footer {
    display: none;
  }

  .il-hero-orb {
    display: none;
  }

  body {
    background: #fff;
  }
}

.il-google-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: .75rem;
  width: 100%;
  padding: .72rem 1.25rem;
  background: #fff;
  border: 1.5px solid var(--n-300);
  border-radius: var(--r8);
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: .9375rem;
  font-weight: 600;
  color: var(--n-800);
  text-decoration: none !important;
  cursor: pointer;
  transition: background var(--t1), border-color var(--t1), box-shadow var(--t1), transform var(--t1);
  margin-bottom: 1rem;
  letter-spacing: -.01em;
  box-shadow: var(--s1);
}

.il-google-btn:hover {
  background: var(--n-50);
  border-color: var(--n-400);
  box-shadow: var(--s2);
  transform: translateY(-1px);
  color: var(--n-900);
}

.il-google-btn:active {
  transform: scale(.98);
  box-shadow: var(--s1);
}

.il-linkedin-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: .75rem;
  width: 100%;
  padding: .72rem 1.25rem;
  background: #0A66C2;
  border: 1.5px solid #0A66C2;
  border-radius: var(--r8);
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: .9375rem;
  font-weight: 600;
  color: #fff;
  text-decoration: none !important;
  cursor: pointer;
  transition: background var(--t1), box-shadow var(--t1), transform var(--t1);
  margin-bottom: 1rem;
  letter-spacing: -.01em;
  box-shadow: var(--s1);
}

.il-linkedin-btn:hover {
  background: #004182;
  border-color: #004182;
  box-shadow: var(--s2);
  transform: translateY(-1px);
  color: #fff;
}

.il-linkedin-btn:active {
  transform: scale(.98);
  box-shadow: var(--s1);
}

.il-oauth-btns {
  display: flex;
  flex-direction: column;
  gap: 0;
}

.il-google-note {
  font-size: .8rem;
  color: var(--n-400);
  text-align: center;
  margin-bottom: .5rem;
  margin-top: -.25rem;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: .35rem;
}

/* Auth divider (OR separator) */
.il-auth-divider {
  display: flex;
  align-items: center;
  gap: .85rem;
  margin: 1.25rem 0;
  color: var(--n-400);
  font-size: .8rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .06em;
}

.il-auth-divider::before,
.il-auth-divider::after {
  content: '';
  flex: 1;
  height: 1px;
  background: var(--n-200);
}


/* Custom Cursor */
@media(pointer:fine){
  .il2-cursor{position:fixed;width:12px;height:12px;border:2px solid var(--il-teal);border-radius:50%;pointer-events:none;z-index:9999;transform:translate(-50%,-50%);transition:width .2s,height .2s,border-color .2s,background .2s}
  .il2-cursor-glow{position:fixed;width:40px;height:40px;background:radial-gradient(circle,rgba(0,160,160,.15),transparent 70%);border-radius:50%;pointer-events:none;z-index:9998;transform:translate(-50%,-50%);transition:width .3s,height .3s,opacity .3s}
  .il2-cursor-hover{width:20px;height:20px;background:rgba(0,160,160,.12);border-color:var(--il-blue)}
  .il2-glow-hover{width:60px;height:60px;opacity:.8}
}

/* Hero */
.il2-hero{position:relative;min-height:100vh;display:flex;align-items:center;overflow:hidden;background:#0a0f1a}
.il2-hero-video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.35;z-index:0}
.il2-hero-overlay{position:absolute;inset:0;background:linear-gradient(135deg,rgba(10,15,26,.85) 0%,rgba(0,60,80,.7) 50%,rgba(10,15,26,.85) 100%);z-index:1}
.il2-gradient-mesh{position:absolute;inset:0;z-index:2;background:radial-gradient(ellipse 50% 60% at 20% 50%,rgba(0,160,160,.12),transparent),radial-gradient(ellipse 40% 50% at 80% 30%,rgba(10,102,194,.1),transparent),radial-gradient(ellipse 30% 40% at 60% 80%,rgba(22,163,74,.08),transparent);animation:meshMove 12s ease-in-out infinite alternate}
@keyframes meshMove{0%{opacity:.8;transform:scale(1)}100%{opacity:1;transform:scale(1.05) translateX(2%)}}
.il2-particles{position:absolute;inset:0;z-index:2;overflow:hidden}
.il2-particle{position:absolute;width:3px;height:3px;background:rgba(0,160,160,.4);border-radius:50%;animation:particleFloat 6s ease-in-out infinite}
@keyframes particleFloat{0%,100%{transform:translateY(0) scale(1);opacity:.3}50%{transform:translateY(-80px) scale(1.5);opacity:.7}}
.il2-hero-inner{position:relative;z-index:3;padding:6rem 0 4rem}

/* Hero text */
.il2-hero-pill{display:inline-flex;align-items:center;gap:.5rem;padding:.4rem 1rem;background:rgba(0,160,160,.12);border:1px solid rgba(0,160,160,.25);border-radius:999px;font-size:.78rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--il-teal);margin-bottom:1.5rem;backdrop-filter:blur(8px)}
.il2-pulse-dot{width:7px;height:7px;background:var(--il-teal);border-radius:50%;animation:pulseDot 2s ease-in-out infinite}
.il2-hero-title{font-family:'Plus Jakarta Sans',sans-serif;font-size:clamp(2.2rem,5.5vw,4rem);font-weight:800;letter-spacing:-.04em;line-height:1.08;color:#fff;margin-bottom:1.2rem}
.il2-grad-text{background:linear-gradient(135deg,var(--il-teal),#22c55e,var(--il-blue));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.il2-hero-sub{font-size:1.1rem;color:rgba(255,255,255,.6);max-width:520px;line-height:1.75;margin-bottom:2.25rem}
.il2-hero-sub strong{color:#fff}
.il2-hero-cta{display:flex;flex-wrap:wrap;gap:.75rem}

/* Buttons */
.il2-btn{display:inline-flex;align-items:center;gap:.45rem;font-family:'Plus Jakarta Sans',sans-serif;font-weight:600;font-size:.9rem;padding:.72rem 1.6rem;border-radius:12px;border:none;cursor:pointer;text-decoration:none!important;transition:all .25s cubic-bezier(.4,0,.2,1);white-space:nowrap;letter-spacing:-.01em}
.il2-btn-primary{background:linear-gradient(135deg,var(--il-teal),var(--il-blue));color:#fff;box-shadow:0 4px 20px rgba(0,160,160,.35)}
.il2-btn-primary:hover{box-shadow:0 6px 30px rgba(0,160,160,.5);transform:translateY(-2px);color:#fff}
.il2-btn-glass{background:rgba(255,255,255,.08);color:#fff;border:1px solid rgba(255,255,255,.15);backdrop-filter:blur(8px)}
.il2-btn-glass:hover{background:rgba(255,255,255,.15);border-color:rgba(255,255,255,.3);color:#fff;transform:translateY(-2px)}
.il2-btn-outline{background:transparent;color:rgba(255,255,255,.7);border:1px solid rgba(255,255,255,.2)}
.il2-btn-outline:hover{color:#fff;border-color:rgba(255,255,255,.5);transform:translateY(-2px)}
.il2-btn-white{background:#fff;color:var(--n-900);box-shadow:0 4px 20px rgba(0,0,0,.15)}
.il2-btn-white:hover{transform:translateY(-2px);box-shadow:0 8px 30px rgba(0,0,0,.2);color:var(--n-900)}
.il2-btn-glass-white{background:rgba(255,255,255,.12);color:#fff;border:1px solid rgba(255,255,255,.25);backdrop-filter:blur(8px)}
.il2-btn-glass-white:hover{background:rgba(255,255,255,.22);color:#fff;transform:translateY(-2px)}
.il2-btn-sm{padding:.5rem 1.1rem;font-size:.82rem;border-radius:10px}

/* Dashboard card */
.il2-dashboard-wrap{position:relative;perspective:1000px}
.il2-glow-behind{position:absolute;inset:-30px;background:radial-gradient(ellipse at center,rgba(0,160,160,.25),rgba(10,102,194,.15),transparent 70%);filter:blur(40px);border-radius:50%;animation:glowPulse 4s ease-in-out infinite alternate;z-index:0}
@keyframes glowPulse{0%{opacity:.6;transform:scale(.95)}100%{opacity:1;transform:scale(1.05)}}
.il2-dashboard-card{position:relative;z-index:1;background:rgba(255,255,255,.06);backdrop-filter:blur(16px);border:1px solid rgba(255,255,255,.1);border-radius:20px;padding:1.5rem;box-shadow:0 20px 60px rgba(0,0,0,.3);transition:transform .4s}
.il2-dash-bar{display:flex;align-items:center;gap:.75rem;margin-bottom:1.25rem}
.il2-dash-dots{display:flex;gap:6px}
.il2-dash-dots span{width:10px;height:10px;border-radius:50%}
.il2-dash-label{font-size:.72rem;color:rgba(255,255,255,.4);font-weight:600;letter-spacing:.05em}
.il2-dash-stats{display:grid;grid-template-columns:1fr 1fr;gap:.75rem;margin-bottom:1rem}
.il2-dash-stat{border-radius:14px;padding:1rem;color:#fff}
.il2-dash-stat-blue{background:linear-gradient(135deg,#004182,#0A66C2)}
.il2-dash-stat-teal{background:linear-gradient(135deg,#006B6B,#00A0A0)}
.il2-dash-stat-lbl{font-size:.65rem;font-weight:700;opacity:.7;text-transform:uppercase;letter-spacing:.08em}
.il2-dash-stat-val{font-size:2rem;font-weight:800;line-height:1;margin-top:.2rem}
.il2-dash-list{display:flex;flex-direction:column;gap:.5rem}
.il2-dash-item{display:flex;justify-content:space-between;align-items:center;padding:.7rem .9rem;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.08);border-radius:12px;transition:all .2s}
.il2-dash-item:hover{background:rgba(255,255,255,.1);border-color:rgba(0,160,160,.3);transform:translateX(4px)}
.il2-dash-co{font-size:.7rem;color:rgba(255,255,255,.5);font-weight:600}
.il2-dash-role{font-size:.88rem;font-weight:700;color:#fff}
.il2-dash-pay{font-size:.75rem;background:rgba(0,160,160,.2);color:var(--il-teal);padding:.25em .65em;border-radius:20px;font-weight:700}

/* Sections */
.il2-section{padding:6rem 0;position:relative}
.il2-section-alt{background:var(--n-50)}
.il2-section-head{text-align:center;max-width:640px;margin:0 auto 3.5rem}
.il2-section-head h2{font-size:clamp(1.6rem,3.5vw,2.5rem);font-weight:800;letter-spacing:-.03em;color:var(--n-900);margin-bottom:.6rem}
.il2-section-head p{font-size:1rem;color:var(--n-500);line-height:1.7}
.il2-section-badge{display:inline-flex;align-items:center;gap:.45rem;padding:.3rem .9rem;background:linear-gradient(135deg,var(--il-blue-light),var(--il-teal-light));border:1px solid rgba(0,160,160,.15);border-radius:999px;font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--il-teal);margin-bottom:1rem}
.il2-section-badge i{font-size:.8rem}

/* Glassmorphism */
.il2-glass-card{background:rgba(255,255,255,.7);backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.5);border-radius:20px;box-shadow:0 4px 24px rgba(15,23,42,.06);transition:transform .35s cubic-bezier(.4,0,.2,1),box-shadow .35s,border-color .35s}
.il2-glass-card:hover{box-shadow:0 12px 40px rgba(15,23,42,.1);border-color:rgba(0,160,160,.2)}
.il2-section-alt .il2-glass-card{background:rgba(255,255,255,.85)}

/* Scroll Reveal */
.il2-reveal{opacity:0;transform:translateY(30px);transition:opacity .7s cubic-bezier(.4,0,.2,1),transform .7s cubic-bezier(.4,0,.2,1)}
.il2-reveal.il2-visible{opacity:1;transform:translateY(0)}

/* Trust / Marquee */
.il2-trust{padding-top:4rem;padding-bottom:4rem;overflow:hidden}
.il2-marquee-wrap{position:relative;overflow:hidden;padding:.5rem 0}
.il2-marquee-fade{position:absolute;top:0;bottom:0;width:100px;z-index:2;pointer-events:none}
.il2-marquee-fade-l{left:0;background:linear-gradient(90deg,var(--n-50) 0%,transparent)}
.il2-marquee-fade-r{right:0;background:linear-gradient(270deg,var(--n-50) 0%,transparent)}
.il2-trust .il2-marquee-fade-l{background:linear-gradient(90deg,#fff 0%,transparent)}
.il2-trust .il2-marquee-fade-r{background:linear-gradient(270deg,#fff 0%,transparent)}
.il2-marquee-track{display:flex;align-items:center;gap:2rem;width:max-content;animation:il2Marquee calc(var(--count,6)*4s) linear infinite}
.il2-marquee-track:hover{animation-play-state:paused}
.il2-marquee-rev{animation-name:il2MarqueeRev}
@keyframes il2Marquee{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}
@keyframes il2MarqueeRev{0%{transform:translateX(-50%)}100%{transform:translateX(0)}}
.il2-logo-card{flex-shrink:0;width:170px;height:95px;background:#fff;border:1px solid var(--n-200);border-radius:16px;display:flex;align-items:center;justify-content:center;padding:1rem;box-shadow:0 2px 8px rgba(15,23,42,.05);transition:all .25s}
.il2-logo-card:hover{box-shadow:0 8px 24px rgba(0,160,160,.12);border-color:var(--il-teal);transform:translateY(-3px) scale(1.03)}
.il2-logo-card img{max-width:100%;max-height:100%;object-fit:contain;filter:grayscale(30%) opacity(.8);transition:filter .25s}
.il2-logo-card:hover img{filter:grayscale(0%) opacity(1)}

/* How It Works */
.il2-steps{display:flex;align-items:flex-start;justify-content:center;gap:0;flex-wrap:wrap}
.il2-step{padding:2rem 1.5rem;text-align:center;flex:0 0 200px;position:relative}
.il2-step .il2-step-num{position:absolute;top:12px;right:16px;font-size:.7rem;font-weight:800;color:var(--il-teal);opacity:.5}
.il2-step-icon{width:56px;height:56px;border-radius:16px;background:var(--il-blue-light);color:var(--il-blue);display:flex;align-items:center;justify-content:center;font-size:1.4rem;margin:0 auto 1rem;transition:transform .3s,box-shadow .3s}
.il2-step:hover .il2-step-icon{transform:scale(1.1);box-shadow:0 8px 24px rgba(10,102,194,.2)}
.il2-icon-teal{background:var(--il-teal-light);color:var(--il-teal)}
.il2-icon-green{background:#dcfce7;color:#16a34a}
.il2-icon-orange{background:#fff3e3;color:#f5820d}
.il2-step h4{font-size:.95rem;font-weight:700;margin-bottom:.4rem;color:var(--n-900)}
.il2-step p{font-size:.82rem;color:var(--n-500);line-height:1.55}
.il2-step-connector{display:flex;align-items:center;padding-top:2.5rem;color:var(--n-300);font-size:1.2rem}

/* Features */
.il2-features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.5rem}
.il2-feature-block{padding:2.5rem 2rem}
.il2-feature-badge{display:inline-flex;align-items:center;gap:.4rem;padding:.3rem .8rem;border-radius:999px;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;margin-bottom:1.2rem}
.il2-fb-blue{background:var(--il-blue-light);color:var(--il-blue-dark)}
.il2-fb-teal{background:var(--il-teal-light);color:#006B6B}
.il2-fb-green{background:#dcfce7;color:#166534}
.il2-feature-block h3{font-size:1.35rem;font-weight:800;letter-spacing:-.02em;margin-bottom:.6rem;color:var(--n-900)}
.il2-feature-block>p{font-size:.9rem;color:var(--n-500);line-height:1.65;margin-bottom:1.5rem}
.il2-feature-list{list-style:none;padding:0;display:flex;flex-direction:column;gap:.65rem}
.il2-feature-list li{display:flex;align-items:center;gap:.6rem;font-size:.88rem;font-weight:500;color:var(--n-700)}
.il2-feature-list li i{color:var(--il-teal);font-size:.9rem;flex-shrink:0}

/* Stats */
.il2-stats-section{background:linear-gradient(135deg,#0a0f1a 0%,#0d2137 50%,#0a1a2a 100%);color:#fff}
.il2-stats-section .il2-section-head h2{color:#fff}
.il2-stats-section .il2-section-head p{color:rgba(255,255,255,.5)}
.il2-stats-section .il2-section-badge{background:rgba(0,160,160,.15);border-color:rgba(0,160,160,.25);color:var(--il-teal)}
.il2-stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:1.25rem;max-width:900px;margin:0 auto}
.il2-stats-section .il2-glass-card{background:rgba(255,255,255,.04);border-color:rgba(255,255,255,.08);backdrop-filter:blur(8px)}
.il2-stats-section .il2-glass-card:hover{border-color:rgba(0,160,160,.3);background:rgba(255,255,255,.07)}
.il2-stat-card{padding:2rem 1.5rem;text-align:center}
.il2-stat-number{font-family:'Plus Jakarta Sans',sans-serif;font-size:2.8rem;font-weight:800;letter-spacing:-.04em;line-height:1;background:linear-gradient(135deg,var(--il-teal),#22c55e);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;display:inline}
.il2-stat-suffix{display:inline;font-size:1.8rem;font-weight:700;background:linear-gradient(135deg,var(--il-teal),#22c55e);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.il2-stat-label{font-size:.78rem;font-weight:600;color:rgba(255,255,255,.5);margin-top:.5rem;text-transform:uppercase;letter-spacing:.06em}

/* Testimonials */
.il2-testimonial-track{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.5rem}
.il2-testimonial{padding:2rem}
.il2-testimonial-stars{color:#f59e0b;font-size:.9rem;margin-bottom:.75rem;letter-spacing:2px}
.il2-testimonial p{font-size:.95rem;color:var(--n-600);line-height:1.7;margin-bottom:1.25rem;font-style:italic}
.il2-testimonial-author{display:flex;align-items:center;gap:.75rem}
.il2-avatar{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700;color:#fff;flex-shrink:0}
.il2-avatar-blue{background:linear-gradient(135deg,var(--il-blue),#1d7fe8)}
.il2-avatar-teal{background:linear-gradient(135deg,#006b6b,var(--il-teal))}
.il2-avatar-green{background:linear-gradient(135deg,#166534,#22c55e)}
.il2-testimonial-author strong{font-size:.88rem;color:var(--n-800)}
.il2-testimonial-author span{font-size:.78rem;color:var(--n-500)}

/* Activity Feed */
.il2-feed{padding:0;overflow:hidden;max-width:700px;margin:0 auto}
.il2-feed-item{display:flex;align-items:center;gap:1rem;padding:1rem 1.5rem;border-bottom:1px solid rgba(0,0,0,.04);transition:background .2s}
.il2-feed-item:last-child{border-bottom:none}
.il2-feed-item:hover{background:rgba(0,160,160,.03)}
.il2-feed-item i{font-size:1.1rem;flex-shrink:0;width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:10px}
.il2-fi-blue{background:var(--il-blue-light);color:var(--il-blue)}
.il2-fi-teal{background:var(--il-teal-light);color:var(--il-teal)}
.il2-fi-green{background:#dcfce7;color:#16a34a}
.il2-fi-orange{background:#fff3e3;color:#f5820d}
.il2-feed-item span{flex:1;font-size:.88rem;color:var(--n-600)}
.il2-feed-item strong{color:var(--n-800)}
.il2-feed-item time{font-size:.72rem;color:var(--n-400);white-space:nowrap}
.il2-badge-live{background:rgba(220,38,38,.08);border-color:rgba(220,38,38,.15);color:#dc2626}
.il2-live-dot{width:7px;height:7px;background:#dc2626;border-radius:50%;animation:pulseDot 1.5s ease-in-out infinite}

/* Drives */
.il2-drives-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1.5rem}
.il2-drive-card{padding:1.75rem 1.5rem;display:flex;flex-direction:column;gap:1rem}
.il2-drive-top{display:flex;align-items:center;gap:.75rem}
.il2-drive-co-icon{width:40px;height:40px;border-radius:12px;background:linear-gradient(135deg,var(--il-blue),#1d7fe8);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:.9rem;flex-shrink:0}
.il2-ci-teal{background:linear-gradient(135deg,#006b6b,var(--il-teal))}
.il2-ci-green{background:linear-gradient(135deg,#166534,#22c55e)}
.il2-ci-orange{background:linear-gradient(135deg,#b85e05,#f5820d)}
.il2-drive-top strong{font-size:.9rem;color:var(--n-800)}
.il2-drive-top span{font-size:.75rem;color:var(--n-500)}
.il2-drive-card h4{font-size:1.05rem;font-weight:700;color:var(--n-900);margin:0}
.il2-drive-tags{display:flex;flex-wrap:wrap;gap:.4rem}
.il2-drive-tags span{font-size:.72rem;font-weight:600;padding:.25em .65em;border-radius:999px;background:var(--il-teal-light);color:#006b6b;border:1px solid rgba(0,160,160,.15)}

/* CTA */
.il2-cta{position:relative;padding:6rem 0;background:linear-gradient(135deg,#0a0f1a,#0d2137,#0a1a2a);overflow:hidden;text-align:center}
.il2-cta-glow{position:absolute;top:50%;left:50%;width:600px;height:400px;background:radial-gradient(ellipse,rgba(0,160,160,.2),rgba(10,102,194,.1),transparent 70%);transform:translate(-50%,-50%);filter:blur(60px);animation:glowPulse 5s ease-in-out infinite alternate}
.il2-cta-inner{position:relative;z-index:1}
.il2-cta h2{font-size:clamp(1.6rem,4vw,2.8rem);font-weight:800;color:#fff;letter-spacing:-.03em;margin-bottom:.75rem}
.il2-cta p{font-size:1.05rem;color:rgba(255,255,255,.55);max-width:520px;margin:0 auto 2rem;line-height:1.7}
.il2-cta-btns{display:flex;justify-content:center;gap:.75rem;flex-wrap:wrap}

/* Responsive */
@media(max-width:991px){
  .il2-hero-inner{padding:4rem 0 3rem}
  .il2-steps{flex-direction:column;align-items:center}
  .il2-step{flex:unset;width:100%;max-width:320px}
  .il2-step-connector{transform:rotate(90deg);padding:0;margin:.5rem 0}
}
@media(max-width:768px){
  .il2-hero-title{font-size:2rem}
  .il2-section{padding:4rem 0}
  .il2-features-grid{grid-template-columns:1fr}
  .il2-stats-grid{grid-template-columns:repeat(2,1fr)}
  .il2-testimonial-track{grid-template-columns:1fr}
  .il2-drives-grid{grid-template-columns:1fr}
  .il2-marquee-fade{width:50px}
  .il2-logo-card{width:130px;height:75px;padding:.75rem}
  .il2-cursor,.il2-cursor-glow{display:none!important}
}
@media(max-width:480px){
  .il2-hero-cta{flex-direction:column}
  .il2-btn{width:100%;justify-content:center}
  .il2-cta-btns{flex-direction:column;align-items:center}
  .il2-cta-btns .il2-btn{width:100%;max-width:300px}
}