/* ============================================================
   TAPGO DESIGN SYSTEM v2.0
   Premium HR Platform — Compete with Factorial & Sesame HR
   Loaded after tapgou.css — overrides & extends the base theme
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Inter:ital,opsz,wght@0,14..32,300;0,14..32,400;0,14..32,500;0,14..32,600;0,14..32,700;0,14..32,800;1,14..32,400&display=swap');

/* ============================================================
   1. DESIGN TOKENS
   ============================================================ */
:root {
  /* Brand Palette */
  --tg-brand-primary:       #081FF7;
  --tg-brand-primary-dark:  #0618C4;
  --tg-brand-primary-light: #EEF0FE;
  --tg-brand-accent:        #6C63FF;
  --tg-brand-accent-dark:   #4F46E5;
  --tg-brand-accent-light:  #A78BFA;
  --tg-brand-warm:          #F59E0B;
  --tg-brand-warm-light:    #FCD34D;

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

  /* Semantic */
  --tg-success:       #10B981;
  --tg-success-light: #D1FAE5;
  --tg-success-dark:  #047857;
  --tg-warning:       #F59E0B;
  --tg-warning-light: #FEF3C7;
  --tg-warning-dark:  #B45309;
  --tg-danger:        #EF4444;
  --tg-danger-light:  #FEE2E2;
  --tg-danger-dark:   #B91C1C;
  --tg-info:          #3B82F6;
  --tg-info-light:    #DBEAFE;
  --tg-info-dark:     #1D4ED8;

  /* Risk */
  --tg-risk-critical: #DC2626;
  --tg-risk-high:     #EA580C;
  --tg-risk-medium:   #D97706;
  --tg-risk-low:      #65A30D;
  --tg-risk-ok:       #10B981;

  /* Surfaces */
  --tg-surface-0:       #FFFFFF;
  --tg-surface-1:       #F8FAFC;
  --tg-surface-2:       #F1F5F9;
  --tg-surface-elevated:#FFFFFF;
  --tg-surface-glass:   rgba(255, 255, 255, 0.72);

  /* Sidebar — siempre oscuro, independiente del tema de contenido */
  --tg-sidebar-bg:      #2D1B69;
  --tg-sidebar-bg-hover:#3D2B84;
  --tg-sidebar-text:    rgba(255,255,255,0.75);
  --tg-sidebar-text-active: #FFFFFF;
  --tg-sidebar-border:  rgba(255,255,255,0.08);

  /* Typography */
  --tg-font-sans: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  --tg-font-mono: 'JetBrains Mono', 'Fira Code', 'Cascadia Code', monospace;

  --tg-text-xs:   0.75rem;
  --tg-text-sm:   0.875rem;
  --tg-text-base: 1rem;
  --tg-text-lg:   1.125rem;
  --tg-text-xl:   1.25rem;
  --tg-text-2xl:  1.5rem;
  --tg-text-3xl:  1.875rem;
  --tg-text-4xl:  2.25rem;

  --tg-font-normal:   400;
  --tg-font-medium:   500;
  --tg-font-semibold: 600;
  --tg-font-bold:     700;
  --tg-font-extrabold:800;

  --tg-leading-tight:  1.25;
  --tg-leading-snug:   1.375;
  --tg-leading-normal: 1.5;
  --tg-leading-relaxed:1.625;

  /* Spacing */
  --tg-space-1:  0.25rem;
  --tg-space-2:  0.5rem;
  --tg-space-3:  0.75rem;
  --tg-space-4:  1rem;
  --tg-space-5:  1.25rem;
  --tg-space-6:  1.5rem;
  --tg-space-8:  2rem;
  --tg-space-10: 2.5rem;
  --tg-space-12: 3rem;
  --tg-space-16: 4rem;
  --tg-space-20: 5rem;

  /* Borders */
  --tg-border-color:  #E5E7EB;
  --tg-border-focus:  #081FF7;
  --tg-border-width:  1px;

  /* Radius */
  --tg-radius-xs:   0.25rem;
  --tg-radius-sm:   0.375rem;
  --tg-radius-md:   0.5rem;
  --tg-radius-lg:   0.75rem;
  --tg-radius-xl:   1rem;
  --tg-radius-2xl:  1.5rem;
  --tg-radius-3xl:  2rem;
  --tg-radius-full: 9999px;

  /* Shadows */
  --tg-shadow-xs:      0 1px 2px 0 rgb(0 0 0 / 0.05);
  --tg-shadow-sm:      0 1px 3px 0 rgb(0 0 0 / 0.1), 0 1px 2px -1px rgb(0 0 0 / 0.1);
  --tg-shadow-md:      0 4px 6px -1px rgb(0 0 0 / 0.07), 0 2px 4px -2px rgb(0 0 0 / 0.07);
  --tg-shadow-lg:      0 10px 15px -3px rgb(0 0 0 / 0.08), 0 4px 6px -4px rgb(0 0 0 / 0.06);
  --tg-shadow-xl:      0 20px 25px -5px rgb(0 0 0 / 0.08), 0 8px 10px -6px rgb(0 0 0 / 0.06);
  --tg-shadow-2xl:     0 25px 50px -12px rgb(0 0 0 / 0.18);
  --tg-shadow-colored: 0 8px 25px -5px rgb(8 31 247 / 0.28);
  --tg-shadow-glow:    0 0 0 3px rgb(8 31 247 / 0.15);
  --tg-shadow-inner:   inset 0 2px 4px 0 rgb(0 0 0 / 0.06);

  /* Transitions */
  --tg-transition-fast:   100ms ease;
  --tg-transition-base:   160ms ease;
  --tg-transition-slow:   280ms ease;
  --tg-transition-spring: 200ms cubic-bezier(0.34, 1.56, 0.64, 1);

  /* Layout */
  --tg-sidebar-width:           260px;
  --tg-sidebar-collapsed-width: 72px;
  --tg-topbar-height:           64px;
  --tg-content-max-width:       1400px;

  /* Z-Index scale */
  --tg-z-base:           0;
  --tg-z-raised:         10;
  --tg-z-dropdown:       1000;
  --tg-z-sticky:         1020;
  --tg-z-fixed:          1030;
  --tg-z-modal-backdrop: 1040;
  --tg-z-modal:          1050;
  --tg-z-popover:        1060;
  --tg-z-tooltip:        1070;
  --tg-z-toast:          1080;
}

/* ============================================================
   2. RESET & BASE
   ============================================================ */
*, *::before, *::after {
  box-sizing: border-box;
}

html {
  -webkit-text-size-adjust: 100%;
  scroll-behavior: smooth;
}

body {
  font-family: var(--tg-font-sans) !important;
  font-size: var(--tg-text-sm);
  font-weight: var(--tg-font-normal);
  line-height: var(--tg-leading-normal);
  color: var(--tg-gray-800);
  background-color: var(--tg-gray-50);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

/* Custom scrollbar */
::-webkit-scrollbar {
  width: 6px;
  height: 6px;
}
::-webkit-scrollbar-track {
  background: var(--tg-gray-100);
  border-radius: var(--tg-radius-full);
}
::-webkit-scrollbar-thumb {
  background: var(--tg-gray-300);
  border-radius: var(--tg-radius-full);
}
::-webkit-scrollbar-thumb:hover {
  background: var(--tg-gray-400);
}

/* Selection */
::selection {
  background-color: rgb(8 31 247 / 0.12);
  color: var(--tg-brand-primary);
}

/* Focus ring — Bug 6: accessibility focus states */
:focus-visible {
  outline: 2px solid var(--tg-brand-accent);
  outline-offset: 2px;
}

button:focus-visible,
a:focus-visible,
input:focus-visible,
select:focus-visible,
textarea:focus-visible {
  outline: 2px solid var(--tg-brand-accent);
  outline-offset: 2px;
  border-radius: var(--tg-radius-sm);
}

/* ============================================================
   3. TYPOGRAPHY
   ============================================================ */
h1, h2, h3, h4, h5, h6,
.tg-h1, .tg-h2, .tg-h3, .tg-h4, .tg-h5, .tg-h6 {
  font-family: var(--tg-font-sans) !important;
  font-weight: var(--tg-font-bold) !important;
  line-height: var(--tg-leading-tight) !important;
  color: var(--tg-gray-900) !important;
  letter-spacing: -0.015em;
}

h1, .tg-h1 { font-size: var(--tg-text-4xl) !important; letter-spacing: -0.03em; }
h2, .tg-h2 { font-size: var(--tg-text-3xl) !important; letter-spacing: -0.025em; }
h3, .tg-h3 { font-size: var(--tg-text-2xl) !important; }
h4, .tg-h4 { font-size: var(--tg-text-xl) !important; }
h5, .tg-h5 { font-size: var(--tg-text-lg) !important; }
h6, .tg-h6 { font-size: var(--tg-text-base) !important; }

.tg-display {
  font-size: clamp(2rem, 5vw, 3.5rem);
  font-weight: var(--tg-font-extrabold);
  letter-spacing: -0.04em;
  line-height: 1.1;
}

.tg-lead {
  font-size: var(--tg-text-lg);
  font-weight: var(--tg-font-normal);
  color: var(--tg-gray-600);
  line-height: var(--tg-leading-relaxed);
}

.tg-label {
  font-size: var(--tg-text-xs);
  font-weight: var(--tg-font-semibold);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--tg-gray-500);
}

.tg-caption {
  font-size: var(--tg-text-xs);
  color: var(--tg-gray-500);
  line-height: var(--tg-leading-normal);
}

.tg-overline {
  font-size: 0.6875rem;
  font-weight: var(--tg-font-semibold);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--tg-gray-400);
}

code, .tg-code {
  font-family: var(--tg-font-mono);
  font-size: 0.875em;
  background-color: var(--tg-gray-100);
  color: var(--tg-brand-accent-dark);
  padding: 0.1em 0.35em;
  border-radius: var(--tg-radius-sm);
}

pre, .tg-pre {
  font-family: var(--tg-font-mono);
  font-size: var(--tg-text-sm);
  background-color: var(--tg-gray-900);
  color: #E2E8F0;
  padding: var(--tg-space-4);
  border-radius: var(--tg-radius-lg);
  overflow-x: auto;
  line-height: var(--tg-leading-relaxed);
}

