:root {
  /* ═══════════════════════════════════════════════════════════════════════
     BASE COLORS
     ═══════════════════════════════════════════════════════════════════════ */
  --linkooc-bg: #FFFFFF;
  --linkooc-hover-bg: #F7F7F8;
  --linkooc-second-bg: #FEFEFE;
  --linkooc-hover-second-bg: #e7f1e8;
  --linkooc-text: #000601;
  --linkooc-text-display: #000601;
  --linkooc-text-secondary: #6d6d6d;
  --linkooc-text-display-second: #22AD01;
  --linkooc-text-display-tertiary: #054810;
  --linkooc-button-primary: #08781B;
  --linkooc-button-primary-rgba: rgba(8, 120, 27, 0.5);
  --linkooc-button-secondary: #054810;
  --linkooc-border-color: #dee2e6bf;
  --bs-primary-rgb: 201, 36, 24;
  --bs-danger-rgb: 201, 36, 24;
  --bs-warning-rgb: 201, 118, 24;
  --bs-success-bg-subtle: #d1e7dd;
  --linkooc-reverse-second-bg: #162127;
  --linkooc-reverse-text: #FFFFFF;
  --linkooc-reverse-border-color: #212529;

  /* ═══════════════════════════════════════════════════════════════════════
     COLOR PALETTE VARIANTS
     ═══════════════════════════════════════════════════════════════════════ */
  --linkooc-green-var-1: #197C28;
  --linkooc-green-var-2: #11671E;
  --linkooc-green-var-3: #085215;
  --linkooc-green-var-4: #054411;
  --linkooc-green-var-5: #053D11;
  --linkooc-green-var-6: #063511;

  /* ═══════════════════════════════════════════════════════════════════════
     GREEN SCALE (Light Mode) - Based on #08781B
     50-400: Lighter tints | 500: Base | 600-900: Darker shades
     ═══════════════════════════════════════════════════════════════════════ */
  --linkooc-green-50: #A5B8A5;
  --linkooc-green-100: #79AB7B;
  --linkooc-green-200: #579E5C;
  --linkooc-green-300: #399142;
  --linkooc-green-400: #1E852C;
  --linkooc-green-500: #08781B;
  /* Primary base */
  --linkooc-green-600: #025212;
  --linkooc-green-700: #002B0A;
  --linkooc-green-800: #000501;
  --linkooc-green-900: #000000;
  --linkooc-blue-var-1: #197CBA;
  --linkooc-blue-var-2: #1167A1;
  --linkooc-blue-var-3: #085285;
  --linkooc-blue-var-4: #054471;
  --linkooc-blue-var-5: #053D61;
  --linkooc-blue-var-6: #063551;
  --linkooc-red-var-1: #BA1919;
  --linkooc-red-var-2: #A11111;
  --linkooc-red-var-3: #850808;
  --linkooc-red-var-4: #710505;
  --linkooc-red-var-5: #610505;
  --linkooc-red-var-6: #510505;
  --linkooc-orange-var-1: #FFA500;
  --linkooc-orange-var-2: #FF8C00;
  --linkooc-orange-var-3: #FF7F50;
  --linkooc-orange-var-4: #FF6347;
  --linkooc-orange-var-5: #FF4500;
  --linkooc-orange-var-6: #FF3300;

  /* ═══════════════════════════════════════════════════════════════════════
     BRAND GRADIENT (Green → Teal → Blue)
     Use for headers, progress bars, decorative elements
     ═══════════════════════════════════════════════════════════════════════ */
  --linkooc-gradient-1: #08781B;
  /* Primary green */
  --linkooc-gradient-2: #008251;
  /* Teal-green */
  --linkooc-gradient-3: #008A82;
  /* Teal */
  --linkooc-gradient-4: #008FAD;
  /* Teal-blue */
  --linkooc-gradient-5: #0090CB;
  /* Light blue */
  --linkooc-gradient-6: #078ED9;
  /* Blue */

  /* Ready-to-use gradient backgrounds */
  --linkooc-gradient-horizontal: linear-gradient(90deg, var(--linkooc-gradient-1), var(--linkooc-gradient-6));
  --linkooc-gradient-vertical: linear-gradient(180deg, var(--linkooc-gradient-1), var(--linkooc-gradient-6));
  --linkooc-gradient-diagonal: linear-gradient(135deg, var(--linkooc-gradient-1), var(--linkooc-gradient-6));
  --linkooc-gradient-subtle: linear-gradient(90deg, var(--linkooc-gradient-1), var(--linkooc-gradient-3));

  /* ═══════════════════════════════════════════════════════════════════════
     SEMANTIC COLORS (use these in components)
     ═══════════════════════════════════════════════════════════════════════ */
  --linkooc-primary: var(--linkooc-button-primary);
  --linkooc-primary-light: var(--linkooc-hover-second-bg);
  --linkooc-primary-subtle: rgba(8, 120, 27, 0.1);
  --linkooc-danger: var(--linkooc-red-var-1);
  --linkooc-danger-light: rgba(186, 25, 25, 0.1);
  --linkooc-warning: var(--linkooc-orange-var-1);
  --linkooc-warning-light: rgba(255, 165, 0, 0.1);
  --linkooc-success: var(--linkooc-green-var-1);
  --linkooc-success-light: rgba(25, 124, 40, 0.1);
  --linkooc-info: var(--linkooc-blue-var-1);
  --linkooc-info-light: rgba(25, 124, 186, 0.1);
  --linkooc-text-primary: var(--linkooc-text);
  --linkooc-text-muted: var(--linkooc-text-secondary);
  --linkooc-surface: var(--linkooc-second-bg);
  --linkooc-surface-hover: var(--linkooc-hover-bg);

  /* ═══════════════════════════════════════════════════════════════════════
     SPACING
     ═══════════════════════════════════════════════════════════════════════ */
  --linkooc-spacing-xs: 0.25rem;
  --linkooc-spacing-sm: 0.5rem;
  --linkooc-spacing-md: 1rem;
  --linkooc-spacing-lg: 1.5rem;
  --linkooc-spacing-xl: 2rem;
  --linkooc-spacing-2xl: 3rem;
  --linkooc-page-offset: calc(3.5rem + 2.05rem);
  /* top-row + content padding */

  /* ═══════════════════════════════════════════════════════════════════════
     TYPOGRAPHY - Font Sizes
     Use these instead of hardcoding rem values!
     ═══════════════════════════════════════════════════════════════════════ */
  --linkooc-font-family: system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;

  /* Page header hierarchy */
  --linkooc-page-title-size: 1.5rem;
  /* 24px - Main page title (h1) */
  --linkooc-page-title-weight: 600;
  --linkooc-page-count-size: 1rem;
  /* 16px - Count next to title */
  --linkooc-page-subtitle-size: 0.875rem;
  /* 14px - Gray subtitle below title */
  --linkooc-breadcrumb-size: 0.8125rem;
  /* 13px - Breadcrumb navigation */

  /* Panel headers */
  --linkooc-detail-title-size: 1.125rem;
  /* 18px - Detail panel header title */
  --linkooc-detail-title-weight: 600;
  --linkooc-section-title-size: 1rem;
  /* 16px - Section headers within content */
  --linkooc-section-title-weight: 600;

  /* List items */
  --linkooc-list-item-title-size: 0.9375rem;
  /* 15px - List item primary text */
  --linkooc-list-item-title-weight: 600;
  --linkooc-list-item-desc-size: 0.8125rem;
  /* 13px - List item secondary/muted text */

  /* Body text */
  --linkooc-body-size: 0.875rem;
  /* 14px - Default body text */
  --linkooc-small-size: 0.75rem;
  /* 12px - Small/caption text */
  --linkooc-tiny-size: 0.65rem;
  /* ~10px - Badges, micro text */

  /* Form labels */
  --linkooc-label-size: 0.875rem;
  /* 14px - Form field labels */
  --linkooc-label-weight: 500;
  --linkooc-input-size: 0.875rem;
  /* 14px - Input text */

  /* ═══════════════════════════════════════════════════════════════════════
     LAYOUT
     ═══════════════════════════════════════════════════════════════════════ */
  --linkooc-radius: 1.5rem;
  --linkooc-radius-sm: 0.5rem;
  --linkooc-radius-md: 0.75rem;
  --linkooc-radius-lg: 1rem;
  --linkooc-panel-header-height: 56px;
  --linkooc-sticky-bar-height: 48px;
  --linkooc-sidebar-width: 280px;
  --linkooc-detail-min-width: 400px;

  /* ═══════════════════════════════════════════════════════════════════════
     LIST SELECTION STATES
     ═══════════════════════════════════════════════════════════════════════ */
  --linkooc-list-selection-bg: var(--linkooc-primary-subtle);
  --linkooc-list-selection-border-color: var(--linkooc-primary);
  --linkooc-list-hover-bg: var(--linkooc-hover-bg);

  /* ═══════════════════════════════════════════════════════════════════════
     SHADOWS
     ═══════════════════════════════════════════════════════════════════════ */
  --linkooc-shadow-sm: 0 1px 2px rgba(0, 0, 0, 0.05);
  --linkooc-shadow-md: 0 4px 6px -1px rgba(0, 0, 0, 0.1);
  --linkooc-shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, 0.1);
  --linkooc-shadow-sticky: 0 -2px 10px rgba(0, 0, 0, 0.1);

  /* ═══════════════════════════════════════════════════════════════════════
     TRANSITIONS
     ═══════════════════════════════════════════════════════════════════════ */
  --linkooc-transition-fast: 150ms ease;
  --linkooc-transition-normal: 250ms ease;
  --linkooc-transition-slow: 350ms ease;

  /* Linkooc -> MatrixComponents tokens */
  --matrix-primary: var(--linkooc-button-primary);
  --matrix-secondary: var(--linkooc-text-display);
  --matrix-success: var(--linkooc-text-display-second);
  --matrix-danger: var(--linkooc-red-var-1);
  --matrix-warning: var(--linkooc-orange-var-1);
  --matrix-bg: var(--linkooc-bg);
  --matrix-surface: var(--linkooc-second-bg);
  --matrix-border: var(--linkooc-border-color);
  --matrix-text: var(--linkooc-text);
  --matrix-text-muted: var(--linkooc-text-secondary);
  --matrix-radius: 12px;

  /* Linkooc -> Telerik (Kendo) tokens */
  --kendo-color-primary: var(--linkooc-button-primary);
  --kendo-color-primary-hover: var(--linkooc-text-display-second);
  --kendo-color-primary-emphasis: var(--linkooc-button-primary-rgba);
  --kendo-color-primary-on-subtle: var(--linkooc-green-var-4);
  --kendo-color-on-primary: var(--linkooc-reverse-text);
  --kendo-color-base: var(--linkooc-bg);
  --kendo-color-on-base: var(--linkooc-text-display);
  --kendo-color-app-surface: var(--linkooc-bg);
  --kendo-color-surface: var(--linkooc-second-bg);
  --kendo-color-surface-alt: var(--linkooc-hover-bg);
  --kendo-color-on-app-surface: var(--linkooc-text);
  --kendo-color-subtle: var(--linkooc-text-secondary);
  --kendo-color-border: var(--linkooc-border-color);
  --kendo-color-info: var(--linkooc-blue-var-1);
  --kendo-color-success: var(--linkooc-green-var-1);
  --kendo-color-warning: var(--linkooc-orange-var-1);
  --kendo-color-error: var(--linkooc-red-var-1);
  --kendo-border-radius-md: var(--linkooc-radius);
}

