:root {
    /* ═══════════════════════════════════════════════════════════════════════
     BASE COLORS
     ═══════════════════════════════════════════════════════════════════════ */
    --linkooc-bg: #FFFFFF;
    --linkooc-bg-muted: #FEFEFE;
    --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-bg-primary: var(--linkooc-surface);
    --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 {
  /* ═══════════════════════════════════════════════════════════════════════
     DARK MODE OVERHAUL
     Inspired by: Linear, Vercel, GitHub, Notion, Figma
     Key principles:
       1. Multi-level surfaces (not flat) — Linear approach
       2. Semi-transparent borders — Vercel approach
       3. Desaturated accent green — GitHub approach
       4. Opacity-based text hierarchy — Notion approach
       5. Subtle tinted selections — Figma approach
     ═══════════════════════════════════════════════════════════════════════ */

  /* ── SURFACE LAYERING (Linear-inspired) ─────────────────────────────
     3 distinct surface levels create natural depth without shadows.
     Each layer is ~8-12% lighter than its parent.
     Old: bg #181818 / second-bg #162127 (blue-tinted, too close)
     New: true neutral grays with clear separation                    */
  --linkooc-bg: #0f0f0f;
  --linkooc-bg-muted: #141414;
  --linkooc-hover-bg: #1e1e1e;
  --linkooc-second-bg: #171717;
  --linkooc-hover-second-bg: #1a2e1e;

  /* ── TEXT HIERARCHY (Notion-inspired) ───────────────────────────────
     Using high-contrast white for primary, then stepping down opacity
     via actual hex values (more predictable than rgba in cascading vars).
     Old: #FFFFFF / #a0a0a0 (only 2 levels, muted was too dark)
     New: 4-tier system for clear readability                         */
  --linkooc-text: rgba(255, 255, 255, 0.92);
  --linkooc-text-display: rgba(255, 255, 255, 0.95);
  --linkooc-text-secondary: rgba(255, 255, 255, 0.55);
  --linkooc-text-display-tertiary: rgba(255, 255, 255, 0.35);

  /* ── ACCENT GREEN — DESATURATED (GitHub-inspired) ──────────────────
     Light mode green (#22AD01) is too vivid in dark mode — eye-searing.
     GitHub desaturates ~15-20% and reduces brightness for dark mode.
     Old: #22AD01 (same as light mode — neon glow)
     New: softer, more muted green that reads well on dark surfaces    */
  --linkooc-text-display-second: #34a853;
  --linkooc-button-primary: #1a8a30;
  --linkooc-button-primary-rgba: rgba(26, 138, 48, 0.45);
  --linkooc-button-secondary: #14712a;

  /* ── BORDERS — SEMI-TRANSPARENT (Vercel-inspired) ──────────────────
     Vercel uses hsla(0,0%,100%, 0.08-0.12) for borders.
     Semi-transparent white adapts to any surface level automatically.
     Old: #3a3a3a (solid gray — dead, invisible on dark surfaces)
     New: translucent white that creates subtle structure              */
  --linkooc-border-color: rgba(255, 255, 255, 0.08);

  /* Reverse tokens (for elements that need light-on-dark inversion) */
  --linkooc-reverse-second-bg: #FAFAFA;
  --linkooc-reverse-text: #0a0a0a;
  --linkooc-reverse-border-color: rgba(0, 0, 0, 0.12);

  /* ── SEMANTIC COLORS — TUNED FOR DARK (GitHub-inspired) ────────────
     Bump alpha to ~0.12-0.15 range for subtle tinted backgrounds.
     Old: 0.2 alpha was too heavy — created muddy colored blocks.
     New: lighter touch, visible but not overpowering                  */
  --linkooc-primary: var(--linkooc-button-primary);
  --linkooc-primary-light: #1a2e1e;
  --linkooc-primary-subtle: rgba(26, 138, 48, 0.10);
  --linkooc-danger: #e5534b;
  --linkooc-danger-light: rgba(229, 83, 75, 0.12);
  --linkooc-warning: #d29922;
  --linkooc-warning-light: rgba(210, 153, 34, 0.12);
  --linkooc-success: #34a853;
  --linkooc-success-light: rgba(52, 168, 83, 0.12);
  --linkooc-info: #58a6ff;
  --linkooc-info-light: rgba(88, 166, 255, 0.12);

  /* ── SURFACES & STATES ─────────────────────────────────────────────  */
  --linkooc-surface: var(--linkooc-second-bg);
  --linkooc-surface-hover: var(--linkooc-hover-bg);

  /* ── LIST SELECTION (Figma-inspired) ───────────────────────────────
     Figma uses low-opacity brand tint + accent left border.
     Old: rgba(8,120,27, 0.2) — heavy green block, swallows text.
     New: very subtle tint — the left border does the heavy lifting    */
  --linkooc-list-selection-bg: rgba(26, 138, 48, 0.08);
  --linkooc-list-selection-border-color: #34a853;
  --linkooc-list-hover-bg: rgba(255, 255, 255, 0.04);

  /* ── GREEN SCALE — DARK MODE OPTIMIZED ─────────────────────────────
     Spread is wider for better distinction between levels.
     Lower end is slightly warmer to avoid "dead" look                 */
  --linkooc-green-50: #0d1a0f;
  --linkooc-green-100: #0f2413;
  --linkooc-green-200: #122e17;
  --linkooc-green-300: #15391c;
  --linkooc-green-400: #194a22;
  --linkooc-green-500: #1a8a30;
  --linkooc-green-600: #34a853;
  --linkooc-green-700: #4cba68;
  --linkooc-green-800: #6fcc82;
  --linkooc-green-900: #95daa3;

  /* ── COLOR PALETTE VARIANTS — ADAPTED FOR DARK ─────────────────────  */
  --linkooc-green-var-1: #34a853;
  --linkooc-green-var-2: #2d9249;
  --linkooc-green-var-3: #257c3e;
  --linkooc-green-var-4: #1e6634;
  --linkooc-green-var-5: #185229;
  --linkooc-green-var-6: #123d1f;
  --linkooc-blue-var-1: #58a6ff;
  --linkooc-blue-var-2: #4899e8;
  --linkooc-blue-var-3: #388bd2;
  --linkooc-blue-var-4: #2d7bbc;
  --linkooc-blue-var-5: #236ba5;
  --linkooc-blue-var-6: #1a5b8f;
  --linkooc-red-var-1: #e5534b;
  --linkooc-red-var-2: #d4443c;
  --linkooc-red-var-3: #c3352e;
  --linkooc-red-var-4: #b12721;
  --linkooc-red-var-5: #9e1b15;
  --linkooc-red-var-6: #8b100c;
  --linkooc-orange-var-1: #d29922;
  --linkooc-orange-var-2: #c48b17;
  --linkooc-orange-var-3: #b57d0d;
  --linkooc-orange-var-4: #a76f05;
  --linkooc-orange-var-5: #986100;
  --linkooc-orange-var-6: #895300;

  /* ── GRADIENTS — DESATURATED FOR DARK ──────────────────────────────  */
  --linkooc-gradient-1: #1a8a30;
  --linkooc-gradient-2: #0e7a4c;
  --linkooc-gradient-3: #087a72;
  --linkooc-gradient-4: #0a7a98;
  --linkooc-gradient-5: #1078b5;
  --linkooc-gradient-6: #1a74c2;

  /* ── SHADOWS — GLOW INSTEAD OF DARKNESS ────────────────────────────
     In dark mode, shadows don't create depth (everything is dark).
     Instead: softer, slightly larger spreads + subtle glow.
     Old: just heavier black shadows (invisible on dark bg)
     New: wider, softer shadows with slight ambient lift               */
  --linkooc-shadow-sm: 0 1px 3px rgba(0, 0, 0, 0.4), 0 0 0 1px rgba(255, 255, 255, 0.03);
  --linkooc-shadow-md: 0 4px 12px rgba(0, 0, 0, 0.5), 0 0 0 1px rgba(255, 255, 255, 0.04);
  --linkooc-shadow-lg: 0 8px 24px rgba(0, 0, 0, 0.6), 0 0 0 1px rgba(255, 255, 255, 0.05);
  --linkooc-shadow-sticky: 0 -2px 12px rgba(0, 0, 0, 0.5), 0 0 0 1px rgba(255, 255, 255, 0.04);

  /* ── MATRIX COMPONENT TOKENS — DARK OVERRIDES ────────────────────── */
  --matrix-bg-primary: var(--linkooc-surface);
}

.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;
}