.tg-truncate {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.tg-text-gradient {
  background: linear-gradient(135deg, var(--tg-brand-primary) 0%, var(--tg-brand-accent) 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

/* ============================================================
   4. LAYOUT SYSTEM
   ============================================================ */
.tg-layout {
  display: flex;
  min-height: 100vh;
}

.tg-main {
  flex: 1;
  min-width: 0;
  margin-left: var(--tg-sidebar-width);
  padding-top: var(--tg-topbar-height);
  background-color: var(--tg-gray-50);
  transition: margin-left var(--tg-transition-slow);
}

.tg-main.sidebar-collapsed {
  margin-left: var(--tg-sidebar-collapsed-width);
}

.tg-content {
  padding: var(--tg-space-6);
  max-width: var(--tg-content-max-width);
}

.tg-content-full {
  padding: var(--tg-space-6);
}

/* Grid helpers */
.tg-grid {
  display: grid;
  gap: var(--tg-space-5);
}

.tg-grid-2 { grid-template-columns: repeat(2, 1fr); }
.tg-grid-3 { grid-template-columns: repeat(3, 1fr); }
.tg-grid-4 { grid-template-columns: repeat(4, 1fr); }
.tg-grid-auto { grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); }

.tg-flex { display: flex; }
.tg-flex-col { flex-direction: column; }
.tg-items-center { align-items: center; }
.tg-justify-between { justify-content: space-between; }
.tg-gap-2 { gap: var(--tg-space-2); }
.tg-gap-3 { gap: var(--tg-space-3); }
.tg-gap-4 { gap: var(--tg-space-4); }
.tg-gap-5 { gap: var(--tg-space-5); }

/* ============================================================
   5. SIDEBAR NAVIGATION
   ============================================================ */
/* Bug 5: sidebar overflow must be visible so dropdowns escape */
.tg-sidebar {
  position: fixed;
  top: 0;
  left: 0;
  width: var(--tg-sidebar-width);
  height: 100vh;
  background-color: var(--tg-sidebar-bg);
  border-right: 1px solid var(--tg-sidebar-border);
  display: flex;
  flex-direction: column;
  overflow: visible;
  z-index: var(--tg-z-fixed);
  transition: width var(--tg-transition-slow);
}

.tg-sidebar.collapsed {
  width: var(--tg-sidebar-collapsed-width);
}

/* Logo area */
.tg-sidebar-logo {
  display: flex;
  align-items: center;
  gap: var(--tg-space-3);
  height: var(--tg-topbar-height);
  padding: 0 var(--tg-space-5);
  border-bottom: 1px solid var(--tg-sidebar-border);
  flex-shrink: 0;
  text-decoration: none;
  overflow: hidden;
}

.tg-sidebar-logo-icon {
  width: 36px;
  height: 36px;
  flex-shrink: 0;
  background: rgba(255,255,255,0.15);
  border-radius: var(--tg-radius-lg);
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  font-weight: var(--tg-font-extrabold);
  font-size: 16px;
  letter-spacing: -1px;
}

.tg-sidebar-logo-text {
  font-size: 18px;
  font-weight: var(--tg-font-extrabold);
  color: #FFFFFF;
  letter-spacing: -0.5px;
  white-space: nowrap;
  transition: opacity var(--tg-transition-base), width var(--tg-transition-base);
}

.tg-sidebar-logo-text span {
  color: rgba(255,255,255,0.7);
}

.tg-sidebar.collapsed .tg-sidebar-logo-text {
  opacity: 0;
  width: 0;
  pointer-events: none;
}

/* Nav scroll area — Bug 5: allow x-overflow so dropdowns can escape */
.tg-sidebar-nav {
  flex: 1;
  overflow-y: auto;
  overflow-x: visible;
  padding: var(--tg-space-3) 0;
}

.tg-sidebar-nav::-webkit-scrollbar { width: 3px; }
.tg-sidebar-nav::-webkit-scrollbar-thumb { background: var(--tg-gray-200); }

/* Nav section label — sobre fondo oscuro del sidebar */
.tg-nav-section-label {
  font-size: 0.625rem;
  font-weight: var(--tg-font-semibold);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: rgba(255,255,255,0.35);
  padding: var(--tg-space-4) var(--tg-space-5) var(--tg-space-2);
  white-space: nowrap;
  overflow: hidden;
  transition: opacity var(--tg-transition-base);
}

.tg-sidebar.collapsed .tg-nav-section-label {
  opacity: 0;
}

/* Nav item */
.tg-nav-item {
  list-style: none;
  padding: 0 var(--tg-space-3);
  margin-bottom: 2px;
}

.tg-nav-link {
  display: flex;
  align-items: center;
  gap: var(--tg-space-3);
  padding: 9px var(--tg-space-3);
  border-radius: var(--tg-radius-lg);
  color: var(--tg-sidebar-text);
  font-size: var(--tg-text-sm);
  font-weight: var(--tg-font-medium);
  text-decoration: none;
  white-space: nowrap;
  overflow: hidden;
  transition: background-color var(--tg-transition-fast),
              color var(--tg-transition-fast),
              box-shadow var(--tg-transition-fast);
  position: relative;
}

.tg-nav-link .tg-nav-icon {
  width: 20px;
  height: 20px;
  flex-shrink: 0;
  font-size: 20px;
  color: rgba(255,255,255,0.5);
  transition: color var(--tg-transition-fast);
  display: flex;
  align-items: center;
  justify-content: center;
}

.tg-nav-link .tg-nav-label {
  flex: 1;
  transition: opacity var(--tg-transition-base);
}

.tg-sidebar.collapsed .tg-nav-link .tg-nav-label {
  opacity: 0;
  width: 0;
  pointer-events: none;
}

.tg-nav-link .tg-nav-badge {
  flex-shrink: 0;
  min-width: 18px;
  height: 18px;
  background: var(--tg-danger);
  color: #fff;
  font-size: 10px;
  font-weight: var(--tg-font-bold);
  border-radius: var(--tg-radius-full);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0 4px;
  transition: opacity var(--tg-transition-base);
}

.tg-sidebar.collapsed .tg-nav-badge {
  opacity: 0;
}

/* Hover — tono más claro sobre fondo navy */
.tg-nav-link:hover {
  background-color: rgba(255,255,255,0.1);
  color: var(--tg-sidebar-text-active);
  text-decoration: none;
}

.tg-nav-link:hover .tg-nav-icon {
  color: rgba(255,255,255,0.85);
}

/* Active — highlight blanco semitransparente */
.tg-nav-link.active,
.tg-nav-item.active > .tg-nav-link {
  background-color: rgba(255,255,255,0.15);
  color: var(--tg-sidebar-text-active);
  font-weight: var(--tg-font-semibold);
}

.tg-nav-link.active .tg-nav-icon,
.tg-nav-item.active > .tg-nav-link .tg-nav-icon {
  color: var(--tg-sidebar-text-active);
}

/* Active left accent bar */
.tg-nav-link.active::before {
  content: '';
  position: absolute;
  left: -12px;
  top: 50%;
  transform: translateY(-50%);
  width: 3px;
  height: 60%;
  background: var(--tg-brand-primary);
  border-radius: 0 3px 3px 0;
}

/* Collapsed tooltip */
.tg-sidebar.collapsed .tg-nav-item {
  position: relative;
}

.tg-sidebar.collapsed .tg-nav-item:hover::after {
  content: attr(data-label);
  position: absolute;
  left: calc(var(--tg-sidebar-collapsed-width) - 4px);
  top: 50%;
  transform: translateY(-50%);
  background: var(--tg-gray-900);
  color: #fff;
  font-size: var(--tg-text-xs);
  font-weight: var(--tg-font-medium);
  white-space: nowrap;
  padding: 5px 10px;
  border-radius: var(--tg-radius-md);
  z-index: var(--tg-z-tooltip);
  pointer-events: none;
  box-shadow: var(--tg-shadow-md);
}

/* Sidebar toggle button */
.tg-sidebar-toggle {
  position: absolute;
  top: 50%;
  right: -12px;
  transform: translateY(-50%);
  width: 24px;
  height: 24px;
  background: var(--tg-surface-0);
  border: 1px solid var(--tg-border-color);
  border-radius: var(--tg-radius-full);
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  z-index: 2;
  box-shadow: var(--tg-shadow-sm);
  transition: background-color var(--tg-transition-fast),
              transform var(--tg-transition-base);
}

.tg-sidebar-toggle:hover {
  background: var(--tg-brand-primary-light);
}

.tg-sidebar-toggle svg {
  width: 12px;
  height: 12px;
  color: var(--tg-gray-500);
  transition: transform var(--tg-transition-base);
}

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

/* User profile at bottom of sidebar — Bug 5: overflow visible for dropdown */
.tg-sidebar-user {
  padding: var(--tg-space-3);
  border-top: 1px solid var(--tg-sidebar-border);
  flex-shrink: 0;
  position: relative;
  overflow: visible;
}

.tg-sidebar-user-inner {
  display: flex;
  align-items: center;
  gap: var(--tg-space-3);
  padding: var(--tg-space-2) var(--tg-space-2);
  border-radius: var(--tg-radius-lg);
  cursor: pointer;
  transition: background-color var(--tg-transition-fast);
  overflow: hidden;
}

.tg-sidebar-user-inner:hover {
  background-color: rgba(255,255,255,0.1);
}

.tg-sidebar-user-avatar {
  width: 32px;
  height: 32px;
  border-radius: var(--tg-radius-full);
  background: rgba(255,255,255,0.2);
  color: #fff;
  font-size: var(--tg-text-sm);
  font-weight: var(--tg-font-bold);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  overflow: hidden;
}

.tg-sidebar-user-avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.tg-sidebar-user-info {
  flex: 1;
  min-width: 0;
  transition: opacity var(--tg-transition-base);
}

.tg-sidebar.collapsed .tg-sidebar-user-info {
  opacity: 0;
  width: 0;
}

.tg-sidebar-user-name {
  font-size: var(--tg-text-sm);
  font-weight: var(--tg-font-semibold);
  color: var(--tg-sidebar-text-active);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.tg-sidebar-user-role {
  font-size: var(--tg-text-xs);
  color: rgba(255,255,255,0.5);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

/* Bug 5: sidebar user dropdown — positioned above the user area */
.tg-sidebar-user-dropdown {
  position: absolute;
  bottom: 100%;
  left: 0;
  right: 0;
  z-index: 1060;
}

/* Bug 4: dropdowns inside sidebar must clear the sidebar z-index */
.tg-sidebar .tg-dropdown-menu {
  z-index: 1060;
}

/* Bug 7: mobile sidebar backdrop */
.tg-sidebar-backdrop {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.5);
  z-index: 1029;
  backdrop-filter: blur(2px);
  -webkit-backdrop-filter: blur(2px);
}

.tg-sidebar-backdrop.active {
  display: block;
}

/* ============================================================
   6. TOPBAR
   ============================================================ */
.tg-topbar {
  position: fixed;
  top: 0;
  left: var(--tg-sidebar-width);
  right: 0;
  height: var(--tg-topbar-height);
  background: var(--tg-surface-0);
  border-bottom: 1px solid var(--tg-border-color);
  display: flex;
  align-items: center;
  padding: 0 var(--tg-space-6);
  gap: var(--tg-space-4);
  z-index: var(--tg-z-sticky);
  transition: left var(--tg-transition-slow);
}

.tg-topbar.sidebar-collapsed {
  left: var(--tg-sidebar-collapsed-width);
}

/* Breadcrumbs */
.tg-breadcrumb {
  display: flex;
  align-items: center;
  gap: var(--tg-space-2);
  font-size: var(--tg-text-sm);
  color: var(--tg-gray-500);
  flex: 1;
  min-width: 0;
}

.tg-breadcrumb-item {
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.tg-breadcrumb-item a {
  color: var(--tg-gray-500);
  text-decoration: none;
  transition: color var(--tg-transition-fast);
}

.tg-breadcrumb-item a:hover {
  color: var(--tg-brand-primary);
}

.tg-breadcrumb-item.active {
  font-weight: var(--tg-font-semibold);
  color: var(--tg-gray-800);
}

.tg-breadcrumb-sep {
  color: var(--tg-gray-300);
  flex-shrink: 0;
}

/* Topbar search */
.tg-topbar-search {
  position: relative;
  max-width: 320px;
  width: 100%;
}

.tg-topbar-search-input {
  width: 100%;
  height: 36px;
  padding: 0 var(--tg-space-3) 0 36px;
  background-color: var(--tg-gray-100);
  border: 1px solid transparent;
  border-radius: var(--tg-radius-full);
  font-size: var(--tg-text-sm);
  font-family: var(--tg-font-sans);
  color: var(--tg-gray-800);
  transition: background-color var(--tg-transition-fast),
              border-color var(--tg-transition-fast),
              box-shadow var(--tg-transition-fast);
}

.tg-topbar-search-input:focus {
  background-color: var(--tg-surface-0);
  border-color: var(--tg-brand-primary);
  box-shadow: var(--tg-shadow-glow);
  outline: none;
}

.tg-topbar-search-icon {
  position: absolute;
  left: 10px;
  top: 50%;
  transform: translateY(-50%);
  color: var(--tg-gray-400);
  pointer-events: none;
  font-size: 16px;
}

/* Topbar actions */
.tg-topbar-actions {
  display: flex;
  align-items: center;
  gap: var(--tg-space-2);
}

.tg-topbar-btn {
  width: 36px;
  height: 36px;
  border-radius: var(--tg-radius-lg);
  background: transparent;
  border: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--tg-gray-500);
  position: relative;
  transition: background-color var(--tg-transition-fast),
              color var(--tg-transition-fast);
}

.tg-topbar-btn:hover {
  background-color: var(--tg-gray-100);
  color: var(--tg-gray-700);
}

.tg-topbar-btn .tg-notif-dot {
  position: absolute;
  top: 6px;
  right: 6px;
  width: 8px;
  height: 8px;
  background: var(--tg-danger);
  border-radius: var(--tg-radius-full);
  border: 2px solid var(--tg-surface-0);
}

/* Topbar user menu */
.tg-topbar-user {
  display: flex;
  align-items: center;
  gap: var(--tg-space-2);
  padding: var(--tg-space-1) var(--tg-space-3);
  border-radius: var(--tg-radius-lg);
  cursor: pointer;
  transition: background-color var(--tg-transition-fast);
  text-decoration: none;
}

.tg-topbar-user:hover {
  background-color: var(--tg-gray-100);
}

.tg-topbar-user-avatar {
  width: 32px;
  height: 32px;
  border-radius: var(--tg-radius-full);
  background: linear-gradient(135deg, var(--tg-brand-primary), var(--tg-brand-accent));
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  font-size: var(--tg-text-xs);
  font-weight: var(--tg-font-bold);
  overflow: hidden;
  flex-shrink: 0;
}

.tg-topbar-user-avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.tg-topbar-user-name {
  font-size: var(--tg-text-sm);
  font-weight: var(--tg-font-semibold);
  color: var(--tg-gray-800);
}

/* ============================================================
   7. CARDS & PANELS
   ============================================================ */

/* Base card */
.tg-card {
  background: var(--tg-surface-0);
  border: 1px solid var(--tg-border-color);
  border-radius: var(--tg-radius-xl);
  box-shadow: var(--tg-shadow-sm);
  overflow: hidden;
  transition: box-shadow var(--tg-transition-base),
              transform var(--tg-transition-base),
              border-color var(--tg-transition-base);
}

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

.tg-card-body {
  padding: var(--tg-space-5);
}

.tg-card-header {
  padding: var(--tg-space-4) var(--tg-space-5);
  border-bottom: 1px solid var(--tg-border-color);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--tg-space-3);
}

.tg-card-title {
  font-size: var(--tg-text-base);
  font-weight: var(--tg-font-semibold);
  color: var(--tg-gray-800);
  margin: 0;
}

.tg-card-subtitle {
  font-size: var(--tg-text-sm);
  color: var(--tg-gray-500);
  margin-top: 2px;
}

.tg-card-footer {
  padding: var(--tg-space-3) var(--tg-space-5);
  border-top: 1px solid var(--tg-border-color);
  background: var(--tg-gray-50);
}

/* Interactive card */
.tg-card-interactive {
  cursor: pointer;
}

.tg-card-interactive:hover {
  border-color: var(--tg-brand-primary);
  box-shadow: var(--tg-shadow-colored);
  transform: translateY(-2px);
}

/* Stat card */
.tg-stat-card {
  background: var(--tg-surface-0);
  border: 1px solid var(--tg-border-color);
  border-radius: var(--tg-radius-xl);
  padding: var(--tg-space-5);
  box-shadow: var(--tg-shadow-sm);
  transition: box-shadow var(--tg-transition-base), transform var(--tg-transition-base);
  display: flex;
  flex-direction: column;
  gap: var(--tg-space-3);
}

.tg-stat-card:hover {
  box-shadow: var(--tg-shadow-md);
  transform: translateY(-2px);
}

.tg-stat-card-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
}

.tg-stat-card-icon {
  width: 44px;
  height: 44px;
  border-radius: var(--tg-radius-lg);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 22px;
  flex-shrink: 0;
}

.tg-stat-card-icon.primary   { background: var(--tg-brand-primary-light); color: var(--tg-brand-primary); }
.tg-stat-card-icon.success   { background: var(--tg-success-light);       color: var(--tg-success-dark); }
.tg-stat-card-icon.warning   { background: var(--tg-warning-light);       color: var(--tg-warning-dark); }
.tg-stat-card-icon.danger    { background: var(--tg-danger-light);        color: var(--tg-danger-dark); }
.tg-stat-card-icon.info      { background: var(--tg-info-light);          color: var(--tg-info-dark); }

.tg-stat-value {
  font-size: var(--tg-text-3xl);
  font-weight: var(--tg-font-extrabold);
  color: var(--tg-gray-900);
  line-height: 1;
  letter-spacing: -0.03em;
}

.tg-stat-label {
  font-size: var(--tg-text-sm);
  color: var(--tg-gray-500);
  font-weight: var(--tg-font-medium);
}

.tg-stat-trend {
  display: inline-flex;
  align-items: center;
  gap: 3px;
  font-size: var(--tg-text-xs);
  font-weight: var(--tg-font-semibold);
  padding: 2px 7px;
  border-radius: var(--tg-radius-full);
}

.tg-stat-trend.up   { background: var(--tg-success-light); color: var(--tg-success-dark); }
.tg-stat-trend.down { background: var(--tg-danger-light);  color: var(--tg-danger-dark); }
.tg-stat-trend.flat { background: var(--tg-gray-100);      color: var(--tg-gray-500); }

/* Glass card */
.tg-card-glass {
  background: var(--tg-surface-glass);
  backdrop-filter: blur(16px) saturate(180%);
  -webkit-backdrop-filter: blur(16px) saturate(180%);
  border: 1px solid rgba(255, 255, 255, 0.5);
  border-radius: var(--tg-radius-xl);
  box-shadow: var(--tg-shadow-lg);
}

/* Gradient hero card */
.tg-card-gradient {
  background: linear-gradient(135deg, var(--tg-brand-primary) 0%, var(--tg-brand-accent) 100%);
  border: none;
  border-radius: var(--tg-radius-xl);
  color: #fff;
  padding: var(--tg-space-6);
  box-shadow: var(--tg-shadow-colored);
  position: relative;
  overflow: hidden;
}

.tg-card-gradient::before {
  content: '';
  position: absolute;
  top: -40%;
  right: -10%;
  width: 300px;
  height: 300px;
  background: rgba(255, 255, 255, 0.08);
  border-radius: 50%;
  pointer-events: none;
}

.tg-card-gradient::after {
  content: '';
  position: absolute;
  bottom: -30%;
  left: 5%;
  width: 200px;
  height: 200px;
  background: rgba(255, 255, 255, 0.05);
  border-radius: 50%;
  pointer-events: none;
}

.tg-card-gradient *:not(.tg-card-gradient::before):not(.tg-card-gradient::after) {
  position: relative;
  z-index: 1;
}

.tg-card-gradient h1,
.tg-card-gradient h2,
.tg-card-gradient h3,
.tg-card-gradient h4,
.tg-card-gradient h5,
.tg-card-gradient .tg-stat-value {
  color: #fff !important;
}

.tg-card-gradient .tg-stat-label,
.tg-card-gradient p {
  color: rgba(255, 255, 255, 0.8) !important;
}

/* Elevated card */
.tg-card-elevated {
  box-shadow: var(--tg-shadow-xl);
  border: none;
}

/* ============================================================
   8. BUTTONS
   ============================================================ */
.tg-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--tg-space-2);
  padding: 9px var(--tg-space-4);
  font-family: var(--tg-font-sans);
  font-size: var(--tg-text-sm);
  font-weight: var(--tg-font-semibold);
  line-height: 1;
  border-radius: var(--tg-radius-lg);
  border: 1px solid transparent;
  cursor: pointer;
  text-decoration: none;
  white-space: nowrap;
  transition: background-color var(--tg-transition-fast),
              color var(--tg-transition-fast),
              border-color var(--tg-transition-fast),
              box-shadow var(--tg-transition-fast),
              transform var(--tg-transition-spring);
  user-select: none;
  -webkit-user-select: none;
}