main.dark-theme {
  /* Base colors */
  --linkooc-bg: #181818;
  --linkooc-hover-bg: #2a2a2a;
  --linkooc-second-bg: #162127;
  --linkooc-hover-second-bg: #374151;
  --linkooc-text: #FFFFFF;
  --linkooc-text-display: #FFFFFF;
  --linkooc-text-secondary: #a0a0a0;
  --linkooc-text-display-second: #22AD01;
  --linkooc-text-display-tertiary: #054810;
  --linkooc-button-primary: #08781B;
  --linkooc-button-secondary: #054810;
  --linkooc-border-color: #3a3a3a;
  --linkooc-reverse-second-bg: #FEFEFE;
  --linkooc-reverse-text: #000601;
  --linkooc-reverse-border-color: #dee2e6bf;

  /* Semantic colors - dark mode adjustments */
  --linkooc-primary-subtle: rgba(8, 120, 27, 0.2);
  --linkooc-danger-light: rgba(186, 25, 25, 0.2);
  --linkooc-warning-light: rgba(255, 165, 0, 0.2);
  --linkooc-success-light: rgba(25, 124, 40, 0.2);
  --linkooc-info-light: rgba(25, 124, 186, 0.2);
  --linkooc-surface: var(--linkooc-second-bg);
  --linkooc-surface-hover: var(--linkooc-hover-bg);
  --linkooc-list-selection-bg: var(--linkooc-primary-subtle);
  --linkooc-list-hover-bg: var(--linkooc-hover-bg);

  /* Green scale - Dark mode optimized */
  --linkooc-green-50: #111713;
  --linkooc-green-100: #102414;
  --linkooc-green-200: #103216;
  --linkooc-green-300: #0F4117;
  --linkooc-green-400: #0C5519;
  --linkooc-green-500: #0A691A;
  --linkooc-green-600: #1D7A2A;
  --linkooc-green-700: #378B40;
  --linkooc-green-800: #559A5A;
  --linkooc-green-900: #77A879;

  /* Shadows - darker for dark mode */
  --linkooc-shadow-sm: 0 1px 2px rgba(0, 0, 0, 0.3);
  --linkooc-shadow-md: 0 4px 6px -1px rgba(0, 0, 0, 0.4);
  --linkooc-shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, 0.5);
  --linkooc-shadow-sticky: 0 -2px 10px rgba(0, 0, 0, 0.4);
}