.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;
  flex-shrink: 0; /* Prevent topbar from shrinking */
}

.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;
  flex: 1;
  min-height: 0; /* Critical for flex children to respect overflow */
  overflow: hidden;
}

.linkooc-page-header {
  flex-shrink: 0;
  background-color: var(--linkooc-surface);
}

.linkooc-wizard-footer {
  background-color: var(--linkooc-surface);
}

.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 PAGE HEADER — MOBILE RESPONSIVE (≤768px)
   These rules apply automatically to ALL pages using standard Linkooc classes.
   Uses !important to override per-page scoped <style> blocks (Blazor b-xxxxx).
   ═══════════════════════════════════════════════════════════════════════════════ */
@media (max-width: 768px) {
  /* Hide subtitle — nobody reads it on small screens */
  .linkooc-page-subtitle {
    display: none !important;
  }

  /* Options dropdown — restyle trigger to ⋮ overflow icon on mobile */
  .linkooc-page-header .linkooc-dropdown .linkooc-dropdown-toggle .matrix-btn-label,
  .linkooc-page-header .linkooc-dropdown .linkooc-dropdown-toggle .btn-text {
    display: none !important;
  }
  .linkooc-page-header .linkooc-dropdown .linkooc-dropdown-toggle .matrix-btn-icon::before {
    content: "\f5d3" !important; /* bi-three-dots-vertical */
  }
  /* Hide the dropdown caret arrow on the ⋮ button */
  .linkooc-page-header .linkooc-dropdown .linkooc-dropdown-toggle::after {
    display: none !important;
  }
  .linkooc-page-header .linkooc-dropdown .linkooc-dropdown-toggle {
    width: 40px !important;
    height: 40px !important;
    min-width: 40px !important;
    padding: 0 !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    border-radius: var(--linkooc-radius, 1.5rem) !important;
  }
  .linkooc-page-header .linkooc-dropdown .linkooc-dropdown-toggle .matrix-btn-icon {
    margin: 0 !important;
  }

  /* Hide wiki/guide links (both wrapper span and direct component class) */
  .linkooc-page-header .link-to-wiki,
  .linkooc-page-header .linkooc-link-wiki {
    display: none !important;
  }

  /* Hide refresh button — not a mobile UX pattern */
  .linkooc-page-header .linkooc-refresh-btn {
    display: none !important;
  }

  /* Primary buttons: icon-only 40×40 square */
  .linkooc-page-header .matrix-btn-primary .matrix-btn-label,
  .linkooc-page-header .btn-primary .matrix-btn-label {
    display: none !important;
  }
  .linkooc-page-header .matrix-btn-primary,
  .linkooc-page-header .btn-primary {
    width: 40px !important;
    height: 40px !important;
    padding: 0 !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    border-radius: var(--linkooc-radius, 1.5rem) !important;
    min-width: 40px !important;
  }
  .linkooc-page-header .matrix-btn-primary .matrix-btn-icon,
  .linkooc-page-header .btn-primary .matrix-btn-icon {
    margin: 0 !important;
    font-size: 1.125rem !important;
  }
  /* Fallback: text-only primary buttons (no icon) keep text */
  .linkooc-page-header .matrix-btn-primary:not(:has(.matrix-btn-icon)),
  .linkooc-page-header .btn-primary:not(:has(.matrix-btn-icon)) {
    width: auto !important;
    padding: 0.375rem 0.75rem !important;
  }
  .linkooc-page-header .matrix-btn-primary:not(:has(.matrix-btn-icon)) .matrix-btn-label,
  .linkooc-page-header .btn-primary:not(:has(.matrix-btn-icon)) .matrix-btn-label {
    display: inline !important;
    font-size: 0.8125rem !important;
  }

  /* Page title: smaller */
  .linkooc-page-title {
    font-size: 1.125rem !important;
  }

  /* Breadcrumb: hide on mobile — hamburger + back nav is enough */
  .linkooc-breadcrumb {
    display: none !important;
  }

  /* Header padding: tighter on mobile */
  .linkooc-page-header {
    padding: 0.375rem 0.75rem !important;
  }

  /* Title row: reduce bottom margin, center-align buttons with title (subtitle hidden) */
  .linkooc-page-header .d-flex.mb-2 {
    margin-bottom: 0.25rem !important;
    align-items: center !important;
  }
  .linkooc-page-header .linkooc-title-right {
    flex-shrink: 0;
  }
}

/* ═══════════════════════════════════════════════════════════════════════════════
   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;
}

/* ═══════════════════════════════════════════════════════════════════════════════
   LAYOUT HEIGHT FIX - Ensure full viewport height for pages
   The .main > .content > .container > .row > .col-md-12 chain must propagate height
   so that pages using h-100 and flex-grow-1 can fill remaining space.
   ═══════════════════════════════════════════════════════════════════════════════ */

main {
  display: flex;
  flex-direction: column;
  height: 100vh;
  overflow: hidden;
}

main > .content {
  flex: 1;
  display: flex;
  flex-direction: column;
  min-height: 0; /* Critical for flex children to shrink */
  overflow: hidden;
  padding-top: 0 !important; /* Override site.css */
}

main > .content > .container {
  flex: 1;
  display: flex;
  flex-direction: column;
  min-height: 0;
  max-width: 100%; /* Override Bootstrap container max-width */
  padding: 0;
}

main > .content > .container > .row {
  flex: 1;
  min-height: 0;
}

main > .content > .container > .row > .col-md-12 {
  height: 100%;
  display: flex;
  flex-direction: column;
  min-height: 0;
  overflow: hidden;
}