.tg-btn:focus-visible {
  outline: 2px solid var(--tg-brand-primary);
  outline-offset: 2px;
}

.tg-btn:active { transform: translateY(0) scale(0.98) !important; }

.tg-btn-xs  { padding: 5px 10px;                  font-size: 0.75rem; }
.tg-btn-sm  { padding: 7px var(--tg-space-3);      font-size: var(--tg-text-sm); }
.tg-btn-lg  { padding: 12px var(--tg-space-6);     font-size: var(--tg-text-base); }
.tg-btn-xl  { padding: 14px var(--tg-space-8);     font-size: var(--tg-text-lg); }
.tg-btn-full{ width: 100%; }

/* Primary */
.tg-btn-primary {
  background-color: var(--tg-brand-primary);
  border-color: var(--tg-brand-primary);
  color: #fff;
}
.tg-btn-primary:hover {
  background-color: var(--tg-brand-primary-dark);
  border-color: var(--tg-brand-primary-dark);
  box-shadow: var(--tg-shadow-colored);
  transform: translateY(-1px);
  color: #fff;
  text-decoration: none;
}

/* Secondary */
.tg-btn-secondary {
  background-color: var(--tg-surface-0);
  border-color: var(--tg-border-color);
  color: var(--tg-gray-700);
}
.tg-btn-secondary:hover {
  background-color: var(--tg-gray-50);
  border-color: var(--tg-gray-300);
  box-shadow: var(--tg-shadow-sm);
  transform: translateY(-1px);
  color: var(--tg-gray-800);
  text-decoration: none;
}

/* Ghost */
.tg-btn-ghost {
  background-color: transparent;
  border-color: transparent;
  color: var(--tg-gray-600);
}
.tg-btn-ghost:hover {
  background-color: var(--tg-gray-100);
  color: var(--tg-gray-800);
  text-decoration: none;
}

/* Danger */
.tg-btn-danger {
  background-color: var(--tg-danger);
  border-color: var(--tg-danger);
  color: #fff;
}
.tg-btn-danger:hover {
  background-color: var(--tg-danger-dark);
  border-color: var(--tg-danger-dark);
  box-shadow: 0 8px 20px -4px rgb(239 68 68 / 0.4);
  transform: translateY(-1px);
  color: #fff;
  text-decoration: none;
}