.rounded {
  border-radius: var(--linkooc-radius, 1.5rem) !important;
}

/* ═══════════════════════════════════════════════════════════════════════
   ESTABLISHMENT QR CARD (Sidebar)
   ═══════════════════════════════════════════════════════════════════════ */
.establishment-qr-card {
  display: flex;
  flex-direction: column;
  align-items: center;
  background: var(--linkooc-bg);
  border: 1px solid var(--linkooc-border-color);
  border-radius: var(--linkooc-radius-md, 0.75rem);
  padding: 0.375rem 0.5rem;
  /* Tighter padding */
  gap: 0.25rem;
  /* Minimal gap */
}

.establishment-qr-card .qr-wrapper {
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 0.5rem;
  /* Minimal padding around QR */
  background: white;
  border-radius: var(--linkooc-radius-sm, 0.5rem);
}

.establishment-qr-card .establishment-details {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: 0;
}

.establishment-qr-card .establishment-details .label {
  font-size: 0.6rem;
  color: var(--linkooc-text-muted, #6d6d6d);
  text-transform: uppercase;
  letter-spacing: 0.5px;
  font-weight: 500;
}

.establishment-qr-card .establishment-details .name {
  font-size: 0.85rem;
  font-weight: 600;
  color: var(--linkooc-button-primary, #1a7431);
  text-decoration: none;
}

.establishment-qr-card .establishment-details a.name:hover {
  text-decoration: underline;
}

.establishment-qr-mini {
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 4px;
  background: white;
  border-radius: var(--linkooc-radius-sm, 0.5rem);
  border: 1px solid var(--linkooc-border-color);
}

/* ═══════════════════════════════════════════════════════════════════════
   QR CODE FLIP ANIMATION - Context-aware (Esta <-> Menus)
   ═══════════════════════════════════════════════════════════════════════ */
.qr-flip-container {
  perspective: 1000px;
}

.qr-flipper {
    position: relative;
    width: 120px;
    height: 120px;
    transition: transform 0.6s cubic-bezier(0.4, 0, 0.2, 1);
    transform-style: preserve-3d;
    padding: var(--linkooc-spacing-sm);
}

.qr-flipper.flipped {
  transform: rotateY(180deg);
}

.qr-front,
.qr-back {
  position: absolute;
  width: 100%;
  height: 100%;
  backface-visibility: hidden;
  display: flex;
  justify-content: center;
  align-items: center;
}

.qr-back {
  transform: rotateY(180deg);
}

/* Label Switcher Animation */
.qr-label-container {
  position: relative;
  width: 100%;
  height: 50px;
  overflow: hidden;
}

.qr-label-switcher {
  position: relative;
  width: 100%;
  transition: transform 0.4s cubic-bezier(0.4, 0, 0.2, 1);
}

.qr-label-switcher.show-esta {
  transform: translateY(0);
}

.qr-label-switcher.show-menus {
  transform: translateY(-50px);
}

.qr-label {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  height: 50px;
  justify-content: center;
}

.qr-label .label {
  font-size: 0.6rem;
  color: var(--linkooc-text-muted, #6d6d6d);
  text-transform: uppercase;
  letter-spacing: 0.5px;
  font-weight: 500;
}

.qr-label .name {
  font-size: 0.85rem;
  font-weight: 600;
  color: var(--linkooc-button-primary, #1a7431);
  text-decoration: none;
}

.qr-label a.name:hover {
  text-decoration: underline;
}

/* ═══════════════════════════════════════════════════════════════════════
   TOPBAR - New Layout
   ═══════════════════════════════════════════════════════════════════════ */
.topbar-new {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: var(--linkooc-spacing-sm, 0.5rem) var(--linkooc-spacing-md, 1rem);
  border-bottom: 1px solid var(--linkooc-border-color);
  background: var(--linkooc-second-bg);
  min-height: 48px;
}

.topbar-left,
.topbar-right {
  display: flex;
  align-items: center;
  gap: var(--linkooc-spacing-sm, 0.5rem);
}

.topbar-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  border: none;
  background: transparent;
  color: var(--linkooc-text);
  border-radius: var(--linkooc-radius-sm, 0.5rem);
  cursor: pointer;
  transition: var(--linkooc-transition-fast, 150ms ease);
}

.topbar-btn:hover {
  background: var(--linkooc-hover-bg);
}

.topbar-btn i {
  font-size: 1.1rem;
}

/* Smaller variant for sidebar toggle */
.topbar-btn-sm {
  width: 28px;
  height: 28px;
}

.topbar-btn-sm i {
  font-size: 0.9rem;
}

.topbar-info {
  display: flex;
  align-items: center;
  gap: 4px;
  padding: 4px 10px;
  background: var(--linkooc-bg);
  border: 1px solid var(--linkooc-border-color);
  border-radius: var(--linkooc-radius-sm, 0.5rem);
  font-size: var(--linkooc-small-size, 0.75rem);
}

.topbar-info .info-label {
  color: var(--linkooc-text-muted, #6d6d6d);
  font-weight: 500;
}

.topbar-info .info-value {
  color: var(--linkooc-text);
  font-weight: 600;
}

.topbar-info .info-id {
  color: var(--linkooc-text-muted, #6d6d6d);
  font-size: var(--linkooc-tiny-size, 0.65rem);
}

.bg-subtle-green {
  background-color: var(--linkooc-primary-subtle);
}

/* ═══════════════════════════════════════════════════════════════════════
   SIDEBAR SETTINGS DROPDOWN - Linkooc Visual Identity
   ═══════════════════════════════════════════════════════════════════════ */
.sidebar-settings-dropdown {
  position: relative;
}

.sidebar-settings-btn {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.75rem 1rem;
  background: transparent;
  border: none;
  color: var(--linkooc-text);
  cursor: pointer;
  transition: background-color var(--linkooc-transition-fast, 150ms ease);
  text-align: left;
}

.sidebar-settings-btn:hover {
  background-color: var(--linkooc-hover-bg);
}

.sidebar-settings-btn.collapsed {
  justify-content: center;
  padding: 0.75rem;
}

.sidebar-settings-btn i {
  font-size: 1rem;
}

.sidebar-settings-btn .nav-link-text {
  flex: 1;
  font-size: var(--linkooc-body-size, 0.875rem);
}

.sidebar-dropdown-toggle::after {
  content: '';
  display: inline-block;
  margin-left: auto;
  vertical-align: middle;
  border-bottom: 0.3em solid;
  border-right: 0.3em solid transparent;
  border-left: 0.3em solid transparent;
}

.sidebar-dropdown-toggle.collapsed::after {
  display: none;
}

.sidebar-dropdown-menu {
  position: absolute;
  left: 0;
  right: 0;
  bottom: calc(100% + 4px);
  z-index: 1050;
  background: var(--linkooc-bg, #fff);
  border: 1px solid var(--linkooc-border-color, #dee2e6);
  border-radius: var(--linkooc-radius-md, 0.5rem);
  box-shadow: var(--linkooc-shadow-md, 0 4px 16px rgba(0, 0, 0, 0.12));
  padding: 0.5rem 0;
  animation: sidebarDropdownIn 0.15s ease-out;
}

.sidebar-dropdown-menu-collapsed {
  left: calc(100% + 4px);
  right: auto;
  bottom: 0;
  min-width: 200px;
}

@keyframes sidebarDropdownIn {
  from {
    opacity: 0;
    transform: translateY(8px);
  }

  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.sidebar-dropdown-item {
  display: flex;
  align-items: center;
  width: 100%;
  padding: 0.5rem 1rem;
  border: none;
  background: transparent;
  text-align: left;
  cursor: pointer;
  transition: background-color var(--linkooc-transition-fast, 150ms ease);
}

.sidebar-dropdown-item:hover {
  background-color: var(--linkooc-hover-second-bg, #e7f1e8);
}

.sidebar-dropdown-item-content {
  display: flex;
  flex-direction: column;
}

.sidebar-dropdown-item-content span {
  font-size: var(--linkooc-body-size, 0.875rem);
  font-weight: 500;
  color: var(--linkooc-text-display, #000601);
}

.sidebar-dropdown-overlay {
  position: fixed;
  inset: 0;
  z-index: 1040;
  background: transparent;
}

/* ═══════════════════════════════════════════════════════════════════════════════
   LINKOOC ACTION BUTTONS - For Grid/Table row actions
   These styles override the default Bootstrap btn-primary/btn-danger to use
   Linkooc Visual Identity colors. Use .linkooc-action-btn-* classes.
   ═══════════════════════════════════════════════════════════════════════════════ */

/* Base action button container */
.linkooc-actions-cell {
  display: flex;
  gap: 0.5rem;
  justify-content: center;
  align-items: center;
}

/* Primary action button (Edit) - Linkooc green */
.linkooc-action-btn-edit {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
  border-radius: var(--linkooc-radius-md, 0.375rem);
  border: none;
  background-color: var(--linkooc-button-primary, #08781B);
  color: var(--linkooc-reverse-text, #ffffff);
  cursor: pointer;
  transition: background-color var(--linkooc-transition-fast, 150ms ease),
    transform var(--linkooc-transition-fast, 150ms ease);
}

.linkooc-action-btn-edit:hover:not(:disabled) {
  background-color: var(--linkooc-text-display-second, #22AD01);
  transform: translateY(-1px);
}

.linkooc-action-btn-edit:active:not(:disabled) {
  transform: translateY(0);
}

.linkooc-action-btn-edit:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}

/* Danger action button (Delete) - Red with subtle styling */
.linkooc-action-btn-delete {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
  border-radius: var(--linkooc-radius-md, 0.375rem);
  border: 1px solid var(--linkooc-danger, #BA1919);
  background-color: transparent;
  color: var(--linkooc-danger, #BA1919);
  cursor: pointer;
  transition: background-color var(--linkooc-transition-fast, 150ms ease),
    color var(--linkooc-transition-fast, 150ms ease),
    transform var(--linkooc-transition-fast, 150ms ease);
}

.linkooc-action-btn-delete:hover:not(:disabled) {
  background-color: var(--linkooc-danger, #BA1919);
  color: var(--linkooc-reverse-text, #ffffff);
  transform: translateY(-1px);
}

.linkooc-action-btn-delete:active:not(:disabled) {
  transform: translateY(0);
}

.linkooc-action-btn-delete:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}

/* Secondary action button (View/Info) - Outline style */
.linkooc-action-btn-secondary {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
  border-radius: var(--linkooc-radius-md, 0.375rem);
  border: 1px solid var(--linkooc-border-color, #dee2e6);
  background-color: transparent;
  color: var(--linkooc-text-secondary, #6d6d6d);
  cursor: pointer;
  transition: background-color var(--linkooc-transition-fast, 150ms ease),
    border-color var(--linkooc-transition-fast, 150ms ease),
    transform var(--linkooc-transition-fast, 150ms ease);
}

.linkooc-action-btn-secondary:hover:not(:disabled) {
  background-color: var(--linkooc-hover-bg, #F7F7F8);
  border-color: var(--linkooc-button-primary, #08781B);
  color: var(--linkooc-button-primary, #08781B);
  transform: translateY(-1px);
}

/* Action buttons with text (larger variant) */
.linkooc-action-btn-text {
  padding: 0.375rem 0.75rem;
  width: auto;
  font-size: var(--linkooc-small-size, 0.75rem);
  font-weight: 500;
}

.linkooc-action-btn-text i {
  margin-right: 0.375rem;
}

/* ═══════════════════════════════════════════════════════════════════════════════
   LINKOOC PAGE HEADER - Common styles for all pages
   Used with .linkooc-page-container, .linkooc-page-header, etc.
   ═══════════════════════════════════════════════════════════════════════════════ */

.linkooc-page-container {
  display: flex;
  flex-direction: column;
  height: 100%;
}

.linkooc-page-header {
  flex-shrink: 0;
}

.linkooc-breadcrumb .breadcrumb {
  font-size: var(--linkooc-breadcrumb-size, 0.8125rem);
}

.linkooc-breadcrumb .breadcrumb-item a {
  color: var(--linkooc-text-secondary, #6d6d6d);
  text-decoration: none;
}

.linkooc-breadcrumb .breadcrumb-item a:hover {
  color: var(--linkooc-button-primary, #08781B);
}

.linkooc-breadcrumb .breadcrumb-item.active {
  color: var(--linkooc-text-display, #000601);
  font-weight: 500;
}

.linkooc-page-title {
  font-size: var(--linkooc-page-title-size, 1.5rem);
  font-weight: var(--linkooc-page-title-weight, 600);
  color: var(--linkooc-text-display, #000601);
  margin: 0;
}

.linkooc-page-count {
  font-size: var(--linkooc-page-count-size, 1rem);
  font-weight: 400;
  color: var(--linkooc-text-secondary, #6d6d6d);
}

.linkooc-page-subtitle {
  font-size: var(--linkooc-page-subtitle-size, 0.875rem);
  color: var(--linkooc-text-secondary, #6d6d6d);
}

/* ═══════════════════════════════════════════════════════════════════════════════
   LINKOOC EMPTY STATE - Centered empty state pattern
   ═══════════════════════════════════════════════════════════════════════════════ */

.linkooc-empty-state {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  min-height: 300px;
  text-align: center;
}

.linkooc-empty-state i {
  font-size: 4rem;
  color: var(--linkooc-text-muted, #6d6d6d);
  margin-bottom: 1rem;
}

.linkooc-empty-state h4 {
  color: var(--linkooc-text-display, #000601);
  margin-bottom: 0.5rem;
}

.linkooc-empty-state p {
  color: var(--linkooc-text-muted, #6d6d6d);
  margin-bottom: 1.5rem;
}

/* ═══════════════════════════════════════════════════════════════════════════════
   LINKOOC USER AVATAR - Card avatar matching topbar style
   ═══════════════════════════════════════════════════════════════════════════════ */

.linkooc-user-avatar {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 48px;
  height: 48px;
  border-radius: 50%;
  background: var(--linkooc-primary-subtle, rgba(8, 120, 27, 0.1));
  border: 2px solid var(--linkooc-primary, #08781B);
  font-size: 1rem;
  font-weight: 600;
  color: var(--linkooc-primary, #08781B);
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.linkooc-user-avatar-sm {
  width: 36px;
  height: 36px;
  font-size: 0.75rem;
}

.linkooc-user-avatar-lg {
  width: 64px;
  height: 64px;
  font-size: 1.25rem;
}