/* Soft variants */
.tg-btn-soft-primary {
  background-color: var(--tg-brand-primary-light);
  border-color: var(--tg-brand-primary-light);
  color: var(--tg-brand-primary);
}
.tg-btn-soft-primary:hover {
  background-color: rgba(8, 31, 247, 0.15);
  color: var(--tg-brand-primary-dark);
  text-decoration: none;
}

.tg-btn-soft-success {
  background-color: var(--tg-success-light);
  border-color: var(--tg-success-light);
  color: var(--tg-success-dark);
}
.tg-btn-soft-danger {
  background-color: var(--tg-danger-light);
  border-color: var(--tg-danger-light);
  color: var(--tg-danger-dark);
}
.tg-btn-soft-warning {
  background-color: var(--tg-warning-light);
  border-color: var(--tg-warning-light);
  color: var(--tg-warning-dark);
}

/* Icon button */
.tg-btn-icon {
  width: 36px;
  height: 36px;
  padding: 0;
  flex-shrink: 0;
}
.tg-btn-icon.tg-btn-sm { width: 30px; height: 30px; }
.tg-btn-icon.tg-btn-lg { width: 44px; height: 44px; }
.tg-btn-icon.tg-btn-xl { width: 52px; height: 52px; }

/* Button group */
.tg-btn-group {
  display: inline-flex;
  border-radius: var(--tg-radius-lg);
  overflow: hidden;
  border: 1px solid var(--tg-border-color);
}
.tg-btn-group .tg-btn {
  border-radius: 0;
  border: none;
  border-right: 1px solid var(--tg-border-color);
}
.tg-btn-group .tg-btn:last-child { border-right: none; }

/* Loading state */
.tg-btn.loading {
  position: relative;
  color: transparent !important;
  pointer-events: none;
}
.tg-btn.loading::after {
  content: '';
  position: absolute;
  width: 14px;
  height: 14px;
  top: 50%;
  left: 50%;
  margin: -7px 0 0 -7px;
  border: 2px solid rgba(255, 255, 255, 0.35);
  border-top-color: #fff;
  border-radius: 50%;
  animation: tg-spin 0.7s linear infinite;
}

.tg-btn-secondary.loading::after,
.tg-btn-ghost.loading::after {
  border-color: rgba(8, 31, 247, 0.2);
  border-top-color: var(--tg-brand-primary);
}

/* Disabled */
.tg-btn:disabled,
.tg-btn.disabled {
  opacity: 0.5;
  cursor: not-allowed;
  pointer-events: none;
}

/* ============================================================
   9. FORMS
   ============================================================ */
.tg-form-group {
  margin-bottom: var(--tg-space-4);
}

.tg-label,
label.tg-form-label {
  display: block;
  font-size: var(--tg-text-sm);
  font-weight: var(--tg-font-medium);
  color: var(--tg-gray-700);
  margin-bottom: var(--tg-space-1);
}

.tg-label-required::after {
  content: ' *';
  color: var(--tg-danger);
}

.tg-input,
.tg-select,
.tg-textarea {
  width: 100%;
  padding: 9px var(--tg-space-3);
  font-family: var(--tg-font-sans);
  font-size: var(--tg-text-sm);
  color: var(--tg-gray-800);
  background-color: var(--tg-gray-50);
  border: 1px solid var(--tg-border-color);
  border-radius: var(--tg-radius-lg);
  transition: border-color var(--tg-transition-fast),
              box-shadow var(--tg-transition-fast),
              background-color var(--tg-transition-fast);
  -webkit-appearance: none;
  appearance: none;
}

.tg-input:hover,
.tg-select:hover,
.tg-textarea:hover {
  border-color: var(--tg-gray-300);
}

.tg-input:focus,
.tg-select:focus,
.tg-textarea:focus {
  border-color: var(--tg-brand-primary);
  box-shadow: var(--tg-shadow-glow);
  background-color: var(--tg-surface-0);
  outline: none;
}

.tg-input::placeholder,
.tg-textarea::placeholder {
  color: var(--tg-gray-400);
}

.tg-input.error,
.tg-select.error,
.tg-textarea.error {
  border-color: var(--tg-danger);
  box-shadow: 0 0 0 3px rgb(239 68 68 / 0.12);
}

.tg-input.success {
  border-color: var(--tg-success);
}

.tg-select {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%2394A3B8' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right var(--tg-space-3) center;
  padding-right: var(--tg-space-8);
  cursor: pointer;
}

.tg-textarea {
  resize: vertical;
  min-height: 80px;
  line-height: var(--tg-leading-relaxed);
}

/* Input sizes */
.tg-input-sm { padding: 6px var(--tg-space-3); font-size: var(--tg-text-xs); }
.tg-input-lg { padding: 12px var(--tg-space-4); font-size: var(--tg-text-base); }

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

.tg-input-group .tg-input {
  padding-left: 36px;
}

.tg-input-group-icon {
  position: absolute;
  left: 11px;
  top: 50%;
  transform: translateY(-50%);
  color: var(--tg-gray-400);
  pointer-events: none;
  font-size: 18px;
  line-height: 1;
}

.tg-input-group-append {
  position: absolute;
  right: var(--tg-space-3);
  top: 50%;
  transform: translateY(-50%);
}

/* Input helper text */
.tg-form-hint {
  font-size: var(--tg-text-xs);
  color: var(--tg-gray-500);
  margin-top: var(--tg-space-1);
}

.tg-form-error {
  font-size: var(--tg-text-xs);
  color: var(--tg-danger);
  margin-top: var(--tg-space-1);
  display: flex;
  align-items: center;
  gap: 4px;
}

/* Checkbox & Radio */
.tg-check {
  display: flex;
  align-items: center;
  gap: var(--tg-space-2);
  cursor: pointer;
  user-select: none;
}

.tg-check-input {
  width: 16px;
  height: 16px;
  border: 2px solid var(--tg-gray-300);
  border-radius: var(--tg-radius-sm);
  background: var(--tg-surface-0);
  flex-shrink: 0;
  cursor: pointer;
  -webkit-appearance: none;
  appearance: none;
  transition: background-color var(--tg-transition-fast),
              border-color var(--tg-transition-fast);
  position: relative;
}

.tg-check-input:checked {
  background-color: var(--tg-brand-primary);
  border-color: var(--tg-brand-primary);
}

.tg-check-input:checked::after {
  content: '';
  position: absolute;
  top: 1px;
  left: 4px;
  width: 5px;
  height: 8px;
  border: 2px solid #fff;
  border-top: none;
  border-left: none;
  transform: rotate(40deg);
}

.tg-radio-input {
  border-radius: 50%;
}

.tg-radio-input:checked::after {
  content: '';
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 6px;
  height: 6px;
  background: #fff;
  border-radius: 50%;
}

.tg-check-label {
  font-size: var(--tg-text-sm);
  color: var(--tg-gray-700);
}

/* Toggle switch */
.tg-switch {
  display: inline-flex;
  align-items: center;
  gap: var(--tg-space-2);
  cursor: pointer;
}

.tg-switch-track {
  width: 40px;
  height: 22px;
  background: var(--tg-gray-300);
  border-radius: var(--tg-radius-full);
  position: relative;
  transition: background-color var(--tg-transition-base);
  flex-shrink: 0;
}

.tg-switch-input {
  position: absolute;
  opacity: 0;
  width: 0;
  height: 0;
}

.tg-switch-input:checked + .tg-switch-track {
  background: var(--tg-brand-primary);
}

.tg-switch-thumb {
  position: absolute;
  top: 3px;
  left: 3px;
  width: 16px;
  height: 16px;
  background: #fff;
  border-radius: 50%;
  box-shadow: var(--tg-shadow-sm);
  transition: transform var(--tg-transition-spring);
}

.tg-switch-input:checked ~ .tg-switch-thumb,
.tg-switch-input:checked + .tg-switch-track .tg-switch-thumb {
  transform: translateX(18px);
}

.tg-switch-label {
  font-size: var(--tg-text-sm);
  color: var(--tg-gray-700);
}

/* File upload */
.tg-file-drop {
  border: 2px dashed var(--tg-gray-300);
  border-radius: var(--tg-radius-xl);
  padding: var(--tg-space-8) var(--tg-space-4);
  text-align: center;
  cursor: pointer;
  transition: border-color var(--tg-transition-fast),
              background-color var(--tg-transition-fast);
}

.tg-file-drop:hover,
.tg-file-drop.dragover {
  border-color: var(--tg-brand-primary);
  background-color: var(--tg-brand-primary-light);
}

/* ============================================================
   10. TABLES
   ============================================================ */
.tg-table-container {
  overflow-x: auto;
  border-radius: var(--tg-radius-xl);
  border: 1px solid var(--tg-border-color);
  background: var(--tg-surface-0);
  box-shadow: var(--tg-shadow-sm);
}

.tg-table {
  width: 100%;
  border-collapse: collapse;
  font-size: var(--tg-text-sm);
}

.tg-table thead {
  background: var(--tg-gray-50);
  border-bottom: 1px solid var(--tg-border-color);
}

.tg-table thead th {
  padding: 11px var(--tg-space-4);
  font-size: var(--tg-text-xs);
  font-weight: var(--tg-font-semibold);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--tg-gray-500);
  text-align: left;
  white-space: nowrap;
  border-bottom: 1px solid var(--tg-border-color);
}

.tg-table thead th.sortable {
  cursor: pointer;
  user-select: none;
}

.tg-table thead th.sortable:hover {
  color: var(--tg-gray-700);
}

.tg-table thead th .sort-icon {
  display: inline-block;
  margin-left: 4px;
  opacity: 0.4;
  font-size: 12px;
}

.tg-table thead th.asc .sort-icon,
.tg-table thead th.desc .sort-icon {
  opacity: 1;
  color: var(--tg-brand-primary);
}

.tg-table tbody tr {
  border-bottom: 1px solid var(--tg-border-color);
  transition: background-color var(--tg-transition-fast);
}

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

.tg-table tbody tr:hover {
  background-color: var(--tg-gray-50);
}

.tg-table tbody td {
  padding: var(--tg-space-3) var(--tg-space-4);
  color: var(--tg-gray-700);
  vertical-align: middle;
}

.tg-table tbody td.tg-td-primary {
  font-weight: var(--tg-font-semibold);
  color: var(--tg-gray-900);
}

/* Table actions column */
.tg-table .tg-td-actions {
  display: flex;
  align-items: center;
  gap: var(--tg-space-1);
  opacity: 0;
  transition: opacity var(--tg-transition-fast);
}

.tg-table tbody tr:hover .tg-td-actions {
  opacity: 1;
}

/* Table striped */
.tg-table.striped tbody tr:nth-child(even) {
  background-color: var(--tg-gray-50);
}

/* ============================================================
   11. BADGES & PILLS
   ============================================================ */
.tg-badge {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 3px 8px;
  font-size: var(--tg-text-xs);
  font-weight: var(--tg-font-semibold);
  border-radius: var(--tg-radius-full);
  white-space: nowrap;
  letter-spacing: 0.01em;
}

.tg-badge-dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  flex-shrink: 0;
}

/* Semantic badges */
.tg-badge-success { background: var(--tg-success-light); color: var(--tg-success-dark); }
.tg-badge-warning { background: var(--tg-warning-light); color: var(--tg-warning-dark); }
.tg-badge-danger  { background: var(--tg-danger-light);  color: var(--tg-danger-dark); }
.tg-badge-info    { background: var(--tg-info-light);    color: var(--tg-info-dark); }
.tg-badge-primary { background: var(--tg-brand-primary-light); color: var(--tg-brand-primary); }
.tg-badge-neutral { background: var(--tg-gray-100); color: var(--tg-gray-600); }

/* Solid badges */
.tg-badge-success.solid { background: var(--tg-success); color: #fff; }
.tg-badge-warning.solid { background: var(--tg-warning); color: #fff; }
.tg-badge-danger.solid  { background: var(--tg-danger);  color: #fff; }
.tg-badge-primary.solid { background: var(--tg-brand-primary); color: #fff; }

/* Count badge (small circle) */
.tg-count-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 20px;
  height: 20px;
  padding: 0 5px;
  font-size: 11px;
  font-weight: var(--tg-font-bold);
  border-radius: var(--tg-radius-full);
  background: var(--tg-danger);
  color: #fff;
}

/* Role badge */
.tg-role-badge {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 3px 10px;
  font-size: 11px;
  font-weight: var(--tg-font-semibold);
  border-radius: var(--tg-radius-full);
}

.tg-role-admin      { background: #EDE9FE; color: #5B21B6; }
.tg-role-gestor     { background: var(--tg-brand-primary-light); color: var(--tg-brand-primary-dark); }
.tg-role-supervisor { background: var(--tg-info-light); color: var(--tg-info-dark); }
.tg-role-user       { background: var(--tg-gray-100); color: var(--tg-gray-600); }

/* ============================================================
   12. ALERTS & TOASTS
   ============================================================ */
.tg-alert {
  display: flex;
  align-items: flex-start;
  gap: var(--tg-space-3);
  padding: var(--tg-space-4);
  border-radius: var(--tg-radius-lg);
  border: 1px solid transparent;
  font-size: var(--tg-text-sm);
}

.tg-alert-icon {
  flex-shrink: 0;
  width: 20px;
  height: 20px;
  margin-top: 1px;
}

.tg-alert-content { flex: 1; }
.tg-alert-title {
  font-weight: var(--tg-font-semibold);
  margin-bottom: 2px;
}

.tg-alert-success {
  background: var(--tg-success-light);
  border-color: rgba(16, 185, 129, 0.25);
  color: var(--tg-success-dark);
}

.tg-alert-warning {
  background: var(--tg-warning-light);
  border-color: rgba(245, 158, 11, 0.25);
  color: var(--tg-warning-dark);
}

.tg-alert-danger {
  background: var(--tg-danger-light);
  border-color: rgba(239, 68, 68, 0.25);
  color: var(--tg-danger-dark);
}

.tg-alert-info {
  background: var(--tg-info-light);
  border-color: rgba(59, 130, 246, 0.25);
  color: var(--tg-info-dark);
}

/* Compliance alert */
.tg-alert-compliance {
  background: #FFF7ED;
  border-color: rgba(234, 88, 12, 0.25);
  color: #9A3412;
  border-left: 4px solid var(--tg-risk-high);
}

/* Toast container */
.tg-toast-container {
  position: fixed;
  top: calc(var(--tg-topbar-height) + 16px);
  right: var(--tg-space-5);
  z-index: var(--tg-z-toast);
  display: flex;
  flex-direction: column;
  gap: var(--tg-space-2);
  pointer-events: none;
  max-width: 380px;
  width: calc(100vw - 40px);
}

.tg-toast {
  background: var(--tg-gray-900);
  color: #F3F4F6;
  padding: var(--tg-space-3) var(--tg-space-4);
  border-radius: var(--tg-radius-lg);
  box-shadow: var(--tg-shadow-xl);
  display: flex;
  align-items: center;
  gap: var(--tg-space-3);
  font-size: var(--tg-text-sm);
  font-weight: var(--tg-font-medium);
  pointer-events: all;
  animation: tg-slide-in-right var(--tg-transition-slow) both;
  border: 1px solid rgba(255, 255, 255, 0.08);
}

.tg-toast.hiding {
  animation: tg-slide-out-right var(--tg-transition-slow) both;
}

.tg-toast-success { border-left: 3px solid var(--tg-success); }
.tg-toast-warning { border-left: 3px solid var(--tg-warning); }
.tg-toast-danger  { border-left: 3px solid var(--tg-danger); }
.tg-toast-info    { border-left: 3px solid var(--tg-info); }

.tg-toast-icon { font-size: 18px; flex-shrink: 0; }
.tg-toast-message { flex: 1; }
.tg-toast-close {
  cursor: pointer;
  opacity: 0.5;
  background: none;
  border: none;
  color: inherit;
  padding: 2px;
  flex-shrink: 0;
  line-height: 1;
}
.tg-toast-close:hover { opacity: 1; }

/* ============================================================
   13. MODALS
   ============================================================ */
.tg-modal-backdrop {
  position: fixed;
  inset: 0;
  background: rgba(15, 23, 42, 0.55);
  backdrop-filter: blur(3px);
  -webkit-backdrop-filter: blur(3px);
  z-index: var(--tg-z-modal-backdrop);
  animation: tg-fade-in var(--tg-transition-base) both;
}

.tg-modal-wrapper {
  position: fixed;
  inset: 0;
  z-index: var(--tg-z-modal);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--tg-space-4);
}

.tg-modal {
  background: var(--tg-surface-0);
  border-radius: var(--tg-radius-2xl);
  box-shadow: var(--tg-shadow-2xl);
  width: 100%;
  max-width: 520px;
  max-height: calc(100vh - var(--tg-space-8));
  display: flex;
  flex-direction: column;
  animation: tg-scale-in var(--tg-transition-slow) cubic-bezier(0.34, 1.56, 0.64, 1) both;
  border: 1px solid var(--tg-border-color);
}

.tg-modal-sm  { max-width: 360px; }
.tg-modal-lg  { max-width: 720px; }
.tg-modal-xl  { max-width: 1000px; }
.tg-modal-full { max-width: calc(100vw - 48px); }

.tg-modal-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--tg-space-5) var(--tg-space-6);
  border-bottom: 1px solid var(--tg-border-color);
  flex-shrink: 0;
}

.tg-modal-title {
  font-size: var(--tg-text-lg);
  font-weight: var(--tg-font-bold);
  color: var(--tg-gray-900);
  margin: 0;
}

.tg-modal-close {
  width: 32px;
  height: 32px;
  border-radius: var(--tg-radius-lg);
  background: transparent;
  border: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--tg-gray-400);
  transition: background-color var(--tg-transition-fast),
              color var(--tg-transition-fast);
  font-size: 20px;
}

.tg-modal-close:hover {
  background: var(--tg-gray-100);
  color: var(--tg-gray-700);
}

.tg-modal-body {
  padding: var(--tg-space-6);
  overflow-y: auto;
  flex: 1;
}

.tg-modal-footer {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: var(--tg-space-3);
  padding: var(--tg-space-4) var(--tg-space-6);
  border-top: 1px solid var(--tg-border-color);
  flex-shrink: 0;
  background: var(--tg-gray-50);
  border-radius: 0 0 var(--tg-radius-2xl) var(--tg-radius-2xl);
}

/* ============================================================
   14. DROPDOWNS
   ============================================================ */
.tg-dropdown {
  position: relative;
  display: inline-block;
}

.tg-dropdown-menu {
  position: absolute;
  top: calc(100% + 6px);
  right: 0;
  min-width: 200px;
  background: var(--tg-surface-0);
  border: 1px solid var(--tg-border-color);
  border-radius: var(--tg-radius-xl);
  box-shadow: var(--tg-shadow-xl);
  padding: var(--tg-space-2);
  z-index: var(--tg-z-dropdown);
  animation: tg-scale-in-sm var(--tg-transition-fast) both;
  transform-origin: top right;
}

.tg-dropdown-menu.open {
  display: block;
}

.tg-dropdown-item {
  display: flex;
  align-items: center;
  gap: var(--tg-space-3);
  padding: 8px var(--tg-space-3);
  border-radius: var(--tg-radius-lg);
  font-size: var(--tg-text-sm);
  color: var(--tg-gray-700);
  cursor: pointer;
  text-decoration: none;
  transition: background-color var(--tg-transition-fast),
              color var(--tg-transition-fast);
  white-space: nowrap;
}

.tg-dropdown-item:hover {
  background-color: var(--tg-gray-100);
  color: var(--tg-gray-900);
  text-decoration: none;
}

.tg-dropdown-item.danger:hover {
  background-color: var(--tg-danger-light);
  color: var(--tg-danger-dark);
}

.tg-dropdown-divider {
  height: 1px;
  background: var(--tg-border-color);
  margin: var(--tg-space-2) 0;
}

.tg-dropdown-header {
  padding: var(--tg-space-2) var(--tg-space-3) var(--tg-space-1);
  font-size: var(--tg-text-xs);
  font-weight: var(--tg-font-semibold);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--tg-gray-400);
}

/* ============================================================
   15. PROGRESS & LOADING
   ============================================================ */

/* Progress bar */
.tg-progress {
  height: 6px;
  background: var(--tg-gray-200);
  border-radius: var(--tg-radius-full);
  overflow: hidden;
}

.tg-progress-bar {
  height: 100%;
  border-radius: var(--tg-radius-full);
  background: linear-gradient(90deg, var(--tg-brand-primary), var(--tg-brand-accent));
  transition: width 0.6s cubic-bezier(0.4, 0, 0.2, 1);
}

.tg-progress-sm { height: 4px; }
.tg-progress-lg { height: 10px; }

.tg-progress.success .tg-progress-bar { background: var(--tg-success); }
.tg-progress.warning .tg-progress-bar { background: var(--tg-warning); }
.tg-progress.danger  .tg-progress-bar { background: var(--tg-danger); }

/* Striped animated */
.tg-progress.striped .tg-progress-bar {
  background-image: repeating-linear-gradient(
    45deg,
    transparent,
    transparent 6px,
    rgba(255,255,255,0.2) 6px,
    rgba(255,255,255,0.2) 12px
  );
  animation: tg-progress-stripes 1s linear infinite;
}

/* Skeleton loader */
.tg-skeleton {
  background: linear-gradient(
    90deg,
    var(--tg-gray-200) 25%,
    var(--tg-gray-100) 50%,
    var(--tg-gray-200) 75%
  );
  background-size: 200% 100%;
  animation: tg-shimmer 1.5s ease-in-out infinite;
  border-radius: var(--tg-radius-md);
}

.tg-skeleton-text  { height: 14px; margin-bottom: var(--tg-space-2); }
.tg-skeleton-title { height: 22px; width: 60%; margin-bottom: var(--tg-space-3); }
.tg-skeleton-card  { height: 120px; border-radius: var(--tg-radius-xl); }
.tg-skeleton-avatar{ width: 40px; height: 40px; border-radius: 50%; }
.tg-skeleton-btn   { height: 36px; width: 100px; border-radius: var(--tg-radius-lg); }

/* Spinner */
.tg-spinner {
  display: inline-block;
  border-radius: 50%;
  border: 2px solid var(--tg-gray-200);
  border-top-color: var(--tg-brand-primary);
  animation: tg-spin 0.7s linear infinite;
}

.tg-spinner-xs { width: 14px; height: 14px; }
.tg-spinner-sm { width: 18px; height: 18px; }
.tg-spinner-md { width: 28px; height: 28px; border-width: 3px; }
.tg-spinner-lg { width: 40px; height: 40px; border-width: 3px; }
.tg-spinner-xl { width: 56px; height: 56px; border-width: 4px; }

/* Page loader overlay */
.tg-page-loader {
  position: fixed;
  inset: 0;
  background: var(--tg-surface-0);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: var(--tg-space-4);
  z-index: 9999;
}

/* ============================================================
   16. CHARTS AREA
   ============================================================ */
.tg-chart-container {
  position: relative;
  width: 100%;
  min-height: 200px;
}

.tg-chart-title {
  font-size: var(--tg-text-base);
  font-weight: var(--tg-font-semibold);
  color: var(--tg-gray-800);
  margin-bottom: var(--tg-space-1);
}

.tg-chart-subtitle {
  font-size: var(--tg-text-xs);
  color: var(--tg-gray-500);
  margin-bottom: var(--tg-space-4);
}

.tg-chart-legend {
  display: flex;
  flex-wrap: wrap;
  gap: var(--tg-space-3);
  margin-top: var(--tg-space-3);
}

.tg-chart-legend-item {
  display: flex;
  align-items: center;
  gap: var(--tg-space-2);
  font-size: var(--tg-text-xs);
  color: var(--tg-gray-600);
}

.tg-chart-legend-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  flex-shrink: 0;
}

/* ============================================================
   17. CALENDAR COMPONENT (FullCalendar overrides)
   ============================================================ */
.fc {
  font-family: var(--tg-font-sans) !important;
}

.fc .fc-toolbar-title {
  font-size: var(--tg-text-xl) !important;
  font-weight: var(--tg-font-bold) !important;
  color: var(--tg-gray-900) !important;
}

.fc .fc-button {
  background: var(--tg-surface-0) !important;
  border: 1px solid var(--tg-border-color) !important;
  color: var(--tg-gray-700) !important;
  font-family: var(--tg-font-sans) !important;
  font-weight: var(--tg-font-medium) !important;
  font-size: var(--tg-text-sm) !important;
  border-radius: var(--tg-radius-lg) !important;
  box-shadow: none !important;
  padding: 6px 14px !important;
  transition: background-color var(--tg-transition-fast),
              border-color var(--tg-transition-fast) !important;
}

.fc .fc-button:hover {
  background: var(--tg-gray-100) !important;
  border-color: var(--tg-gray-300) !important;
}

.fc .fc-button-primary:not(:disabled).fc-button-active,
.fc .fc-button-primary:not(:disabled):active {
  background: var(--tg-brand-primary) !important;
  border-color: var(--tg-brand-primary) !important;
  color: #fff !important;
}

.fc .fc-col-header-cell {
  background: var(--tg-gray-50) !important;
  font-size: var(--tg-text-xs) !important;
  font-weight: var(--tg-font-semibold) !important;
  text-transform: uppercase !important;
  letter-spacing: 0.05em !important;
  color: var(--tg-gray-500) !important;
  padding: 8px 0 !important;
  border: none !important;
  border-bottom: 1px solid var(--tg-border-color) !important;
}

.fc .fc-daygrid-day-number {
  font-size: var(--tg-text-sm) !important;
  color: var(--tg-gray-600) !important;
  padding: 6px 8px !important;
}

.fc .fc-daygrid-day.fc-day-today {
  background-color: var(--tg-brand-primary-light) !important;
}

.fc .fc-daygrid-day.fc-day-today .fc-daygrid-day-number {
  background: var(--tg-brand-primary) !important;
  color: #fff !important;
  border-radius: 50% !important;
  width: 28px !important;
  height: 28px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  margin: 4px !important;
}

.fc .fc-event {
  border-radius: var(--tg-radius-sm) !important;
  font-size: 11px !important;
  font-weight: var(--tg-font-semibold) !important;
  border: none !important;
  padding: 2px 6px !important;
}

.fc td, .fc th {
  border-color: var(--tg-border-color) !important;
}

/* ============================================================
   18. COMPLIANCE COMPONENTS
   ============================================================ */

/* Risk indicator bar */
.tg-risk-bar {
  display: flex;
  align-items: center;
  gap: var(--tg-space-3);
}

.tg-risk-bar-track {
  flex: 1;
  height: 8px;
  background: var(--tg-gray-200);
  border-radius: var(--tg-radius-full);
  overflow: hidden;
}

.tg-risk-bar-fill {
  height: 100%;
  border-radius: var(--tg-radius-full);
  transition: width 0.8s cubic-bezier(0.4, 0, 0.2, 1);
}

.tg-risk-bar.critical .tg-risk-bar-fill { background: var(--tg-risk-critical); width: 100%; }
.tg-risk-bar.high     .tg-risk-bar-fill { background: var(--tg-risk-high);     }
.tg-risk-bar.medium   .tg-risk-bar-fill { background: var(--tg-risk-medium);   }
.tg-risk-bar.low      .tg-risk-bar-fill { background: var(--tg-risk-low);      }
.tg-risk-bar.ok       .tg-risk-bar-fill { background: var(--tg-risk-ok);       }

/* Risk pill */
.tg-risk-pill {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 4px 10px;
  border-radius: var(--tg-radius-full);
  font-size: var(--tg-text-xs);
  font-weight: var(--tg-font-semibold);
}

.tg-risk-pill.critical { background: #FEF2F2; color: var(--tg-risk-critical); }
.tg-risk-pill.high     { background: #FFF7ED; color: var(--tg-risk-high); }
.tg-risk-pill.medium   { background: var(--tg-warning-light); color: var(--tg-warning-dark); }
.tg-risk-pill.low      { background: #F7FEE7; color: var(--tg-risk-low); }
.tg-risk-pill.ok       { background: var(--tg-success-light); color: var(--tg-success-dark); }

/* Compliance score widget */
.tg-compliance-score {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--tg-space-2);
}

.tg-compliance-score-ring {
  position: relative;
  width: 80px;
  height: 80px;
}

.tg-compliance-score-ring svg {
  transform: rotate(-90deg);
  width: 80px;
  height: 80px;
}

.tg-compliance-score-ring circle {
  fill: none;
  stroke-width: 6;
  stroke-linecap: round;
}

.tg-compliance-score-ring .track {
  stroke: var(--tg-gray-200);
}

.tg-compliance-score-ring .fill {
  stroke: var(--tg-brand-primary);
  transition: stroke-dashoffset 1s cubic-bezier(0.4, 0, 0.2, 1);
}

.tg-compliance-score-value {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: var(--tg-text-lg);
  font-weight: var(--tg-font-extrabold);
  color: var(--tg-gray-900);
}

/* ============================================================
   19. VISION BOARD (Company graph)
   ============================================================ */
.tg-vision-board {
  position: relative;
  width: 100%;
  min-height: 400px;
  background: radial-gradient(ellipse at center, var(--tg-gray-100) 0%, var(--tg-gray-50) 100%);
  border-radius: var(--tg-radius-2xl);
  border: 1px solid var(--tg-border-color);
  overflow: hidden;
}

.tg-vision-node {
  background: var(--tg-surface-0);
  border: 2px solid var(--tg-border-color);
  border-radius: var(--tg-radius-xl);
  padding: var(--tg-space-3) var(--tg-space-4);
  cursor: pointer;
  transition: box-shadow var(--tg-transition-base),
              border-color var(--tg-transition-base),
              transform var(--tg-transition-spring);
  min-width: 160px;
  text-align: center;
  box-shadow: var(--tg-shadow-sm);
  user-select: none;
}

.tg-vision-node:hover {
  border-color: var(--tg-brand-primary);
  box-shadow: var(--tg-shadow-colored);
  transform: translateY(-3px);
}

.tg-vision-node.root {
  border-color: var(--tg-brand-primary);
  background: var(--tg-brand-primary-light);
}

.tg-vision-node.risk-high  { border-color: var(--tg-risk-high); }
.tg-vision-node.risk-critical { border-color: var(--tg-risk-critical); box-shadow: 0 0 0 2px rgba(220,38,38,0.2); }

.tg-vision-edge {
  stroke: var(--tg-gray-300);
  stroke-width: 1.5;
  fill: none;
}

/* Heatmap cell */
.tg-heatmap {
  display: grid;
  gap: 3px;
}

.tg-heatmap-cell {
  width: 14px;
  height: 14px;
  border-radius: var(--tg-radius-xs);
  cursor: pointer;
  transition: transform var(--tg-transition-fast);
  position: relative;
}

.tg-heatmap-cell:hover {
  transform: scale(1.3);
}

.tg-heatmap-cell[data-level="0"] { background: var(--tg-gray-100); }
.tg-heatmap-cell[data-level="1"] { background: #BBF7D0; }
.tg-heatmap-cell[data-level="2"] { background: var(--tg-success); }
.tg-heatmap-cell[data-level="3"] { background: #059669; }
.tg-heatmap-cell[data-level="4"] { background: #065F46; }

/* ============================================================
   20. EMPLOYEE CARDS
   ============================================================ */
.tg-employee-card {
  background: var(--tg-surface-0);
  border: 1px solid var(--tg-border-color);
  border-radius: var(--tg-radius-xl);
  padding: var(--tg-space-5);
  text-align: center;
  transition: box-shadow var(--tg-transition-base), transform var(--tg-transition-base);
  box-shadow: var(--tg-shadow-sm);
}

.tg-employee-card:hover {
  box-shadow: var(--tg-shadow-lg);
  transform: translateY(-3px);
}

.tg-employee-card-avatar {
  position: relative;
  display: inline-block;
  margin-bottom: var(--tg-space-3);
}

.tg-employee-avatar {
  width: 64px;
  height: 64px;
  border-radius: var(--tg-radius-full);
  background: linear-gradient(135deg, var(--tg-brand-primary), var(--tg-brand-accent));
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  font-size: var(--tg-text-xl);
  font-weight: var(--tg-font-bold);
  overflow: hidden;
  border: 3px solid var(--tg-surface-0);
  box-shadow: var(--tg-shadow-md);
}

.tg-employee-avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.tg-employee-avatar-sm  { width: 32px;  height: 32px;  font-size: var(--tg-text-sm);  border-width: 2px; }
.tg-employee-avatar-md  { width: 48px;  height: 48px;  font-size: var(--tg-text-lg);  border-width: 2px; }
.tg-employee-avatar-lg  { width: 80px;  height: 80px;  font-size: var(--tg-text-2xl); border-width: 3px; }
.tg-employee-avatar-xl  { width: 100px; height: 100px; font-size: var(--tg-text-3xl); border-width: 4px; }

/* Avatar status dot */
.tg-avatar-status {
  position: absolute;
  bottom: 2px;
  right: 2px;
  width: 12px;
  height: 12px;
  border-radius: 50%;
  border: 2px solid var(--tg-surface-0);
}

.tg-avatar-status.online  { background: var(--tg-success); }
.tg-avatar-status.offline { background: var(--tg-gray-400); }
.tg-avatar-status.away    { background: var(--tg-warning); }
.tg-avatar-status.busy    { background: var(--tg-danger); }

.tg-employee-name {
  font-size: var(--tg-text-base);
  font-weight: var(--tg-font-semibold);
  color: var(--tg-gray-900);
  margin-bottom: 2px;
}

.tg-employee-role {
  font-size: var(--tg-text-sm);
  color: var(--tg-gray-500);
  margin-bottom: var(--tg-space-3);
}

.tg-employee-stats {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--tg-space-2);
  border-top: 1px solid var(--tg-border-color);
  padding-top: var(--tg-space-3);
  margin-top: var(--tg-space-3);
}

.tg-employee-stat-value {
  font-size: var(--tg-text-xl);
  font-weight: var(--tg-font-bold);
  color: var(--tg-gray-900);
}

.tg-employee-stat-label {
  font-size: 11px;
  color: var(--tg-gray-500);
}

/* ============================================================
   21. TIMELINE COMPONENT
   ============================================================ */
.tg-timeline {
  position: relative;
  padding-left: var(--tg-space-8);
}

.tg-timeline::before {
  content: '';
  position: absolute;
  left: 15px;
  top: 0;
  bottom: 0;
  width: 2px;
  background: var(--tg-gray-200);
  border-radius: var(--tg-radius-full);
}

.tg-timeline-item {
  position: relative;
  padding-bottom: var(--tg-space-5);
}

.tg-timeline-item:last-child { padding-bottom: 0; }

.tg-timeline-dot {
  position: absolute;
  left: calc(-1 * var(--tg-space-8) + 8px);
  top: 2px;
  width: 16px;
  height: 16px;
  border-radius: 50%;
  background: var(--tg-brand-primary);
  border: 2px solid var(--tg-surface-0);
  box-shadow: 0 0 0 3px var(--tg-brand-primary-light);
}

.tg-timeline-dot.success { background: var(--tg-success); box-shadow: 0 0 0 3px var(--tg-success-light); }
.tg-timeline-dot.warning { background: var(--tg-warning); box-shadow: 0 0 0 3px var(--tg-warning-light); }
.tg-timeline-dot.danger  { background: var(--tg-danger);  box-shadow: 0 0 0 3px var(--tg-danger-light); }
.tg-timeline-dot.neutral { background: var(--tg-gray-400); box-shadow: 0 0 0 3px var(--tg-gray-100); }

.tg-timeline-content {
  background: var(--tg-surface-0);
  border: 1px solid var(--tg-border-color);
  border-radius: var(--tg-radius-lg);
  padding: var(--tg-space-3) var(--tg-space-4);
  box-shadow: var(--tg-shadow-xs);
}

.tg-timeline-time {
  font-size: var(--tg-text-xs);
  color: var(--tg-gray-400);
  margin-bottom: 2px;
}

.tg-timeline-title {
  font-size: var(--tg-text-sm);
  font-weight: var(--tg-font-semibold);
  color: var(--tg-gray-800);
}

.tg-timeline-desc {
  font-size: var(--tg-text-xs);
  color: var(--tg-gray-500);
  margin-top: 2px;
}

/* ============================================================
   22. EMPTY STATES
   ============================================================ */
.tg-empty-state {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: var(--tg-space-12) var(--tg-space-6);
  gap: var(--tg-space-4);
}

.tg-empty-state-icon {
  width: 80px;
  height: 80px;
  background: var(--tg-gray-100);
  border-radius: var(--tg-radius-full);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 36px;
  color: var(--tg-gray-400);
  margin-bottom: var(--tg-space-2);
}

.tg-empty-state-title {
  font-size: var(--tg-text-xl);
  font-weight: var(--tg-font-bold);
  color: var(--tg-gray-800);
  margin: 0;
}

.tg-empty-state-desc {
  font-size: var(--tg-text-sm);
  color: var(--tg-gray-500);
  max-width: 380px;
  line-height: var(--tg-leading-relaxed);
  margin: 0;
}

/* ============================================================
   23. PAGE HEADER
   ============================================================ */
.tg-page-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: var(--tg-space-4);
  margin-bottom: var(--tg-space-6);
  flex-wrap: wrap;
}

.tg-page-header-left { flex: 1; min-width: 0; }

.tg-page-title {
  font-size: var(--tg-text-2xl);
  font-weight: var(--tg-font-bold);
  color: var(--tg-gray-900);
  letter-spacing: -0.025em;
  margin: 0 0 var(--tg-space-1);
}

.tg-page-subtitle {
  font-size: var(--tg-text-sm);
  color: var(--tg-gray-500);
  margin: 0;
}

.tg-page-actions {
  display: flex;
  align-items: center;
  gap: var(--tg-space-2);
  flex-shrink: 0;
}

/* ============================================================
   24. FILTER BAR
   ============================================================ */
.tg-filter-bar {
  display: flex;
  align-items: center;
  gap: var(--tg-space-3);
  flex-wrap: wrap;
  padding: var(--tg-space-3) var(--tg-space-4);
  background: var(--tg-surface-0);
  border: 1px solid var(--tg-border-color);
  border-radius: var(--tg-radius-xl);
  box-shadow: var(--tg-shadow-xs);
  margin-bottom: var(--tg-space-5);
}

.tg-filter-bar-search {
  flex: 1;
  min-width: 200px;
  position: relative;
}

.tg-filter-bar-search .tg-input {
  padding-left: 36px;
  background: var(--tg-gray-50);
}

.tg-filter-bar-search .tg-input-group-icon {
  left: 10px;
  font-size: 16px;
}

.tg-filter-bar-actions {
  display: flex;
  align-items: center;
  gap: var(--tg-space-2);
}

.tg-filter-tag {
  display: inline-flex;
  align-items: center;
  gap: var(--tg-space-1);
  padding: 4px 10px;
  background: var(--tg-brand-primary-light);
  color: var(--tg-brand-primary);
  border-radius: var(--tg-radius-full);
  font-size: var(--tg-text-xs);
  font-weight: var(--tg-font-semibold);
}

.tg-filter-tag-remove {
  cursor: pointer;
  opacity: 0.6;
  line-height: 1;
  font-size: 14px;
}

.tg-filter-tag-remove:hover { opacity: 1; }

/* ============================================================
   25. ANIMATIONS & TRANSITIONS
   ============================================================ */
@keyframes tg-fade-in {
  from { opacity: 0; }
  to   { opacity: 1; }
}

@keyframes tg-fade-in-up {
  from { opacity: 0; transform: translateY(12px); }
  to   { opacity: 1; transform: translateY(0); }
}

@keyframes tg-fade-in-down {
  from { opacity: 0; transform: translateY(-12px); }
  to   { opacity: 1; transform: translateY(0); }
}

@keyframes tg-scale-in {
  from { opacity: 0; transform: scale(0.94); }
  to   { opacity: 1; transform: scale(1); }
}

@keyframes tg-scale-in-sm {
  from { opacity: 0; transform: scale(0.96) translateY(-4px); }
  to   { opacity: 1; transform: scale(1) translateY(0); }
}

@keyframes tg-slide-in-right {
  from { opacity: 0; transform: translateX(20px); }
  to   { opacity: 1; transform: translateX(0); }
}

@keyframes tg-slide-out-right {
  from { opacity: 1; transform: translateX(0); }
  to   { opacity: 0; transform: translateX(20px); }
}

@keyframes tg-slide-in-left {
  from { opacity: 0; transform: translateX(-20px); }
  to   { opacity: 1; transform: translateX(0); }
}

@keyframes tg-spin {
  to { transform: rotate(360deg); }
}

@keyframes tg-shimmer {
  from { background-position: 200% 0; }
  to   { background-position: -200% 0; }
}

@keyframes tg-pulse {
  0%, 100% { opacity: 1; }
  50%       { opacity: 0.5; }
}

@keyframes tg-bounce {
  0%, 100% { transform: translateY(0); }
  50%       { transform: translateY(-6px); }
}

@keyframes tg-progress-stripes {
  from { background-position: 24px 0; }
  to   { background-position: 0 0; }
}

@keyframes tg-ring-pulse {
  0%   { box-shadow: 0 0 0 0 rgba(8, 31, 247, 0.35); }
  70%  { box-shadow: 0 0 0 10px rgba(8, 31, 247, 0); }
  100% { box-shadow: 0 0 0 0 rgba(8, 31, 247, 0); }
}

/* Animation utility classes */
.tg-animate-fade-in     { animation: tg-fade-in     var(--tg-transition-slow) both; }
.tg-animate-fade-in-up  { animation: tg-fade-in-up  var(--tg-transition-slow) both; }
.tg-animate-fade-in-down{ animation: tg-fade-in-down var(--tg-transition-slow) both; }
.tg-animate-scale-in    { animation: tg-scale-in    var(--tg-transition-slow) both; }
.tg-animate-pulse       { animation: tg-pulse 2s ease-in-out infinite; }
.tg-animate-spin        { animation: tg-spin 1s linear infinite; }

/* Staggered children */
.tg-stagger > * { animation: tg-fade-in-up 0.4s both; }
.tg-stagger > *:nth-child(1) { animation-delay: 0ms; }
.tg-stagger > *:nth-child(2) { animation-delay: 60ms; }
.tg-stagger > *:nth-child(3) { animation-delay: 120ms; }
.tg-stagger > *:nth-child(4) { animation-delay: 180ms; }
.tg-stagger > *:nth-child(5) { animation-delay: 240ms; }
.tg-stagger > *:nth-child(6) { animation-delay: 300ms; }

/* Reduced motion */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
  }
}

/* ============================================================
   26. RESPONSIVE UTILITIES
   ============================================================ */
@media (max-width: 1024px) {
  .tg-grid-4 { grid-template-columns: repeat(2, 1fr); }
  .tg-grid-3 { grid-template-columns: repeat(2, 1fr); }
  .tg-hide-md { display: none !important; }
}

@media (max-width: 768px) {
  .tg-grid-4,
  .tg-grid-3,
  .tg-grid-2 { grid-template-columns: 1fr; }
  .tg-hide-sm { display: none !important; }
  .tg-page-header { flex-direction: column; }
  .tg-filter-bar  { flex-direction: column; align-items: stretch; }
  .tg-filter-bar-search { min-width: unset; }
  .tg-topbar { padding: 0 var(--tg-space-4); gap: var(--tg-space-2); }
  .tg-topbar-search { display: none; }
  .tg-content { padding: var(--tg-space-4); }

  .tg-modal { max-width: 100%; border-radius: var(--tg-radius-xl) var(--tg-radius-xl) 0 0; }
  .tg-modal-wrapper { align-items: flex-end; padding: 0; }
}

/* Hide desktop collapse toggle on mobile — not applicable */
@media (max-width: 991.98px) {
  .tg-sidebar-toggle { display: none !important; }
}

/* Bug 7: Mobile sidebar slide-in / backdrop */
@media (max-width: 991.98px) {
  .tg-sidebar {
    transform: translateX(-100%);
    transition: transform var(--tg-transition-slow);
    z-index: 1030;
  }
  .tg-sidebar.tg-sidebar-mobile-open {
    transform: translateX(0);
  }
  .tg-main {
    margin-left: 0 !important;
  }
  .tg-topbar {
    left: 0 !important;
  }
}

@media (max-width: 480px) {
  .tg-hide-xs { display: none !important; }
  .tg-stat-value { font-size: var(--tg-text-2xl); }
}

/* ============================================================
   27. DARK MODE
   ============================================================ */
/* prefers-color-scheme: dark — solo cuando NO hay elección explícita del usuario.
   Guard :not([data-theme="light"]) evita conflicto con el toggle manual de TapGo. */
@media (prefers-color-scheme: dark) {
  :root:not([data-theme="light"]):not([data-theme="dark"]) {
    --tg-border-color:    #2D3148;
    --tg-surface-0:       #0F1117;
    --tg-surface-1:       #1A1D27;
    --tg-surface-2:       #252836;
    --tg-surface-elevated:#1E2233;
    --tg-surface-glass:   rgba(15, 17, 23, 0.8);
    --tg-gray-50:         #1E293B;
    --tg-gray-100:        #334155;
    --tg-gray-200:        #475569;
    --tg-gray-300:        #64748B;
    --tg-gray-400:        #94A3B8;
    --tg-gray-500:        #94A3B8;
    --tg-gray-600:        #CBD5E1;
    --tg-gray-700:        #E2E8F0;
    --tg-gray-800:        #F1F5F9;
    --tg-gray-900:        #F8FAFC;
    color-scheme: dark;
  }

  :root:not([data-theme="light"]):not([data-theme="dark"]) .tg-skeleton {
    background: linear-gradient(
      90deg,
      #334155 25%,
      #475569 50%,
      #334155 75%
    );
    background-size: 200% 100%;
  }

  :root:not([data-theme="light"]):not([data-theme="dark"]) .tg-toast {
    background: var(--tg-gray-800);
    border-color: rgba(255,255,255,0.1);
    color: var(--tg-gray-900);
  }
}

/* ============================================================
   Bug 1 + 2: Dark mode — dual selector (data-theme-version AND data-theme)
   Bug 2: Complete variable overrides for ALL surface/text/border tokens
   ============================================================ */

/* DexignLab dark-mode override (uses data-theme-version="dark") */
/* HTML toggle uses data-theme="dark" — both selectors required */
[data-theme-version="dark"],
[data-theme="dark"] {
  --tg-border-color:    #2D3148;
  --tg-surface-0:       #0F1117;
  --tg-surface-1:       #1A1D27;
  --tg-surface-2:       #252836;
  --tg-surface-elevated:#1E2233;
  --tg-surface-glass:   rgba(15, 17, 23, 0.8);
  --tg-gray-50:         #1E293B;
  --tg-gray-100:        #334155;
  --tg-gray-200:        #475569;
  --tg-gray-300:        #64748B;
  --tg-gray-400:        #94A3B8;
  --tg-gray-500:        #94A3B8;
  --tg-gray-600:        #CBD5E1;
  --tg-gray-700:        #E2E8F0;
  --tg-gray-800:        #F1F5F9;
  --tg-gray-900:        #F8FAFC;
  color-scheme: dark;
}

/* Bug 11: body and content backgrounds in dark mode */
[data-theme-version="dark"] body,
[data-theme="dark"] body {
  background: var(--tg-surface-0) !important;
  color: var(--tg-gray-800) !important;
}

[data-theme-version="dark"] .content-body,
[data-theme="dark"] .content-body {
  background: var(--tg-surface-0) !important;
}
/* .tg-content intentionally removed — inherits from .tg-main which uses --tg-gray-50 (remapped in dark mode) */

/* Card overrides — Bug 10 */
[data-theme-version="dark"] .tg-card,
[data-theme="dark"] .tg-card,
[data-theme-version="dark"] .tg-stat-card,
[data-theme="dark"] .tg-stat-card {
  background: var(--tg-surface-elevated) !important;
  border-color: var(--tg-border-color) !important;
}

[data-theme-version="dark"] .tg-card-header,
[data-theme="dark"] .tg-card-header,
[data-theme-version="dark"] .tg-card-footer,
[data-theme="dark"] .tg-card-footer {
  background: var(--tg-surface-2) !important;
  border-color: var(--tg-border-color) !important;
  color: var(--tg-gray-700) !important;
}

/* Bug 8: Table contrast in dark mode */
[data-theme-version="dark"] .table,
[data-theme="dark"] .table,
[data-theme-version="dark"] .tg-table,
[data-theme="dark"] .tg-table {
  color: var(--tg-gray-800) !important;
  border-color: var(--tg-border-color) !important;
}

[data-theme-version="dark"] .table th,
[data-theme="dark"] .table th,
[data-theme-version="dark"] .tg-table th,
[data-theme="dark"] .tg-table th {
  background: var(--tg-surface-2) !important;
  color: var(--tg-gray-600) !important;
}

[data-theme-version="dark"] .table td,
[data-theme="dark"] .table td {
  background: var(--tg-surface-1) !important;
  border-color: var(--tg-border-color) !important;
}

[data-theme-version="dark"] .tg-table thead,
[data-theme="dark"] .tg-table thead {
  background: var(--tg-surface-2) !important;
}

/* Bug 9: Input/form dark mode visibility */
[data-theme-version="dark"] input,
[data-theme="dark"] input,
[data-theme-version="dark"] select,
[data-theme="dark"] select,
[data-theme-version="dark"] textarea,
[data-theme="dark"] textarea {
  background: var(--tg-surface-2) !important;
  color: var(--tg-gray-800) !important;
  border-color: var(--tg-gray-300) !important;
}

[data-theme-version="dark"] input::placeholder,
[data-theme="dark"] input::placeholder {
  color: var(--tg-gray-400) !important;
}

[data-theme-version="dark"] .tg-input,
[data-theme="dark"] .tg-input,
[data-theme-version="dark"] .tg-select,
[data-theme="dark"] .tg-select,
[data-theme-version="dark"] .tg-textarea,
[data-theme="dark"] .tg-textarea {
  background: var(--tg-surface-1);
  border-color: var(--tg-border-color);
  color: var(--tg-gray-800);
}

/* Modal */
[data-theme-version="dark"] .tg-modal,
[data-theme="dark"] .tg-modal {
  background: var(--tg-surface-0);
  border-color: var(--tg-border-color);
}

/* Dropdown */
[data-theme-version="dark"] .tg-dropdown-menu,
[data-theme="dark"] .tg-dropdown-menu {
  background: var(--tg-surface-0);
  border-color: var(--tg-border-color);
}

/* Sidebar — intentionally NOT overridden in dark mode.
   The sidebar always uses --tg-sidebar-bg (#2D1B69 purple) in both themes. */

/* Topbar */
[data-theme-version="dark"] .tg-topbar,
[data-theme="dark"] .tg-topbar {
  background: var(--tg-surface-0) !important;
  border-color: var(--tg-border-color) !important;
}

/* Bug 12: Scrollbar in dark mode */
[data-theme-version="dark"] ::-webkit-scrollbar-track,
[data-theme="dark"] ::-webkit-scrollbar-track {
  background: var(--tg-surface-2);
}

[data-theme-version="dark"] ::-webkit-scrollbar-thumb,
[data-theme="dark"] ::-webkit-scrollbar-thumb {
  background: var(--tg-gray-300);
}

/* Bug 13: Charts container dark mode */
[data-theme-version="dark"] .tg-chart-container,
[data-theme="dark"] .tg-chart-container {
  background: var(--tg-surface-elevated) !important;
}

/* ── Impersonation Banner ─────────────────────────────────────── */
.tg-impersonation-banner {
    position: fixed;
    top: 0; left: 0; right: 0;
    z-index: 9999;
    background: linear-gradient(90deg, #f59e0b, #d97706);
    color: #fff;
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 8px 20px;
    font-size: 12.5px;
    font-weight: 500;
    box-shadow: 0 2px 8px rgba(245,158,11,0.4);
    gap: 12px;
}
.tg-impersonation-content { display: flex; align-items: center; gap: 8px; flex: 1; }
.tg-impersonation-icon { font-size: 14px; }
.tg-impersonation-sep { opacity: 0.6; }
.tg-impersonation-info { opacity: 0.85; font-size: 11.5px; }
.tg-impersonation-exit {
    color: #fff;
    text-decoration: none;
    display: flex;
    align-items: center;
    gap: 5px;
    background: rgba(0,0,0,0.15);
    border-radius: 5px;
    padding: 4px 10px;
    font-size: 12px;
    font-weight: 600;
    transition: background 0.15s;
    white-space: nowrap;
}
.tg-impersonation-exit:hover { background: rgba(0,0,0,0.25); }

/* Botón × para cerrar el banner sin hacer logout */
.tg-impersonation-close {
    background: rgba(0,0,0,0.2);
    border: none;
    color: #fff;
    border-radius: 5px;
    width: 26px;
    height: 26px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 18px;
    line-height: 1;
    cursor: pointer;
    flex-shrink: 0;
    transition: background 0.15s;
}
.tg-impersonation-close:hover { background: rgba(0,0,0,0.35); }

/* Píldora compacta visible en el topbar cuando el banner está cerrado */
.tg-imp-pill {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    background: rgba(245,158,11,0.12);
    border: 1px solid rgba(245,158,11,0.35);
    color: #92400e;
    border-radius: 20px;
    padding: 4px 12px;
    font-size: 11.5px;
    font-weight: 600;
    text-decoration: none;
    white-space: nowrap;
    transition: background 0.15s;
}
.tg-imp-pill:hover { background: rgba(245,158,11,0.22); color: #92400e; text-decoration: none; }
[data-theme="dark"] .tg-imp-pill { background: rgba(245,158,11,0.15); border-color: rgba(245,158,11,0.3); color: #fbbf24; }
[data-theme="dark"] .tg-imp-pill:hover { background: rgba(245,158,11,0.25); color: #fbbf24; }

/* Offset del topbar cuando hay banner de impersonación */
body.tg-layout.impersonating .tg-sidebar { top: 37px; }
body.tg-layout.impersonating .tg-main { padding-top: 37px; }

/* ============================================================
   28. PRINT STYLES
   ============================================================ */
@media print {
  .tg-sidebar,
  .tg-topbar,
  .tg-toast-container,
  .tg-modal-backdrop,
  .tg-page-actions,
  .tg-filter-bar,
  .tg-btn:not(.tg-btn-print),
  .tg-topbar-btn,
  .no-print {
    display: none !important;
  }

  body {
    background: #fff !important;
    color: #000 !important;
    font-size: 11pt !important;
  }

  .tg-main {
    margin-left: 0 !important;
    padding-top: 0 !important;
  }

  .tg-card,
  .tg-stat-card {
    break-inside: avoid;
    border: 1px solid #ccc !important;
    box-shadow: none !important;
    page-break-inside: avoid;
  }

  .tg-table tbody tr { break-inside: avoid; }

  a[href]::after {
    content: " (" attr(href) ")";
    font-size: 9pt;
    color: #666;
  }

  a[href^="#"]::after,
  a[href^="javascript"]::after { content: ""; }

  @page {
    margin: 2cm;
    size: A4;
  }
}
