:root {
  /* ==========================================================================
     1. PRIMITIVE TOKENS (Raw values / Base colors / Statics)
     ========================================================================== */
  
  /* --- Brand Colors --- */
  --sb-primitive-blue-500: #1a73e8;       /* Brand accent base blue (3.1:1 contrast on white) */
  --sb-primitive-blue-600: #1557b0;       /* Contrast-safe primary blue (4.8:1 contrast on white, WCAG AA) */
  --sb-primitive-blue-50: #e8f0fe;        /* Light theme primary background */
  
  --sb-primitive-purple-500: #6f42c1;     /* Secondary base purple */
  --sb-primitive-purple-50: #f3e8fd;
  
  /* --- State & Accent Colors --- */
  --sb-primitive-green-500: #1e8e3e;      /* Success base green (WCAG AA compliant) */
  --sb-primitive-green-600: #157347;      /* Success dark green */
  --sb-primitive-green-50: #e6f4ea;
  
  --sb-primitive-yellow-500: #b06000;     /* Warning base amber/dark yellow (WCAG AA compliant) */
  --sb-primitive-yellow-600: #ffca2c;     /* Warning light/yellow */
  --sb-primitive-yellow-50: #fef7e0;
  
  --sb-primitive-orange-500: #f97316;     /* Orange accent */
  --sb-primitive-orange-50: #fef0e0;
  
  --sb-primitive-red-500: #d93025;        /* Danger base red (WCAG AA compliant) */
  --sb-primitive-red-600: #bb2d3b;        /* Danger dark red */
  --sb-primitive-red-50: #fce8e6;
  
  --sb-primitive-cyan-500: #007b83;       /* Info base cyan (WCAG AA compliant) */
  --sb-primitive-cyan-50: #e4f7fb;
  
  --sb-primitive-teal-500: #20c997;       /* Chart/State active green */
  
  /* --- Neutral Grays --- */
  --sb-primitive-gray-50: #f8f9fc;        /* Light bg */
  --sb-primitive-gray-100: #f1f3f4;       /* Border light */
  --sb-primitive-gray-200: #dadce0;       /* Border default */
  --sb-primitive-gray-600: #5f6368;       /* Text muted */
  --sb-primitive-gray-700: #495057;       /* Text intermediate */
  --sb-primitive-gray-800: #2b303c;
  --sb-primitive-gray-900: #202124;       /* Text main */

  /* --- Raw RGB values (For opacity/RGBA calculations) --- */
  --sb-primitive-rgb-blue: 26, 115, 232;
  --sb-primitive-rgb-purple: 111, 66, 193;
  --sb-primitive-rgb-green: 30, 142, 62;
  --sb-primitive-rgb-yellow: 176, 96, 0;
  --sb-primitive-rgb-red: 217, 48, 37;
  --sb-primitive-rgb-cyan: 0, 123, 131;
  --sb-primitive-rgb-white: 255, 255, 255;
  --sb-primitive-rgb-black: 0, 0, 0;

  /* --- Dark Theme Grays --- */
  --sb-primitive-dark-bg-darkest: #111217;
  --sb-primitive-dark-bg-alt: #24292e;
  --sb-primitive-dark-surface: #1a1b1e;
  --sb-primitive-dark-border: #202226;
  --sb-primitive-dark-surface-alt: #22252b;

  /* --- Typography --- */
  --sb-primitive-font-family: 'Inter', 'Roboto', -apple-system, BlinkMacSystemFont, "Segoe UI", Arial, sans-serif;
  --sb-primitive-font-mono: 'SFMono-Regular', Consolas, 'Liberation Mono', Menlo, monospace;
  
  --sb-primitive-font-xs: 0.7rem;
  --sb-primitive-font-sm: 0.875rem;
  --sb-primitive-font-base: 1rem;
  --sb-primitive-font-lg: 1.125rem;
  --sb-primitive-font-xl: 1.25rem;
  --sb-primitive-font-2xl: 1.5rem;
  --sb-primitive-font-3xl: 1.875rem;

  /* --- Spacing --- */
  --sb-primitive-spacing-xs: 0.25rem;
  --sb-primitive-spacing-sm: 0.5rem;
  --sb-primitive-spacing-md: 1rem;
  --sb-primitive-spacing-lg: 1.5rem;
  --sb-primitive-spacing-xl: 2rem;
  --sb-primitive-spacing-2xl: 3rem;

  /* --- Border Radius --- */
  --sb-primitive-radius-sm: 6px;
  --sb-primitive-radius-md: 10px;
  --sb-primitive-radius-lg: 14px;
  --sb-primitive-radius-xl: 18px;
  --sb-primitive-radius-full: 9999px;

  /* --- Shadow Bases --- */
  --sb-primitive-shadow-sm: 0 1px 3px rgba(0, 0, 0, 0.12), 0 1px 2px rgba(0, 0, 0, 0.24);
  --sb-primitive-shadow-md: 0 4px 6px -1px rgba(0, 0, 0, 0.1), 0 2px 4px -1px rgba(0, 0, 0, 0.06);
  --sb-primitive-shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -2px rgba(0, 0, 0, 0.05);

  /* --- Transitions --- */
  --sb-primitive-transition-fast: 150ms cubic-bezier(0.4, 0, 0.2, 1);
  --sb-primitive-transition-base: 250ms cubic-bezier(0.4, 0, 0.2, 1);
  --sb-primitive-transition-slow: 400ms cubic-bezier(0.4, 0, 0.2, 1);

  /* ==========================================================================
     2. SEMANTIC TOKENS (Functional context / Intent)
     ========================================================================== */

  /* --- Brand Semantics --- */
  --sb-color-primary: var(--sb-primitive-blue-500);
  --sb-color-primary-dark: var(--sb-primitive-blue-600);
  --sb-color-primary-text: var(--sb-primitive-blue-600);   /* Resolved contrast (4.8:1) for text/links on white */
  --sb-color-primary-bg-light: var(--sb-primitive-blue-50);
  
  --sb-color-secondary: var(--sb-primitive-purple-500);
  --sb-color-secondary-bg-light: var(--sb-primitive-purple-50);

  /* --- State Semantics --- */
  --sb-color-success: var(--sb-primitive-green-500);
  --sb-color-success-dark: var(--sb-primitive-green-600);
  --sb-color-success-bg: var(--sb-primitive-green-50);
  
  --sb-color-warning: var(--sb-primitive-yellow-500);
  --sb-color-warning-dark: var(--sb-primitive-yellow-500);
  --sb-color-warning-bg: var(--sb-primitive-yellow-50);
  
  --sb-color-danger: var(--sb-primitive-red-500);
  --sb-color-danger-dark: var(--sb-primitive-red-600);
  --sb-color-danger-bg: var(--sb-primitive-red-50);
  
  --sb-color-info: var(--sb-primitive-cyan-500);
  --sb-color-info-bg: var(--sb-primitive-cyan-50);

  /* --- Keyboard Navigation Focus Indicator (Accessibility) --- */
  --sb-color-focus-ring: var(--sb-color-primary-text);
  --sb-focus-ring-shadow: 0 0 0 3px rgba(var(--sb-primitive-rgb-blue), 0.45);

  /* --- Layout & Neutral Theme mapping --- */
  --sb-bg-main: var(--sb-primitive-gray-50);
  --sb-bg-card: #ffffff;
  
  --sb-text-main: var(--sb-primitive-gray-900);
  --sb-text-muted: var(--sb-primitive-gray-600);
  --sb-text-light: var(--sb-primitive-gray-700);
  
  --sb-border: var(--sb-primitive-gray-200);
  --sb-border-light: var(--sb-primitive-gray-100);

  /* --- Typography Config mapping --- */
  --sb-font-main: var(--sb-primitive-font-family);
  --sb-font-mono: var(--sb-primitive-font-mono);
  --sb-font-xs: var(--sb-primitive-font-xs);
  --sb-font-sm: var(--sb-primitive-font-sm);
  --sb-font-base: var(--sb-primitive-font-base);
  --sb-font-lg: var(--sb-primitive-font-lg);
  --sb-font-xl: var(--sb-primitive-font-xl);
  --sb-font-2xl: var(--sb-primitive-font-2xl);
  --sb-font-3xl: var(--sb-primitive-font-3xl);

  /* --- Spacing Config mapping --- */
  --sb-sp-xs: var(--sb-primitive-spacing-xs);
  --sb-sp-sm: var(--sb-primitive-spacing-sm);
  --sb-sp-md: var(--sb-primitive-spacing-md);
  --sb-sp-lg: var(--sb-primitive-spacing-lg);
  --sb-sp-xl: var(--sb-primitive-spacing-xl);
  --sb-sp-2xl: var(--sb-primitive-spacing-2xl);

  /* --- Border Radius Config mapping --- */
  --sb-radius-sm: var(--sb-primitive-radius-sm);
  --sb-radius-md: var(--sb-primitive-radius-md);
  --sb-radius-lg: var(--sb-primitive-radius-lg);
  --sb-radius-xl: var(--sb-primitive-radius-xl);
  --sb-radius-full: var(--sb-primitive-radius-full);

  /* --- Transitions Config mapping --- */
  --sb-transition-fast: var(--sb-primitive-transition-fast);
  --sb-transition-base: var(--sb-primitive-transition-base);
  --sb-transition-slow: var(--sb-primitive-transition-slow);

  /* --- Shadows Theme mapping --- */
  --sb-shadow-sm: var(--sb-primitive-shadow-sm);
  --sb-shadow-md: var(--sb-primitive-shadow-md);
  --sb-shadow-lg: var(--sb-primitive-shadow-lg);

  /* ==========================================================================
     3. COMPONENT TOKENS & BACKWARD COMPATIBILITY ALIASES (Legacy mappings)
     ========================================================================== */

  /* --- Brand & Base compatibility aliases --- */
  --sb-primary: var(--sb-color-primary);
  --sb-primary-dark: var(--sb-color-primary-dark);
  --sb-primary-light: var(--sb-color-primary-bg-light);
  --sb-primary-text: var(--sb-color-primary-text);          /* Contrast-safe primary blue for text/links */
  --sb-secondary: var(--sb-color-secondary);
  --sb-secondary-light: var(--sb-color-secondary-bg-light);

  /* --- Base RGB Components compatibility --- */
  --sb-primary-rgb: var(--sb-primitive-rgb-blue);
  --sb-secondary-rgb: var(--sb-primitive-rgb-purple);
  --sb-success-rgb: var(--sb-primitive-rgb-green);
  --sb-warning-rgb: var(--sb-primitive-rgb-yellow);
  --sb-danger-rgb: var(--sb-primitive-rgb-red);
  --sb-info-rgb: var(--sb-primitive-rgb-cyan);
  --sb-white-rgb: var(--sb-primitive-rgb-white);
  --sb-black-rgb: var(--sb-primitive-rgb-black);

  /* --- Advanced Parameter & State Colors --- */
  --sb-pf: #009688;
  --sb-pf-bg: rgba(0, 150, 136, 0.08);
  --sb-pf-border: rgba(0, 150, 136, 0.2);
  --sb-kurtosis: #e91e63;
  --sb-kurtosis-bg: rgba(233, 30, 99, 0.08);
  --sb-kurtosis-border: rgba(233, 30, 99, 0.2);
  --sb-crest: #673ab7;
  --sb-crest-bg: rgba(103, 58, 183, 0.08);
  --sb-crest-border: rgba(103, 58, 183, 0.2);
  --sb-state-active: var(--sb-primitive-teal-500);
  --sb-state-active-bg: rgba(32, 201, 151, 0.08);
  --sb-state-active-border: rgba(32, 201, 151, 0.2);
  --sb-state-idle: var(--sb-color-warning);
  --sb-state-idle-bg: rgba(255, 193, 7, 0.08);
  --sb-state-idle-border: rgba(255, 193, 7, 0.2);
  --sb-state-stopped: #6c757d;
  --sb-state-stopped-bg: rgba(108, 117, 125, 0.08);
  --sb-state-stopped-border: rgba(108, 117, 125, 0.2);
  --sb-tariff: #0d6efd;
  --sb-tariff-bg: rgba(13, 110, 253, 0.08);
  --sb-tariff-border: rgba(13, 110, 253, 0.2);

  /* --- Specific Page and Grafana Theme Dark Colors --- */
  --sb-dark-bg: var(--sb-primitive-dark-bg-alt);
  --sb-dark-bg-darker: var(--sb-primitive-dark-bg-darkest);
  --sb-dark-bg-alt: var(--sb-primitive-dark-bg-alt);
  --sb-dark-surface: var(--sb-primitive-dark-surface);
  --sb-dark-surface-alt: var(--sb-primitive-dark-surface-alt);
  --sb-dark-border: var(--sb-primitive-dark-border);
  --sb-dark-text: #ffffff;
  --sb-dark-text-muted: #8e8e8e;
  
  --sb-grafana-border: #2c323a;
  --sb-grafana-text: #d8d9da;
  --sb-grafana-muted: #9fa6b2;
  --sb-dark-nav-bg-rgb: 26, 28, 30;
  --sb-dark-dropdown-bg-rgb: 30, 32, 35;
  --sb-bg-dark-slate-rgb: 15, 23, 42;

  /* --- Badge Border Colors (Slightly darker than light backgrounds) --- */
  --sb-primary-light-border: #d2e3fc;
  --sb-warning-light-border: #feefc3;
  --sb-success-light-border: #ceead6;
  --sb-danger-light-border: #fad2cf;
  --sb-info-light-border: #c2f0fb;
  --sb-secondary-light-border: #e2d5f7;

  /* --- Card Gradient Helpers --- */
  --sb-success-bg-light: #f4faf6;
  --sb-warning-bg-light: #fffcf5;
  --sb-orange-bg: #fef0e0;
  --sb-orange-bg-light: #fffaf5;
  --sb-danger-bg-light: #fff7f6;
  --sb-neutral-bg-light: #f8f9fa;
  --sb-dark-gradient-1: #0f172a;
  --sb-dark-gradient-2: #1e1b4b;
  --sb-dark-gradient-3: #311062;
  
  --sb-bg-main-rgb: 248, 249, 252;

  /* --- Extra State and Theme Colors compatibility --- */
  --sb-cyan: #007b83;
  --sb-cyan-rgb: 0, 123, 131;
  --sb-emerald: #1e8e3e;
  --sb-emerald-rgb: 30, 142, 62;
  --sb-amber: #b06000;
  --sb-amber-rgb: 176, 96, 0;
  --sb-orange: var(--sb-primitive-orange-500);
  --sb-orange-rgb: 249, 115, 22;
  --sb-red: var(--sb-primitive-red-500);
  --sb-red-rgb: 217, 48, 37;
  --sb-gray: var(--sb-primitive-gray-600);
  --sb-gray-rgb: 128, 128, 128;
  --sb-gray-600: var(--sb-primitive-gray-600);
  --sb-gray-700: var(--sb-primitive-gray-700);
  --sb-gray-900: var(--sb-primitive-gray-900);
  --sb-bg-gray: #e9ecef;
  --sb-bg-off-white: #fdfdfd;

  /* --- Chart and State RGB Components --- */
  --sb-chart-active-rgb: 13, 202, 240;
  --sb-state-active-rgb: 32, 201, 151;

  /* --- Specific Hover and Dark Variants --- */
  --sb-success-dark: var(--sb-color-success-dark);
  --sb-success-alt-rgb: 25, 135, 84;
  --sb-danger-dark: var(--sb-color-danger-dark);
  --sb-danger-alt-rgb: 220, 53, 69;
  --sb-warning-dark: var(--sb-primitive-yellow-500);
  --sb-warning-alt-rgb: 255, 193, 7;
  --sb-info-dark: #31d2f2;
  --sb-blue-light: #64b5f6;
  --sb-danger-light: #ff4d4d;
  --sb-shadow-blue-rgb: 31, 38, 135;

  /* --- State Semantic colors compatibility mapping --- */
  --sb-success: var(--sb-color-success);
  --sb-success-bg: var(--sb-color-success-bg);
  --sb-warning: var(--sb-color-warning);
  --sb-warning-bg: var(--sb-color-warning-bg);
  --sb-danger: var(--sb-color-danger);
  --sb-danger-bg: var(--sb-color-danger-bg);
  --sb-info: var(--sb-color-info);
  --sb-info-bg: var(--sb-color-info-bg);

  /* --- Chart & Heatmap Colors compatibility --- */
  --sb-chart-active: #0dcaf0;
  --sb-chart-idle: #ffc107;
  --sb-chart-stopped: #eeeeee;

  /* --- Shadow Bases mapping --- */
  --sb-shadow-soft: 0 10px 30px rgba(0, 0, 0, 0.05);
  --sb-shadow-left: -10px 0 30px rgba(0, 0, 0, 0.05);
  --sb-shadow-primary: 0 4px 15px rgba(var(--sb-primary-rgb), 0.2);

  /* --- Subscription & Plan Gradients --- */
  --sb-grad-free: linear-gradient(135deg, #747d8c 0%, #2f3542 100%);
  --sb-grad-starter: linear-gradient(135deg, #747d8c 0%, #2f3542 100%);
  --sb-grad-primary: linear-gradient(135deg, #1a73e8 0%, #0d47a1 100%);
  --sb-grad-success: linear-gradient(135deg, #20c997 0%, #198754 100%);
  --sb-grad-warning: linear-gradient(135deg, #ffc107 0%, #ff8f00 100%);
  --sb-grad-danger: linear-gradient(135deg, #dc3545 0%, #a71d2a 100%);
  --sb-grad-info: linear-gradient(135deg, #0dcaf0 0%, #0aa2c0 100%);
  --sb-grad-dark: linear-gradient(135deg, #212529 0%, #111217 100%);

  /* --- Bootstrap Overrides --- */
  --bs-font-sans-serif: var(--sb-font-main) !important;
  --bs-body-font-family: var(--sb-font-main) !important;
}

body {
  font-family: var(--sb-font-main);
  background-color: var(--sb-bg-main);
  color: var(--sb-text-main);
  margin: 0;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}
/* SuperBox Design System: Buttons */

.btn-sb {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-weight: 600;
  padding: var(--sb-sp-sm) var(--sb-sp-lg);
  border-radius: var(--sb-radius-md);
  transition: all var(--sb-transition-base);
  border: 1px solid transparent;
  cursor: pointer;
  font-size: 0.95rem;
  gap: var(--sb-sp-sm);
  text-decoration: none !important;
}

.btn-sb:hover {
  transform: translateY(-1px);
}

.btn-sb:active {
  transform: translateY(0);
}

/* Primary Button */
.btn-sb-primary {
  background-color: var(--sb-primary) !important;
  color: white !important;
  box-shadow: var(--sb-shadow-primary) !important;
}

.btn-sb-primary:hover {
  background-color: var(--sb-primary-dark);
  box-shadow: 0 6px 20px rgba(var(--sb-primary-rgb), 0.4);
}

.btn-sb-success { background-color: var(--sb-success); color: white !important; }
.btn-sb-success:hover { background-color: var(--sb-success-dark); box-shadow: 0 6px 20px rgba(var(--sb-success-alt-rgb), 0.4); }

.btn-sb-danger { background-color: var(--sb-danger); color: white !important; }
.btn-sb-danger:hover { background-color: var(--sb-danger-dark); box-shadow: 0 6px 20px rgba(var(--sb-danger-alt-rgb), 0.4); }

.btn-sb-warning { background-color: var(--sb-warning); color: var(--sb-text-main) !important; }
.btn-sb-warning:hover { background-color: var(--sb-warning-dark); box-shadow: 0 6px 20px rgba(var(--sb-warning-alt-rgb), 0.4); }

.btn-sb-info { background-color: var(--sb-info); color: white !important; }
.btn-sb-info:hover { background-color: var(--sb-info-dark); box-shadow: 0 6px 20px rgba(var(--sb-chart-active-rgb), 0.4); }

/* Soft Buttons */
.btn-sb-soft-primary {
  background-color: var(--sb-primary-light);
  color: var(--sb-primary-text) !important;
}

.btn-sb-soft-primary:hover {
  background-color: var(--sb-primary-light-border);
}

.btn-sb-soft-success {
  background-color: var(--sb-success-bg);
  color: var(--sb-success) !important;
}

.btn-sb-soft-success:hover {
  background-color: var(--sb-success-light-border);
}

.btn-sb-soft-danger {
  background-color: var(--sb-danger-bg);
  color: var(--sb-danger) !important;
}

.btn-sb-soft-danger:hover {
  background-color: var(--sb-danger-light-border);
}

.btn-sb-soft-warning {
  background-color: var(--sb-warning-bg);
  color: var(--sb-warning) !important;
}

.btn-sb-soft-warning:hover {
  background-color: var(--sb-warning-light-border);
}

.btn-sb-soft-info {
  background-color: var(--sb-info-bg);
  color: var(--sb-info) !important;
}

.btn-sb-soft-info:hover {
  background-color: var(--sb-info-light-border);
}

/* Outline Buttons */
.btn-outline-sb-primary {
  background: transparent;
  border-color: var(--sb-primary);
  color: var(--sb-primary-text) !important;
}

.btn-outline-sb-primary:hover {
  background: var(--sb-primary-light);
  border-color: var(--sb-primary);
}

.btn-check:checked + .btn-outline-sb-primary {
  background-color: var(--sb-primary) !important;
  color: var(--sb-dark-text) !important;
  box-shadow: var(--sb-shadow-primary);
}

/* Icon Buttons */
.btn-sb-icon {
  width: 42px;
  height: 42px;
  padding: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  border-radius: var(--sb-radius-md);
}

.btn-sb-icon:hover {
  transform: scale(1.1);
}

.btn-sb-icon-sm {
  width: 28px;
  height: 28px;
  font-size: 0.8rem;
  padding: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: var(--sb-radius-sm);
}

/* Ghost Button */
.btn-sb-ghost {
  background: transparent;
  color: var(--sb-text-muted);
}

.btn-sb-ghost:hover {
  background: var(--sb-border-light);
  color: var(--sb-text-main);
}
/* SuperBox Design System: Cards */

.sb-card {
  background: var(--sb-bg-card);
  border-radius: var(--sb-radius-lg);
  border: none;
  padding: var(--sb-sp-lg);
  box-shadow: var(--sb-shadow-soft);
  transition: all var(--sb-transition-base);
  position: relative;
  overflow: hidden;
}

/* Leftward focus card (Project Standard) */
.sb-card-left {
  box-shadow: var(--sb-shadow-left);
  border-left-width: 4px;
}

.sb-card-left.primary { border-color: rgba(var(--sb-primary-rgb), 0.2); border-left-color: var(--sb-primary); }
.sb-card-left.success { border-color: rgba(var(--sb-success-rgb), 0.2); border-left-color: var(--sb-success); }
.sb-card-left.warning { border-color: rgba(var(--sb-warning-rgb), 0.2); border-left-color: var(--sb-warning); }
.sb-card-left.danger { border-color: rgba(var(--sb-danger-rgb), 0.2); border-left-color: var(--sb-danger); }
.sb-card-left.info { border-color: rgba(var(--sb-info-rgb), 0.2); border-left-color: var(--sb-info); }

/* Hover Lift Effect */
.sb-card-hover:hover {
  transform: translateY(-4px);
  box-shadow: var(--sb-shadow-lg);
}

/* Glassmorphism Card */
.sb-card-glass {
  background: rgba(var(--sb-white-rgb), 0.7);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border: 1px solid rgba(var(--sb-white-rgb), 0.2);
}

.sb-card-primary {
  background-color: var(--sb-bg-card);
  border: 1px solid var(--sb-primary);
  color: var(--sb-primary);
}

.sb-card-success {
  background-color: var(--sb-bg-card);
  border: 1px solid var(--sb-success);
  color: var(--sb-success);
}

.sb-card-warning {
  background-color: var(--sb-bg-card);
  border: 1px solid var(--sb-warning);
  color: var(--sb-warning);
}

.sb-card-danger {
  background-color: var(--sb-bg-card);
  border: 1px solid var(--sb-danger);
  color: var(--sb-danger);
}

.sb-card-info {
  background-color: var(--sb-bg-card);
  border: 1px solid var(--sb-info);
  color: var(--sb-info);
}

.sb-card-dark {
  background-color: var(--sb-bg-card);
  border: 1px solid var(--sb-dark-bg);
  color: var(--sb-dark-bg);
}

/* Dashboard Analytics Card (Refined) */
.sb-card-analytics {
  background: var(--sb-bg-card);
  border-radius: var(--sb-radius-lg);
  border: 1px solid var(--sb-border-light);
  padding: var(--sb-sp-lg);
  box-shadow: var(--sb-shadow-left);
  border-left: 4px solid var(--sb-primary);
  display: flex;
  flex-direction: column;
  gap: var(--sb-sp-sm);
  min-height: 120px;
  transition: all var(--sb-transition-base);
}

.sb-card-analytics.primary { border-color: rgba(var(--sb-primary-rgb), 0.2); border-left-color: var(--sb-primary); }
.sb-card-analytics.success { border-color: rgba(var(--sb-success-rgb), 0.2); border-left-color: var(--sb-success); }
.sb-card-analytics.warning { border-color: rgba(var(--sb-warning-rgb), 0.2); border-left-color: var(--sb-warning); }
.sb-card-analytics.danger { border-color: rgba(var(--sb-danger-rgb), 0.2); border-left-color: var(--sb-danger); }
.sb-card-analytics.info { border-color: rgba(var(--sb-info-rgb), 0.2); border-left-color: var(--sb-info); }

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

/* Interactive Selection Card */
.sb-card-interactive {
  cursor: pointer;
  border: 2px solid var(--sb-border-light);
  transition: all var(--sb-transition-base);
  background: var(--sb-bg-card);
}

.sb-card-interactive:hover {
  border-color: var(--sb-primary-light);
  transform: translateY(-2px);
  box-shadow: var(--sb-shadow-md);
}

.sb-card-interactive.active {
  border-color: var(--sb-primary);
  background: var(--sb-bg-main);
  box-shadow: var(--sb-shadow-lg);
}

.sb-card-interactive .sb-radio-input {
  display: none;
}

/* Glassmorphism Variants */
.sb-glass-card {
  background: rgba(var(--sb-white-rgb), 0.7);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  border: 1px solid rgba(var(--sb-white-rgb), 0.3);
  box-shadow: 0 8px 32px 0 rgba(var(--sb-shadow-blue-rgb), 0.07);
}

.sb-glass-card-dark {
  background: rgba(var(--sb-bg-dark-slate-rgb), 0.8) !important;
  backdrop-filter: blur(16px) !important;
  -webkit-backdrop-filter: blur(16px) !important;
  border: 1px solid rgba(var(--sb-white-rgb), 0.1) !important;
  color: white !important;
}

/* Local contrast overrides for elements nested inside a dark glass card on light layout */
.sb-glass-card-dark.dark-card-content,
.sb-glass-card-dark .dark-card-content {
  color: rgba(var(--sb-white-rgb), 0.9) !important;
}
.sb-glass-card-dark .sb-form-label {
  color: rgba(var(--sb-white-rgb), 0.7) !important;
}
.sb-glass-card-dark .text-muted,
.sb-glass-card-dark .text-white-50 {
  color: rgba(var(--sb-white-rgb), 0.5) !important;
}
.sb-glass-card-dark .sb-input {
  background-color: rgba(var(--sb-bg-dark-slate-rgb), 0.6) !important;
  color: rgba(var(--sb-white-rgb), 1) !important;
  border-color: rgba(var(--sb-white-rgb), 0.15) !important;
}
.sb-glass-card-dark .sb-input:focus {
  background-color: rgba(var(--sb-bg-dark-slate-rgb), 0.8) !important;
  border-color: var(--sb-primary) !important;
  box-shadow: 0 0 0 3px rgba(var(--sb-primary-rgb), 0.25) !important;
}
.sb-glass-card-dark .sb-input::placeholder {
  color: rgba(var(--sb-white-rgb), 0.35) !important;
}
.sb-glass-card-dark table,
.sb-glass-card-dark table th,
.sb-glass-card-dark table td,
.sb-glass-card-dark table tr {
  background-color: transparent !important;
  background: transparent !important;
  color: inherit !important;
}


/* Predictive Maintenance Health Themes (Light Theme Optimized) */
.sb-glass-card-pdm-normal {
  background: linear-gradient(135deg, var(--sb-success-bg) 0%, var(--sb-success-bg-light) 100%) !important;
  border: 1px solid rgba(var(--sb-success-rgb), 0.22) !important;
  box-shadow: 0 8px 32px 0 rgba(var(--sb-success-rgb), 0.05) !important;
  color: var(--sb-text-main) !important;
}
.sb-glass-card-pdm-normal::before {
  content: "";
  position: absolute;
  width: 300px;
  height: 300px;
  background: radial-gradient(circle, rgba(var(--sb-success-rgb), 0.08) 0%, rgba(var(--sb-black-rgb), 0) 70%);
  top: -100px;
  right: -50px;
  pointer-events: none;
}
.sb-glass-card-pdm-normal::after {
  content: "";
  position: absolute;
  width: 200px;
  height: 200px;
  background: radial-gradient(circle, rgba(var(--sb-success-rgb), 0.04) 0%, rgba(var(--sb-black-rgb), 0) 70%);
  bottom: -80px;
  left: -50px;
  pointer-events: none;
}

.sb-glass-card-pdm-warning_early {
  background: linear-gradient(135deg, var(--sb-warning-bg) 0%, var(--sb-warning-bg-light) 100%) !important;
  border: 1px solid rgba(var(--sb-warning-rgb), 0.22) !important;
  box-shadow: 0 8px 32px 0 rgba(var(--sb-warning-rgb), 0.05) !important;
  color: var(--sb-text-main) !important;
}
.sb-glass-card-pdm-warning_early::before {
  content: "";
  position: absolute;
  width: 300px;
  height: 300px;
  background: radial-gradient(circle, rgba(var(--sb-warning-rgb), 0.08) 0%, rgba(var(--sb-black-rgb), 0) 70%);
  top: -100px;
  right: -50px;
  pointer-events: none;
}
.sb-glass-card-pdm-warning_early::after {
  content: "";
  position: absolute;
  width: 200px;
  height: 200px;
  background: radial-gradient(circle, rgba(var(--sb-warning-rgb), 0.04) 0%, rgba(var(--sb-black-rgb), 0) 70%);
  bottom: -80px;
  left: -50px;
  pointer-events: none;
}

.sb-glass-card-pdm-warning_active {
  background: linear-gradient(135deg, var(--sb-orange-bg) 0%, var(--sb-orange-bg-light) 100%) !important;
  border: 1px solid rgba(var(--sb-orange-rgb), 0.22) !important;
  box-shadow: 0 8px 32px 0 rgba(var(--sb-orange-rgb), 0.05) !important;
  color: var(--sb-text-main) !important;
}
.sb-glass-card-pdm-warning_active::before {
  content: "";
  position: absolute;
  width: 300px;
  height: 300px;
  background: radial-gradient(circle, rgba(var(--sb-orange-rgb), 0.08) 0%, rgba(var(--sb-black-rgb), 0) 70%);
  top: -100px;
  right: -50px;
  pointer-events: none;
}
.sb-glass-card-pdm-warning_active::after {
  content: "";
  position: absolute;
  width: 200px;
  height: 200px;
  background: radial-gradient(circle, rgba(var(--sb-orange-rgb), 0.04) 0%, rgba(var(--sb-black-rgb), 0) 70%);
  bottom: -80px;
  left: -50px;
  pointer-events: none;
}

.sb-glass-card-pdm-critical {
  background: linear-gradient(135deg, var(--sb-danger-bg) 0%, var(--sb-danger-bg-light) 100%) !important;
  border: 1px solid rgba(var(--sb-danger-rgb), 0.25) !important;
  box-shadow: 0 8px 32px 0 rgba(var(--sb-danger-rgb), 0.08) !important;
  color: var(--sb-text-main) !important;
}
.sb-glass-card-pdm-critical::before {
  content: "";
  position: absolute;
  width: 300px;
  height: 300px;
  background: radial-gradient(circle, rgba(var(--sb-danger-rgb), 0.08) 0%, rgba(var(--sb-black-rgb), 0) 70%);
  top: -100px;
  right: -50px;
  pointer-events: none;
}
.sb-glass-card-pdm-critical::after {
  content: "";
  position: absolute;
  width: 200px;
  height: 200px;
  background: radial-gradient(circle, rgba(var(--sb-danger-rgb), 0.04) 0%, rgba(var(--sb-black-rgb), 0) 70%);
  bottom: -80px;
  left: -50px;
  pointer-events: none;
}

.sb-glass-card-pdm-na {
  background: linear-gradient(135deg, var(--sb-border-light) 0%, var(--sb-neutral-bg-light) 100%) !important;
  border: 1px solid rgba(var(--sb-gray-rgb), 0.2) !important;
  box-shadow: 0 8px 32px 0 rgba(var(--sb-gray-rgb), 0.05) !important;
  color: var(--sb-text-main) !important;
  position: relative;
}
.sb-glass-card-pdm-na::before {
  content: "";
  position: absolute;
  width: 300px;
  height: 300px;
  background: radial-gradient(circle, rgba(var(--sb-gray-rgb), 0.08) 0%, rgba(var(--sb-black-rgb), 0) 70%);
  top: -100px;
  right: -50px;
  pointer-events: none;
}
.sb-glass-card-pdm-na::after {
  content: "";
  position: absolute;
  width: 200px;
  height: 200px;
  background: radial-gradient(circle, rgba(var(--sb-gray-rgb), 0.04) 0%, rgba(var(--sb-black-rgb), 0) 70%);
  bottom: -80px;
  left: -50px;
  pointer-events: none;
}
/* SuperBox Design System: Badges & Pills */

.sb-badge {
  display: inline-flex;
  align-items: center;
  padding: 0.25rem 0.6rem;
  border-radius: var(--sb-radius-sm);
  font-size: 0.75rem;
  font-weight: 700;
  line-height: 1;
  text-transform: uppercase;
  letter-spacing: 0.02em;
}

.sb-pill {
  display: inline-flex;
  align-items: center;
  padding: 0.35rem 0.85rem;
  border-radius: var(--sb-radius-full);
  font-size: 0.75rem;
  font-weight: 700;
  gap: 0.5rem;
}

.sb-pill .dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background-color: currentColor;
}

/* Status Variations */
.sb-status-active {
  background-color: var(--sb-success-bg);
  color: var(--sb-success);
}
.sb-status-active .dot { background-color: var(--sb-success); }

.sb-status-inactive {
  background-color: var(--sb-border-light);
  color: var(--sb-text-muted);
}
.sb-status-inactive .dot { background-color: var(--sb-text-muted); }

.sb-status-pending {
  background-color: var(--sb-warning-bg);
  color: var(--sb-warning);
}
.sb-status-pending .dot { background-color: var(--sb-warning); }

.sb-status-error {
  background-color: var(--sb-danger-bg);
  color: var(--sb-danger);
}
.sb-status-error .dot { background-color: var(--sb-danger); }

/* Pill Variations (Success/Danger/Warning/Info) */
.sb-pill-success { background-color: var(--sb-success-bg); color: var(--sb-success); }
.sb-pill-danger { background-color: var(--sb-danger-bg); color: var(--sb-danger); }
.sb-pill-warning { background-color: var(--sb-warning-bg); color: var(--sb-warning); }
.sb-pill-info { background-color: var(--sb-info-bg); color: var(--sb-info); }
.sb-pill-secondary { background-color: var(--sb-border-light); color: var(--sb-text-muted); }

.sb-pill-warning .dot,
.sb-pill-info .dot {
  display: none;
}

/* Technical Parameter Badges (Compact) */
.sb-badge-compact {
  font-family: var(--sb-font-mono);
  font-size: 0.65rem;
  padding: 1px 5px;
  border-radius: 6px;
  border: 1px solid var(--sb-border);
  background: white;
}

.sb-badge-light {
  background-color: rgba(var(--sb-primary-rgb), 0.05);
  color: var(--sb-primary-text);
  padding: 1px 4px;
  border-radius: 4px;
  border: none;
}

.sb-pill i { font-size: 0.5rem; }

.sb-spinner-spin {
  display: inline-block;
  animation: sb-spin 1s linear infinite;
  font-size: 0.85rem !important;
}

.sb-badge-voltage { background-color: var(--sb-primary-light); color: var(--sb-primary-text); border-color: var(--sb-primary-light-border); }
.sb-badge-current { background-color: var(--sb-warning-bg); color: var(--sb-warning); border-color: var(--sb-warning-light-border); }
.sb-badge-power { background-color: var(--sb-success-bg); color: var(--sb-success); border-color: var(--sb-success-light-border); }
.sb-badge-temp { background-color: var(--sb-danger-bg); color: var(--sb-danger); border-color: var(--sb-danger-light-border); }
.sb-badge-humidity { background-color: var(--sb-info-bg); color: var(--sb-info); border-color: var(--sb-info-light-border); }
.sb-badge-vibration { background-color: var(--sb-secondary-light); color: var(--sb-secondary); border-color: var(--sb-secondary-light-border); }
/* Advanced Diagnostics & Power Quality */
.sb-badge-pf { background-color: var(--sb-pf-bg); color: var(--sb-pf); border-color: var(--sb-pf-border); } /* Teal for Power Factor */
.sb-badge-kurtosis { background-color: var(--sb-kurtosis-bg); color: var(--sb-kurtosis); border-color: var(--sb-kurtosis-border); } /* Pink for Kurtosis */
.sb-badge-crest { background-color: var(--sb-crest-bg); color: var(--sb-crest); border-color: var(--sb-crest-border); } /* Purple for Crest Factor */

/* Machine Operational Logic States */
.sb-badge-state-active { background-color: var(--sb-state-active-bg); color: var(--sb-state-active); border-color: var(--sb-state-active-border); } /* Emerald for Active/Running State rule */
.sb-badge-state-idle { background-color: var(--sb-state-idle-bg); color: var(--sb-state-idle); border-color: var(--sb-state-idle-border); } /* Amber/Yellow for Idle/Waiting State rule */
.sb-badge-state-stopped { background-color: var(--sb-state-stopped-bg); color: var(--sb-state-stopped); border-color: var(--sb-state-stopped-border); } /* Gray/Slate for Stopped/Off State rule */

/* Pricing & Tariff Logic */
.sb-badge-tariff { background-color: var(--sb-tariff-bg); color: var(--sb-tariff); border-color: var(--sb-tariff-border); } /* Blue for Tariff */

/* Premium Chips (Interactive Selection) */
.sb-chip-group {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sb-sp-sm);
}

.sb-chip {
  display: inline-flex;
  align-items: center;
  padding: 0.5rem 1rem;
  border-radius: var(--sb-radius-md);
  background: white;
  border: 1px solid var(--sb-border-light);
  font-size: var(--sb-font-sm);
  font-weight: 600;
  cursor: pointer;
  transition: all var(--sb-transition-base);
  color: var(--sb-text-muted);
}

.sb-chip:hover {
  border-color: var(--sb-primary-light);
  color: var(--sb-primary-text);
  transform: translateY(-1px);
}

.sb-chip.active {
  background: var(--sb-primary);
  border-color: var(--sb-primary);
  color: white;
  box-shadow: var(--sb-shadow-md);
}

.sb-chip-discount {
  font-size: 0.65rem;
  padding: 1px 6px;
  background: var(--sb-success);
  color: white;
  border-radius: 4px;
  margin-left: 0.5rem;
}

/* Predictive Maintenance Status Badges */
.sb-badge-pdm-normal {
  background-color: rgba(var(--sb-emerald-rgb), 0.15) !important;
  color: var(--sb-emerald) !important;
  border: 1px solid rgba(var(--sb-emerald-rgb), 0.3) !important;
}
.sb-badge-pdm-warning_early {
  background-color: rgba(var(--sb-amber-rgb), 0.15) !important;
  color: var(--sb-amber) !important;
  border: 1px solid rgba(var(--sb-amber-rgb), 0.3) !important;
}
.sb-badge-pdm-warning_active {
  background-color: rgba(var(--sb-orange-rgb), 0.15) !important;
  color: var(--sb-orange) !important;
  border: 1px solid rgba(var(--sb-orange-rgb), 0.3) !important;
}
.sb-badge-pdm-critical {
  background-color: rgba(var(--sb-red-rgb), 0.15) !important;
  color: var(--sb-red) !important;
  border: 1px solid rgba(var(--sb-red-rgb), 0.3) !important;
}

.sb-badge-pdm-na {
  background-color: rgba(var(--sb-gray-rgb), 0.15) !important;
  color: var(--sb-gray) !important;
  border: 1px solid rgba(var(--sb-gray-rgb), 0.3) !important;
}
/* SuperBox Design System: Tables */

.sb-table-container {
  overflow-x: auto;
  padding-bottom: var(--sb-sp-sm);
  scrollbar-width: none; /* Firefox */
  -ms-overflow-style: none; /* IE/Edge */
}

.sb-table-container::-webkit-scrollbar {
  height: 5px;
  display: none;
}

.sb-table-container:hover {
  scrollbar-width: thin;
}

.sb-table-container:hover::-webkit-scrollbar {
  display: block;
}

.sb-table-container::-webkit-scrollbar-track {
  background: transparent;
}

.sb-table-container::-webkit-scrollbar-thumb {
  background: rgba(var(--sb-black-rgb), 0.1);
  border-radius: 10px;
}

.sb-table-container:hover::-webkit-scrollbar-thumb {
  background: rgba(var(--sb-black-rgb), 0.2);
}

.sb-table {
  width: 100%;
  border-collapse: separate;
  border-spacing: 0 var(--sb-sp-sm);
}

.sb-table th {
  padding: var(--sb-sp-sm) var(--sb-sp-md);
  text-align: left;
  font-size: 0.75rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--sb-text-muted);
  border: none;
}

.sb-table tr {
  background-color: var(--sb-bg-card);
  transition: all var(--sb-transition-fast);
  box-shadow: 0 2px 8px rgba(var(--sb-black-rgb), 0.02);
}

.sb-table tr:hover {
  transform: translateY(-2px);
  box-shadow: var(--sb-shadow-md);
}

.sb-table td {
  padding: var(--sb-sp-md);
  border: none;
  vertical-align: middle;
}

/* Rounding corners of rows */
.sb-table tr td:first-child {
  border-top-left-radius: var(--sb-radius-md);
  border-bottom-left-radius: var(--sb-radius-md);
}

.sb-table tr td:last-child {
  border-top-right-radius: var(--sb-radius-md);
  border-bottom-right-radius: var(--sb-radius-md);
}

/* Row states */
.sb-table tr.inactive {
  opacity: 0.6;
  filter: grayscale(0.5);
}

.sb-table tr.inactive:hover {
  opacity: 1;
  filter: grayscale(0);
}
/* SuperBox Design System: Forms */

.sb-form-label {
  font-size: var(--sb-font-xs);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--sb-text-muted);
  margin-bottom: var(--sb-sp-xs);
}

.sb-input,
.sb-select {
  display: block;
  width: 100%;
  padding: var(--sb-sp-sm) var(--sb-sp-md);
  font-size: var(--sb-font-sm);
  font-weight: 400;
  line-height: 1.5;
  color: var(--sb-text-main);
  background-color: var(--sb-bg-main);
  background-clip: padding-box;
  border: 1px solid transparent;
  border-radius: var(--sb-radius-md);
  transition: all var(--sb-transition-fast);
}

.sb-input:focus,
.sb-select:focus {
  background-color: white;
  border-color: var(--sb-color-primary-dark);
  outline: 0;
  box-shadow: var(--sb-focus-ring-shadow);
}

.sb-input::placeholder {
  color: var(--sb-text-light);
  opacity: 0.7;
}

/* Select Specifics */
.sb-select {
  appearance: none;
  background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3e%3cpath fill='none' stroke='%23343a40' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='m2 5 6 6 6-6'/%3e%3c/svg%3e");
  background-repeat: no-repeat;
  background-position: right var(--sb-sp-md) center;
  background-size: 16px 12px;
  text-overflow: ellipsis;
  white-space: nowrap;
  overflow: hidden;
  padding-right: 2.2rem !important;
}

/* Input Group */
.sb-input-group {
  position: relative;
  display: flex;
  flex-wrap: nowrap;
  align-items: stretch;
  width: 100%;
}

.sb-input-group .sb-input {
  flex: 1 1 auto;
  width: 1%;
  min-width: 0;
}

.sb-input-group-text {
  display: flex;
  align-items: center;
  padding: var(--sb-sp-sm) var(--sb-sp-md);
  font-size: var(--sb-font-sm);
  font-weight: 700;
  color: var(--sb-text-muted);
  background-color: var(--sb-bg-main);
  border-left: 1px solid var(--sb-border-light);
}

/* Radio Button Groups (Toggle style) */
.sb-radio-toggle {
  display: flex;
  background: var(--sb-bg-main);
  padding: 4px;
  border-radius: var(--sb-radius-lg);
  gap: 4px;
}

.sb-radio-toggle input[type="radio"] {
  display: none;
}

.sb-radio-toggle label {
  flex: 1;
  text-align: center;
  padding: var(--sb-sp-sm) var(--sb-sp-md);
  border-radius: var(--sb-radius-md);
  cursor: pointer;
  font-weight: 700;
  font-size: var(--sb-font-xs);
  color: var(--sb-text-muted);
  transition: all var(--sb-transition-fast);
}

.sb-radio-toggle input[type="radio"]:checked + label {
  background: white;
  color: var(--sb-primary);
  box-shadow: var(--sb-shadow-sm);
}

/* Error States */
.sb-input.is-invalid,
.sb-select.is-invalid {
  border-color: var(--sb-danger) !important;
  background-color: var(--sb-danger-bg) !important;
}

/* Handle invalid inputs inside input groups to prevent double borders and inconsistent colors */
.sb-input-group:has(.is-invalid) {
  border-color: var(--sb-danger) !important;
}

.sb-input-group:has(.is-invalid) .sb-input-group-text {
  border-left-color: var(--sb-danger) !important;
}

.sb-input-group .sb-input.is-invalid {
  border-color: transparent !important;
}

.sb-input.is-invalid:focus,
.sb-select.is-invalid:focus {
  background-color: white !important;
  border-color: var(--sb-danger) !important;
  box-shadow: 0 0 0 0.25rem rgba(var(--sb-danger-rgb), 0.1) !important;
}

/* Group focus state when child is invalid */
.sb-input-group:has(.is-invalid:focus) {
  border-color: var(--sb-danger) !important;
  box-shadow: 0 0 0 0.25rem rgba(var(--sb-danger-rgb), 0.1) !important;
}

.sb-error-message {
  font-size: var(--sb-font-xs);
  font-weight: 500;
  color: var(--sb-danger);
  margin-top: var(--sb-sp-xs);
  display: flex;
  align-items: center;
  gap: 0.25rem;
}

/* Responsive Report Filters */
.sb-report-filter-select {
  width: 100% !important;
  min-width: 0 !important;
  max-width: none !important;
}

.sb-report-date-field {
  flex: 1 !important;
  min-width: 0 !important;
  width: 100% !important;
}

.sb-report-date-group {
  width: 100% !important;
}

@media (min-width: 576px) {
  .sb-report-filter-select {
    width: auto !important;
    min-width: 160px !important;
    max-width: 180px !important;
  }
  .sb-report-date-field {
    flex: none !important;
    width: 135px !important;
  }
  .sb-report-date-group {
    width: auto !important;
    flex-shrink: 0 !important;
  }
}
/* SuperBox Design System: Navigation & Menus */

/* Global Navbar Styling (Glassmorphism) */
.sb-navbar {
  background: rgba(var(--sb-dark-nav-bg-rgb), 0.85) !important;
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border-bottom: 1px solid rgba(var(--sb-white-rgb), 0.08);
  transition: transform 0.3s ease-in-out, background 0.3s ease;
  position: sticky;
  top: 0;
  z-index: 1050;
  padding: 0.5rem 0;
}

.sb-navbar.navbar--hidden {
  transform: translateY(-100%);
}

.sb-nav-link {
  font-weight: 600;
  color: rgba(var(--sb-white-rgb), 0.6) !important;
  transition: all var(--sb-transition-fast);
  position: relative;
  font-size: var(--sb-font-sm);
  padding: 0.35rem 0.75rem;
  border-radius: var(--sb-radius-md);
}

.sb-nav-link:hover {
  color: var(--sb-dark-text) !important;
  background: rgba(var(--sb-white-rgb), 0.1) !important;
}

.sb-nav-link.active {
  color: var(--sb-dark-text) !important;
}

.sb-nav-link.active span {
  position: relative;
}

.sb-nav-link.active span::after {
  content: "";
  position: absolute;
  bottom: -6px;
  left: 50%;
  transform: translateX(-50%);
  width: 24px;
  height: 3px;
  background: var(--sb-primary);
  border-radius: var(--sb-radius-full);
  box-shadow: 0 0 10px rgba(var(--sb-primary-rgb), 0.6);
}

/* Premium Dropdown Menu */
.sb-dropdown-menu {
  background: rgba(var(--sb-dark-dropdown-bg-rgb), 0.95) !important;
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border: 1px solid rgba(var(--sb-white-rgb), 0.1) !important;
  border-radius: var(--sb-radius-lg) !important;
  box-shadow: 0 15px 35px rgba(var(--sb-black-rgb), 0.4) !important;
  padding: var(--sb-sp-sm) 0;
  min-width: 200px;

  /* Transition-delay to support smooth, flicker-free hover interaction */
  display: block !important;
  visibility: hidden;
  opacity: 0;
  margin-top: 12px;
  transition: opacity 0.15s cubic-bezier(0.4, 0, 0.2, 1), margin-top 0.15s cubic-bezier(0.4, 0, 0.2, 1), visibility 0.15s cubic-bezier(0.4, 0, 0.2, 1);
  transition-delay: 0.15s;
}

/* Dropdown Active/Show State (Bootstrap JS toggle support) & Hover Highlight */
.sb-nav-link.show {
  color: var(--sb-dark-text) !important;
  background: rgba(var(--sb-white-rgb), 0.12) !important;
}

.sb-dropdown-menu.show {
  visibility: visible !important;
  opacity: 1 !important;
  margin-top: 0 !important;
  transition-delay: 0s !important;
}

@media (min-width: 992px) {
  /* Hover to Open Dropdowns instantly */
  .nav-item.dropdown:hover > .sb-dropdown-menu {
    visibility: visible;
    opacity: 1;
    margin-top: 0;
    transition-delay: 0s;
  }
  
  /* Keep parent nav-link highlighted when menu is hovered/open */
  .nav-item.dropdown:hover > .sb-nav-link {
    color: var(--sb-dark-text) !important;
    background: rgba(var(--sb-white-rgb), 0.12) !important;
  }
}

/* Invisible bridge pseudo-element for extra safety */
.sb-dropdown-menu::before {
  content: "";
  position: absolute;
  top: -20px;
  left: 0;
  right: 0;
  height: 20px;
  background: transparent;
  z-index: -1;
}

.sb-dropdown-lg { min-width: 280px; }
.sb-dropdown-profile { min-width: 250px; }

/* Static alignment fallback for hover-to-open (when Popper is not initialized) */
.sb-dropdown-menu.dropdown-menu-end {
  right: 0 !important;
  left: auto !important;
}

.sb-dropdown-item {
  border-radius: var(--sb-radius-md) !important;
  color: rgba(var(--sb-white-rgb), 0.75) !important;
  padding: var(--sb-sp-sm) var(--sb-sp-md) !important;
  transition: all var(--sb-transition-fast);
}

.sb-dropdown-item:hover {
  background: rgba(var(--sb-white-rgb), 0.12) !important;
  color: var(--sb-dark-text) !important;
}

.sb-dropdown-item .text-muted {
  color: rgba(var(--sb-white-rgb), 0.1) !important;
  transition: color var(--sb-transition-fast);
}

.sb-dropdown-item:hover .text-muted {
  color: rgba(var(--sb-white-rgb), 0.8) !important;
}

.sb-dropdown-item.text-sb-danger:hover {
  background: rgba(var(--sb-danger-alt-rgb), 0.15) !important;
  color: var(--sb-danger-light) !important;
}

/* Vertical / Settings Sidebar Nav */
.sb-settings-nav {
  display: flex;
  flex-direction: column;
  gap: var(--sb-sp-xs);
}

.sb-settings-nav-link {
  display: flex;
  align-items: center;
  gap: var(--sb-sp-md);
  padding: var(--sb-sp-sm) var(--sb-sp-md);
  color: var(--sb-text-muted) !important;
  font-weight: 600;
  border-radius: var(--sb-radius-md);
  transition: all var(--sb-transition-base);
  text-decoration: none;
  border: none;
  background: transparent;
  width: 100%;
  text-align: left;
}

.sb-settings-nav-link:hover {
  background: var(--sb-border-light);
  color: var(--sb-text-main) !important;
  transform: translateX(4px);
}

.sb-settings-nav-link.active {
  background: var(--sb-primary) !important;
  color: var(--sb-dark-text) !important;
  box-shadow: var(--sb-shadow-primary);
}

.sb-settings-nav-link .sb-nav-subtitle {
  display: block;
  font-size: 0.65rem;
  font-weight: 400;
  opacity: 0.8;
  margin-top: 2px;
}

.sb-settings-nav-link.active .sb-nav-subtitle {
  color: rgba(var(--sb-white-rgb), 0.8);
}

@keyframes sbDropdownFadeIn {
  from { opacity: 0; transform: translateY(12px) scale(0.95); }
  to { opacity: 1; transform: translateY(0) scale(1); }
}

@keyframes sbFadeInUp {
  from { opacity: 0; transform: translateY(10px); }
  to { opacity: 1; transform: translateY(0); }
}

/* Custom Navigation Helpers */
.cursor-pointer { cursor: pointer; }
.hover-text-white { transition: color var(--sb-transition-fast); }
.hover-text-white:hover { color: var(--sb-dark-text) !important; }

/* Profile Letter Avatar */
.sb-nav-avatar {
  transition: transform var(--sb-transition-fast), box-shadow var(--sb-transition-fast);
}
.sb-nav-avatar:hover {
  transform: scale(1.05);
  box-shadow: var(--sb-shadow-md);
}

/* Cart & Notification Dropdown Menu */
.sb-cart-dropdown,
.sb-notification-dropdown {
  width: 400px;
  max-width: calc(100vw - 24px);
  border-radius: var(--sb-radius-lg) !important;
  z-index: 1050;
  margin-top: 8px;
  background: rgba(var(--sb-dark-dropdown-bg-rgb), 0.95) !important;
  backdrop-filter: blur(12px) !important;
  -webkit-backdrop-filter: blur(12px) !important;
  border: 1px solid rgba(var(--sb-white-rgb), 0.1) !important;
  box-shadow: 0 15px 35px rgba(var(--sb-black-rgb), 0.4) !important;
}

@media (max-width: 575.98px) {
  #mobile-cart-dropdown-container,
  #mobile-notification-dropdown-container {
    position: static !important;
  }
  
  .sb-cart-dropdown,
  .sb-notification-dropdown {
    left: 12px !important;
    right: 12px !important;
    width: auto !important;
    max-width: none !important;
    transform: none !important;
    top: 100% !important;
    margin-top: 8px !important;
  }
}

/* Mobile Navigation Dropdown Fix */
@media (max-width: 991.98px) {
  .sb-dropdown-menu {
    position: static !important;
    display: none !important;
    visibility: visible !important;
    opacity: 1 !important;
    background: transparent !important;
    border: none !important;
    box-shadow: none !important;
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
    padding-left: 1rem !important;
    width: 100% !important;
    min-width: 0 !important;
    margin-top: 0 !important;
    transform: none !important;
    transition: none !important;
  }

  .sb-dropdown-menu.show {
    display: block !important;
  }

  .sb-dropdown-item {
    background: transparent !important;
    padding: var(--sb-sp-sm) var(--sb-sp-md) !important;
  }
  
  .sb-dropdown-item:hover {
    background: rgba(var(--sb-white-rgb), 0.08) !important;
  }
}

/* Responsive Cart Item Name */
.sb-cart-item-name {
  max-width: 180px;
}
@media (max-width: 400px) {
  .sb-cart-item-name {
    max-width: 120px;
  }
}

/* Notification Nav Link & Badge */
.sb-notification-nav-link {
  color: rgba(var(--sb-white-rgb), 0.7);
  transition: color var(--sb-transition-fast);
}
.sb-notification-nav-link:hover {
  color: var(--sb-dark-text);
}
.sb-notification-nav-badge {
  font-size: 0.55rem;
  padding: 0.15rem 0.3rem;
  z-index: 10;
}

/* Dropdown Content & Elements */
.sb-notification-dropdown-badge {
  font-size: var(--sb-font-sm);
}
.sb-notification-mark-all-btn {
  font-size: var(--sb-font-sm);
  color: var(--sb-primary-text) !important;
}
.sb-notification-mark-all-btn:hover {
  color: var(--sb-primary-light) !important;
}
.sb-notification-list {
  max-height: 250px;
  overflow-y: auto;
}
.sb-notification-footer-btn {
  font-size: var(--sb-font-sm) !important;
  color: rgba(var(--sb-white-rgb), 0.5) !important;
  transition: color var(--sb-transition-fast) !important;
  text-decoration: none !important;
}
.sb-notification-footer-btn:hover {
  color: var(--sb-dark-text) !important;
}

/* Notification Item Details */
.sb-notification-icon-box {
  width: 28px;
  height: 28px;
  flex-shrink: 0;
  margin-top: 2px;
}
.sb-notification-icon {
  font-size: 0.8rem;
}
.sb-notification-text-container {
  line-height: 1.25;
}
.sb-notification-title {
  font-size: 0.8rem;
}
.sb-notification-message {
  font-size: 0.7rem;
}
.sb-notification-time {
  font-size: 0.6rem;
}
.sb-notification-check-icon {
  font-size: 1rem;
}


/* SuperBox Design System: Layout Components */

/* Page Header */
.sb-page-header {
  margin-bottom: var(--sb-sp-xl);
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
}

.sb-page-header h1 {
  font-size: var(--sb-font-3xl);
  font-weight: 800;
  color: var(--sb-text-main);
  margin-bottom: 2px;
  display: flex;
  align-items: center;
  gap: var(--sb-sp-sm);
}

.sb-page-subtitle {
  font-size: var(--sb-font-sm);
  color: var(--sb-text-muted);
  margin-bottom: 0;
}

.sb-breadcrumb {
  display: flex;
  flex-wrap: wrap;
  padding: 0;
  margin-bottom: var(--sb-sp-xs);
  list-style: none;
}

.sb-breadcrumb-item {
  font-size: var(--sb-font-xs);
  color: var(--sb-text-muted);
}

.sb-breadcrumb-item + .sb-breadcrumb-item::before {
  content: "/";
  padding: 0 var(--sb-sp-xs);
  color: var(--sb-text-light);
}

.sb-breadcrumb-item a {
  color: inherit;
  text-decoration: none;
}

.sb-breadcrumb-item.active {
  color: var(--sb-text-light);
}

.sb-icon-box {
  width: 48px;
  height: 48px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: var(--sb-radius-md);
  font-size: 1.25rem;
  flex-shrink: 0;
}

.sb-icon-box-primary { background: var(--sb-primary-light); color: var(--sb-primary); }
.sb-icon-box-success { background: var(--sb-success-bg); color: var(--sb-success); }
.sb-icon-box-warning { background: var(--sb-warning-bg); color: var(--sb-warning); }
.sb-icon-box-danger { background: var(--sb-danger-bg); color: var(--sb-danger); }
.sb-icon-box-info { background: var(--sb-info-bg); color: var(--sb-info); }

/* Action Group (Common for table actions) */
.sb-action-group {
  display: inline-flex;
  gap: 4px;
  padding: 2px;
  background: var(--sb-border-light);
  border: 1px solid var(--sb-border-light);
  border-radius: var(--sb-radius-lg);
  box-shadow: var(--sb-shadow-sm);
}

/* Section Header */
.sb-section-header {
  padding-bottom: var(--sb-sp-md);
  margin-bottom: var(--sb-sp-md);
  border-bottom: 1px solid var(--sb-border-light);
}

.sb-section-header h5 {
  font-size: var(--sb-font-xs);
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--sb-text-main);
  margin-bottom: 0;
}

/* Profile Banner */
/* Profile Banner Premium */
.sb-profile-banner-premium {
  background: linear-gradient(135deg, var(--sb-primary) 0%, var(--sb-primary-dark) 50%, var(--sb-secondary) 100%);
  background-size: 200% 200%;
  animation: meshGradient 10s ease infinite;
  padding: var(--sb-sp-2xl) var(--sb-sp-xl);
  text-align: center;
  position: relative;
  overflow: hidden;
}

@keyframes meshGradient {
  0% { background-position: 0% 50%; }
  50% { background-position: 100% 50%; }
  100% { background-position: 0% 50%; }
}

.sb-profile-banner-premium::before {
  content: "";
  position: absolute;
  top: 0; left: 0; right: 0; bottom: 0;
  background: url("data:image/svg+xml,%3Csvg width='100' height='100' viewBox='0 0 100 100' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M11 18c3.866 0 7-3.134 7-7s-3.134-7-7-7-7 3.134-7 7 3.134 7 7 7zm48 25c3.866 0 7-3.134 7-7s-3.134-7-7-7-7 3.134-7 7 3.134 7 7 7zm-43-7c1.657 0 3-1.343 3-3s-1.343-3-3-3-3 1.343-3 3 1.343 3 3 3zm63 31c1.657 0 3-1.343 3-3s-1.343-3-3-3-3 1.343-3 3 1.343 3 3 3zM34 90c1.657 0 3-1.343 3-3s-1.343-3-3-3-3 1.343-3 3 1.343 3 3 3zm56-76c1.105 0 2-.895 2-2s-.895-2-2-2-2 .895-2 2 .895 2 2 2zM12 86c1.105 0 2-.895 2-2s-.895-2-2-2-2 .895-2 2 .895 2 2 2zm66 3c1.105 0 2-.895 2-2s-.895-2-2-2-2 .895-2 2 .895 2 2 2zm-46-45c1.105 0 2-.895 2-2s-.895-2-2-2-2 .895-2 2 .895 2 2 2zm20-17c.552 0 1-.448 1-1s-.448-1-1-1-1 .448-1 1 .448 1 1 1zm5-40c.552 0 1-.448 1-1s-.448-1-1-1-1 .448-1 1 .448 1 1 1zM31 35c.552 0 1-.448 1-1s-.448-1-1-1-1 .448-1 1 .448 1 1 1zm50 64c.552 0 1-.448 1-1s-.448-1-1-1-1 .448-1 1 .448 1 1 1zm13-10c.552 0 1-.448 1-1s-.448-1-1-1-1 .448-1 1 .448 1 1 1zM70 34c.552 0 1-.448 1-1s-.448-1-1-1-1 .448-1 1 .448 1 1 1zM30 5c.552 0 1-.448 1-1s-.448-1-1-1-1 .448-1 1 .448 1 1 1zm-7 49c.552 0 1-.448 1-1s-.448-1-1-1-1 .448-1 1 .448 1 1 1zM50 71c.552 0 1-.448 1-1s-.448-1-1-1-1 .448-1 1 .448 1 1 1zM8 38c.552 0 1-.448 1-1s-.448-1-1-1-1 .448-1 1 .448 1 1 1z' fill='%23ffffff' fill-opacity='0.05' fill-rule='evenodd'/%3E%3C/svg%3E");
  opacity: 0.4;
}

.sb-profile-banner-premium .avatar-container {
  position: relative;
  z-index: 2;
}

/* Integration & Credential Cards */
/* Integration & Credential Cards Premium */
.sb-integration-card {
  padding: var(--sb-sp-md);
  border-radius: var(--sb-radius-md);
  border: none;
  background: var(--sb-bg-card);
  display: flex;
  align-items: center;
  height: 100%;
  transition: all var(--sb-transition-base);
  box-shadow: 0 2px 4px rgba(var(--sb-black-rgb), 0.02);
}

.sb-integration-card:hover {
  transform: translateY(-3px);
  box-shadow: var(--sb-shadow-lg);
  border-color: var(--sb-primary);
}

.sb-integration-card-primary { border-left: 4px solid var(--sb-primary); }
.sb-integration-card-info { border-left: 4px solid var(--sb-info); }
.sb-integration-card-secondary { border-left: 4px solid var(--sb-secondary); }

.sb-credential-box {
  padding: var(--sb-sp-md);
  border-radius: var(--sb-radius-md);
  background: rgba(var(--sb-white-rgb), 0.6);
  backdrop-filter: blur(8px);
  border: 1px solid var(--sb-border-light);
  height: 100%;
  position: relative;
  transition: all var(--sb-transition-base);
}

.sb-credential-box:hover {
  background: white;
  box-shadow: var(--sb-shadow-md);
}

/* Icon Box Sizing */
.sb-icon-box-sm { width: 32px; height: 32px; font-size: 0.9rem; }
.sb-icon-box-md { width: 40px; height: 40px; font-size: 1.1rem; }
.sb-icon-box-lg { width: 48px; height: 48px; font-size: 1.25rem; }
.sb-icon-box-xl { width: 56px; height: 56px; font-size: 1.5rem; }
.sb-icon-box-avatar { width: 80px; height: 80px; font-size: 2rem; border-radius: 50% !important; }

/* Progress Bar */
.sb-progress-group {
  display: flex;
  align-items: center;
  background: var(--sb-light-bg);
  border-radius: var(--sb-radius-full);
  padding: var(--sb-sp-xs) var(--sb-sp-md);
  border: 1px solid var(--sb-border-light);
  box-shadow: var(--sb-shadow-sm);
}

.sb-progress-bar-container {
  width: 60px;
  height: 6px;
  background-color: var(--sb-bg-gray);
  border-radius: 10px;
  overflow: hidden;
  margin-right: var(--sb-sp-md);
}

.sb-progress-bar {
  height: 100%;
  transition: width 0.6s ease;
}

/* Glassmorphism Utility */
.sb-glass {
  background: rgba(var(--sb-white-rgb), 0.7);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border: 1px solid rgba(var(--sb-white-rgb), 0.2);
}

.sb-modal-content {
  border: none !important;
  border-radius: var(--sb-radius-xl) !important;
  box-shadow: 0 25px 50px -12px rgba(var(--sb-black-rgb), 0.5) !important;
  overflow: hidden;
  background: var(--sb-bg-card);
  width: 100%;
}

.sb-btn-close-static {
  position: static !important;
}

.sb-modal-backdrop {
  backdrop-filter: blur(8px);
  background-color: rgba(var(--sb-black-rgb), 0.4) !important;
}

/* Grafana Dashboard Components */
.sb-grafana-container {
  height: 700px;
  overflow: hidden;
  position: relative;
}

.sb-grafana-iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 125%;
  height: 125%;
  transform: scale(0.8);
  transform-origin: 0 0;
}

/* Live Chart Overlay */
.sb-chart-overlay {
  position: absolute;
  width: 100%;
  display: flex;
  justify-content: space-between;
  align-items: stretch;
  z-index: 10;
  top: 0;
  left: 0;
  pointer-events: none;
  height: 31px;
}

.sb-chart-overlay-badge {
  background: var(--sb-dark-bg);
  color: white;
  font-size: 0.65rem;
  display: flex;
  align-items: stretch;
  overflow: hidden;
  pointer-events: auto;
}

.sb-live-indicator {
  background: var(--sb-danger);
  padding: 0 var(--sb-sp-sm);
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 700;
  font-size: 0.55rem;
  min-width: 60px;
  border-radius: 50rem;
  margin: 4px;
}

.sb-live-clock {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-grow: 1;
  letter-spacing: 0.5px;
}

/* Modal Scroll Area */
.sb-modal-body-scroll {
  max-height: 70vh;
  overflow-y: auto;
}

/* Dynamic Form Toggles */
.sb-tariff-inputs {
  display: none !important;
}

.sb-tariff-inputs.active {
  display: flex !important;
}

.sb-d-none { display: none !important; }
.sb-d-block { display: block !important; }
.sb-d-flex { display: flex !important; }
.sb-gap-2 { gap: var(--sb-sp-sm) !important; }

/* Filter Bar */
.sb-filter-bar {
  background: white;
  padding: 10px 20px;
  border-radius: var(--sb-radius-xl);
  border: 1px solid var(--sb-border-light);
  box-shadow: var(--sb-shadow-sm);
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 15px;
  margin-bottom: var(--sb-sp-xl);
}

.sb-filter-group {
  display: flex;
  align-items: center;
  gap: 8px;
}

.sb-filter-label {
  font-size: var(--sb-font-xs);
  font-weight: 700;
  color: var(--sb-text-muted);
  text-transform: uppercase;
  letter-spacing: 0.5px;
  margin-bottom: 0;
  white-space: nowrap;
}

/* Page Container */
.sb-page-container {
  background: var(--sb-bg-main);
  min-height: 100vh;
}
/* Premium Card-List Table */
.sb-table-premium {
  border-collapse: separate !important;
  border-spacing: 0 12px !important;
  width: 100%;
}

.sb-table-premium tr {
  background-color: var(--sb-bg-card);
  box-shadow: var(--sb-shadow-soft);
  transition: all var(--sb-transition-base);
  border-radius: var(--sb-radius-lg);
}

.sb-table-premium tr:hover {
  transform: translateY(-3px) scale(1.005);
  box-shadow: var(--sb-shadow-lg);
}

.sb-table-premium td {
  border: none !important;
  padding: var(--sb-sp-sm) var(--sb-sp-md) !important;
}

.sb-table-premium td:first-child {
  border-top-left-radius: var(--sb-radius-lg);
  border-bottom-left-radius: var(--sb-radius-lg);
}

.sb-table-premium td:last-child {
  border-top-right-radius: var(--sb-radius-lg);
  border-bottom-right-radius: var(--sb-radius-lg);
}

/* Sticky Footer Layout */
html, body {
  height: 100%;
}

body {
  display: flex;
  flex-direction: column;
  min-height: 100vh;
}

main {
  flex: 1 0 auto;
}

.sb-footer {
  flex-shrink: 0;
}

/* SuperBox Design System: TOU Schedule Component */

.sb-schedule-container {
  background-color: var(--sb-bg-main);
  border-radius: var(--sb-radius-md);
  padding: var(--sb-sp-md);
  border: 1px solid var(--sb-border-light);
}

.sb-schedule-group {
  margin-bottom: var(--sb-sp-md);
}

.sb-schedule-group:last-child {
  margin-bottom: 0;
}

.sb-schedule-day-label {
  font-size: var(--sb-font-xs);
  font-weight: 800;
  color: var(--sb-primary);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  margin-right: var(--sb-sp-sm);
  white-space: nowrap;
}

.sb-schedule-divider {
  flex-grow: 1;
  border-bottom: 1px solid var(--sb-border-light);
  opacity: 0.5;
}

.sb-schedule-slot {
  display: flex;
  align-items: center;
  background-color: white;
  border-radius: var(--sb-radius-full);
  padding: 2px 10px;
  box-shadow: var(--sb-shadow-sm);
  border: 1px solid var(--sb-border-light);
  min-width: 110px;
  transition: all var(--sb-transition-base);
}

.sb-schedule-slot:hover {
  transform: translateY(-1px);
  box-shadow: var(--sb-shadow-md);
}

.sb-schedule-time {
  font-family: var(--sb-font-mono);
  font-size: var(--sb-font-xs);
  color: var(--sb-text-muted);
  margin-right: auto;
}

.sb-schedule-legend {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sb-sp-lg);
  padding-top: var(--sb-sp-md);
  margin-top: var(--sb-sp-md);
  border-top: 1px solid var(--sb-border-light);
}

.sb-schedule-legend-item {
  display: flex;
  align-items: center;
  gap: var(--sb-sp-sm);
}
/* SuperBox Design System: Alerts */

.sb-alert {
  padding: var(--sb-sp-lg);
  border-radius: var(--sb-radius-lg);
  border: 1px solid transparent;
  box-shadow: var(--sb-shadow-sm);
  position: relative;
  overflow: hidden;
}

.sb-alert-primary {
  background-color: var(--sb-primary-light);
  border-color: rgba(var(--sb-primary-rgb), 0.1);
  color: var(--sb-primary-text);
}

.sb-alert-success {
  background-color: var(--sb-success-bg);
  border-color: rgba(var(--sb-success-rgb), 0.1);
  color: var(--sb-success);
}

.sb-alert-warning {
  background-color: var(--sb-warning-bg);
  border-color: rgba(var(--sb-warning-rgb), 0.1);
  color: var(--sb-warning);
}

.sb-alert-danger {
  background-color: var(--sb-danger-bg);
  border-color: rgba(var(--sb-danger-rgb), 0.1);
  color: var(--sb-danger);
}

.sb-alert i {
  flex-shrink: 0;
}
/* SuperBox Design System: Utilities */

/* Spacing Helpers */
.m-sb-1 { margin: var(--sb-sp-xs) !important; }
.m-sb-2 { margin: var(--sb-sp-sm) !important; }
.m-sb-3 { margin: var(--sb-sp-md) !important; }
.m-sb-4 { margin: var(--sb-sp-lg) !important; }
.m-sb-5 { margin: var(--sb-sp-xl) !important; }

.p-sb-1 { padding: var(--sb-sp-xs) !important; }
.p-sb-2 { padding: var(--sb-sp-sm) !important; }
.p-sb-3 { padding: var(--sb-sp-md) !important; }
.p-sb-4 { padding: var(--sb-sp-lg) !important; }
.p-sb-5 { padding: var(--sb-sp-xl) !important; }

/* Typography */
.text-sb-primary { color: var(--sb-primary-text) !important; }
.text-sb-success { color: var(--sb-success) !important; }
.text-sb-warning { color: var(--sb-warning) !important; }
.text-sb-danger { color: var(--sb-danger) !important; }
.text-sb-muted { color: var(--sb-text-muted) !important; }

.bg-sb-primary { background-color: var(--sb-primary) !important; }
.bg-sb-success { background-color: var(--sb-success) !important; }
.bg-sb-warning { background-color: var(--sb-warning) !important; }
.bg-sb-danger { background-color: var(--sb-danger) !important; }

.fw-sb-bold { font-weight: 700 !important; }
.fw-sb-extra-bold { font-weight: 800 !important; }
.fw-sb-black { font-weight: 900 !important; }

.ls-sb-1 { letter-spacing: 0.05em; }
.ls-sb-2 { letter-spacing: 0.1em; }
.ls-sb-wide { letter-spacing: 0.15em; }

/* Interactive */
.hover-lift {
  transition: transform var(--sb-transition-base), box-shadow var(--sb-transition-base);
}

.hover-lift:hover {
  transform: translateY(-3px);
  box-shadow: var(--sb-shadow-lg) !important;
}

.transition-base { transition: all var(--sb-transition-base); }

/* Shadows */
.shadow-sb-soft { box-shadow: var(--sb-shadow-soft) !important; }
.shadow-sb-left { box-shadow: var(--sb-shadow-left) !important; }

/* Backdrop Blur */
.glass-blur {
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
}
/* SuperBox Design System: Confirmation Modal */

.sb-modal-overlay {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(var(--sb-black-rgb), 0.4);
  backdrop-filter: blur(8px);
  display: flex;
  justify-content: center;
  align-items: center;
  z-index: 9999;
  opacity: 0;
  transition: opacity var(--sb-transition-base);
}

.sb-modal-overlay.is-visible {
  opacity: 1;
}

.sb-confirmation-content {
  background: rgba(var(--sb-white-rgb), 0.95);
  backdrop-filter: blur(15px);
  border-radius: var(--sb-radius-lg);
  padding: var(--sb-sp-lg);
  max-width: 420px;
  width: 90%;
  box-shadow: var(--sb-shadow-lg);
  transform: translateY(20px);
  transition: transform var(--sb-transition-base);
  text-align: center;
  border: 1px solid rgba(var(--sb-white-rgb), 0.2);
  font-family: var(--sb-font-main);
}

.sb-modal-overlay.is-visible .sb-confirmation-content {
  transform: translateY(0);
}

.sb-modal-title {
  font-weight: 700;
  font-size: var(--sb-font-xl);
  margin-bottom: var(--sb-sp-sm);
  color: var(--sb-text-main);
}

.sb-modal-body {
  font-size: var(--sb-font-sm);
  color: var(--sb-text-muted);
  margin-bottom: var(--sb-sp-lg);
  line-height: 1.6;
}

.sb-modal-actions {
  display: flex;
  justify-content: center;
  gap: var(--sb-sp-md);
}

.sb-modal-actions .btn-sb {
  min-width: 110px;
}
html.dashboard-layout,
body.dashboard-layout {
    margin: 0;
    padding: 0;
    height: 100vh;
    width: 100vw;
    overflow: hidden;
    background: var(--sb-dark-bg);
}

.dashboard-wrapper {
    position: relative;
    width: 100%;
    height: 100%;
    overflow: hidden;
}

.dashboard-wrapper iframe {
    border: none;
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    display: block;
}

.toggle-blocker-right {
    position: absolute;
    top: 0;
    right: 0;
    width: 70px;
    height: 40px;
    background: var(--sb-dark-bg);
    z-index: 1000;
    pointer-events: auto;
}

.toggle-blocker-left {
    position: absolute;
    top: 0;
    left: 0;
    width: 320px;
    height: 40px;
    background: var(--sb-dark-bg);
    z-index: 1000;
    pointer-events: auto;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--sb-primary);
    font-family: var(--sb-font-main);
    font-weight: 700;
    font-size: 14px;
    letter-spacing: 1.5px;
    transition: all 0.3s ease;
}

.toggle-blocker-left:hover {
    color: var(--sb-dark-text);
    text-shadow: 0 0 10px var(--sb-primary);
    cursor: pointer;
}

/* Custom Time Picker Toolbar styles */
.sb-grafana-toolbar {
    height: 50px;
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0 20px;
    background: var(--sb-dark-bg); /* Grafana dark bg color */
    border-bottom: 1px solid var(--sb-grafana-border);
    color: var(--sb-grafana-text);
    font-family: var(--sb-font-main), sans-serif;
    z-index: 1001;
    box-sizing: border-box;
}

.sb-grafana-toolbar .logo-area a {
    color: var(--sb-primary);
    font-weight: 700;
    text-decoration: none;
    letter-spacing: 0.5px;
}

.sb-grafana-toolbar .logo-area a:hover {
    color: var(--sb-dark-text);
    text-shadow: 0 0 10px var(--sb-primary);
}

.sb-grafana-toolbar .toolbar-area {
    display: flex;
    align-items: center;
    gap: 10px;
}

.sb-grafana-toolbar .toolbar-label {
    font-size: 12px;
    color: var(--sb-grafana-muted);
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.sb-time-picker {
    display: flex;
    gap: 4px;
    background: var(--sb-dark-bg-darker); /* Darker bg for buttons group */
    padding: 4px;
    border-radius: 6px;
    border: 1px solid var(--sb-grafana-border);
}

.sb-time-btn {
    background: transparent;
    border: none;
    color: var(--sb-grafana-muted);
    padding: 4px 12px;
    font-size: 11px;
    font-weight: 600;
    border-radius: 4px;
    cursor: pointer;
    transition: all 0.2s ease;
}

.sb-time-btn:hover {
    color: var(--sb-dark-text);
    background: var(--sb-dark-bg-alt);
}

.sb-time-btn.active {
    color: var(--sb-dark-text);
    background: var(--sb-primary);
    box-shadow: 0 0 8px rgba(var(--sb-cyan-rgb), 0.4);
}

.sb-grafana-toolbar .profile-area {
    font-size: 12px;
    color: var(--sb-grafana-muted);
}

.sb-grafana-toolbar .user-badge {
    background: var(--sb-dark-surface-alt);
    padding: 4px 10px;
    border-radius: 4px;
    border: 1px solid var(--sb-grafana-border);
}

/* Full screen dashboard specific positioning */
.dashboard-custom-header {
    position: absolute;
    top: 0;
    left: 0;
}

/* Inside embedded device show card styling */
.device-dashboard-card {
    border-radius: 8px;
    overflow: hidden;
    border: 1px solid var(--sb-grafana-border);
}

/* Floating time picker on top-right next to blocker-right */
.dashboard-floating-timepicker {
    position: absolute;
    top: 4px;
    right: 76px;
    z-index: 1001;
}

/* Dark Time Picker Select */
.sb-dark-select {
    background-color: var(--sb-dark-bg) !important; /* Match Grafana top bar */
    color: var(--sb-grafana-text) !important;
    border: 1px solid var(--sb-grafana-border) !important;
    border-radius: 4px;
    padding: 4px 30px 4px 12px !important; /* Right padding for the clock icon */
    font-size: 12px;
    font-weight: 500;
    height: 32px;
    min-width: 180px;
    cursor: pointer;
    box-shadow: none !important;
    appearance: none;
    -webkit-appearance: none;
    -moz-appearance: none;
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='%239fa6b2'%3e%3cpath d='M16 8A8 8 0 1 1 0 8a8 8 0 0 1 16 0zM8 3.5a.5.5 0 0 0-1 0V9a.5.5 0 0 0 .252.434l3.5 2a.5.5 0 0 0 .496-.868L8 8.71V3.5z'/%3e%3c/svg%3e") !important;
    background-repeat: no-repeat !important;
    background-position: right 10px center !important;
    background-size: 13px 13px !important;
    transition: all 0.2s ease;
}

.sb-dark-select:hover {
    border-color: var(--sb-gray-600) !important;
}

.sb-dark-select:focus {
    border-color: var(--sb-primary) !important;
    outline: 0;
    box-shadow: 0 0 0 0.2rem rgba(var(--sb-cyan-rgb), 0.25) !important;
}

.sb-dark-select option {
    background-color: var(--sb-dark-bg);
    color: var(--sb-grafana-text);
    padding: 8px;
}

/* Report Hub Premium Styles */
.sb-card-glow {
  position: relative;
}

.sb-card-glow::before {
  content: "";
  position: absolute;
  top: 0; left: 0; right: 0; bottom: 0;
  border-radius: inherit;
  padding: 1px;
  background: linear-gradient(135deg, rgba(var(--sb-primary-rgb), 0.4) 0%, rgba(var(--sb-secondary-rgb), 0.4) 100%);
  -webkit-mask: linear-gradient(var(--sb-dark-text) 0 0) content-box, linear-gradient(var(--sb-dark-text) 0 0);
  -webkit-mask-composite: xor;
  mask-composite: exclude;
  pointer-events: none;
  opacity: 0;
  transition: opacity var(--sb-transition-base);
}

.sb-card-glow:hover::before {
  opacity: 1;
}

.sb-card-glow.primary::before {
  background: linear-gradient(135deg, rgba(var(--sb-primary-rgb), 0.5) 0%, rgba(var(--sb-chart-active-rgb), 0.2) 100%);
}

.sb-card-glow.success::before {
  background: linear-gradient(135deg, rgba(var(--sb-success-rgb), 0.5) 0%, rgba(var(--sb-state-active-rgb), 0.2) 100%);
}

.sb-card-glow.danger::before {
  background: linear-gradient(135deg, rgba(var(--sb-danger-rgb), 0.5) 0%, rgba(var(--sb-danger-alt-rgb), 0.2) 100%);
}

/* Glassmorphic Page Header */
.sb-header-glass {
  background: rgba(var(--sb-white-rgb), 0.6) !important;
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border: 1px solid rgba(var(--sb-white-rgb), 0.3);
  border-radius: var(--sb-radius-xl);
  padding: var(--sb-sp-md) var(--sb-sp-lg);
  box-shadow: 0 8px 32px 0 rgba(var(--sb-shadow-blue-rgb), 0.04);
  margin-bottom: var(--sb-sp-xl);
}

/* Custom canvas styling for Report Hub */
.sb-card canvas {
  filter: drop-shadow(0px 8px 16px rgba(var(--sb-black-rgb), 0.05));
}
/* =====================================================
   SuperBox Design System: Subscriptions
   ===================================================== */

/* ---- Plan selection cards ---- */
.sb-plan-card-label {
  cursor: pointer;
  display: block;
}

.sb-plan-card {
  background: var(--sb-bg-card);
  border-radius: var(--sb-radius-lg);
  border: 2px solid var(--sb-border-light);
  padding: var(--sb-sp-lg);
  transition: all var(--sb-transition-base);
  position: relative;
  overflow: hidden;
}

.sb-plan-card:hover {
  border-color: var(--sb-primary);
  box-shadow: var(--sb-shadow-md);
  transform: translateY(-2px);
}

.sb-plan-radio {
  display: none;
}

.sb-plan-radio:checked + .sb-plan-card {
  border-color: var(--sb-primary);
  background: var(--sb-bg-main);
  box-shadow: var(--sb-shadow-lg);
  transform: translateY(-3px);
}

.sb-plan-radio:checked + .sb-plan-card .sb-plan-check {
  opacity: 1;
  transform: scale(1);
}

/* Check mark circle */
.sb-plan-check {
  opacity: 0;
  position: absolute;
  top: 12px;
  right: 12px;
  width: 24px;
  height: 24px;
  background: var(--sb-primary);
  color: var(--sb-dark-text);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all var(--sb-transition-base);
  transform: scale(0.5);
  z-index: 2;
}

/* Plan badge (POPULAR / BEST VALUE) */
.sb-plan-badge {
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  font-size: 0.65rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  padding: 2px 12px;
  background: var(--sb-primary);
  color: var(--sb-dark-text);
  border-radius: 0 0 10px 10px;
  white-space: nowrap;
  z-index: 1;
}

/* Plan icon */
.sb-plan-icon {
  width: 44px;
  height: 44px;
  border-radius: 12px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.25rem;
  color: var(--sb-dark-text);
  box-shadow: var(--sb-shadow-sm);
}

/* Integration/Connectivity card in Subscription view */
.sb-integration-card {
  display: flex;
  align-items: center;
  padding: var(--sb-sp-md);
  border-radius: var(--sb-radius-md);
  background: var(--sb-bg-main);
  border: 1px solid var(--sb-border-light);
}

.sb-integration-card-primary { background: rgba(var(--sb-primary-rgb), 0.05); border-color: rgba(var(--sb-primary-rgb), 0.1); }
.sb-integration-card-info { background: rgba(var(--sb-info-rgb), 0.05); border-color: rgba(var(--sb-info-rgb), 0.1); }

/* Billing cycle selector labels */
.sb-billing-cycle-btn {
  border-radius: var(--sb-radius-md) !important;
  font-weight: 600;
  padding: var(--sb-sp-sm) var(--sb-sp-md);
}

/* Helper for disabled sections in checkout */
.sb-disabled-section {
  opacity: 0.5;
  pointer-events: none;
  filter: grayscale(0.5);
}

/* Custom dashed border for breakdown rows */
.border-dashed {
  border-bottom-style: dashed !important;
}
/* Pages styling using SuperBox tokens */

.sb-footer {
  background-color: rgb(var(--sb-dark-nav-bg-rgb)) !important;
  border-top: 1px solid rgba(var(--sb-white-rgb), 0.08);
  color: rgba(var(--sb-white-rgb), 0.75) !important;
}

.sb-footer .text-muted {
  color: rgba(var(--sb-white-rgb), 0.6) !important;
}

.sb-footer .footer-logo {
  font-size: var(--sb-font-lg);
  transition: opacity var(--sb-transition-fast);
}

.sb-footer .footer-logo:hover {
  opacity: 0.9;
}

.sb-footer .footer-link {
  color: rgba(var(--sb-white-rgb), 0.6) !important;
  font-weight: 600;
  transition: all var(--sb-transition-fast);
  padding: 0.25rem 0.5rem;
  border-radius: var(--sb-radius-sm);
}

.sb-footer .footer-link:hover {
  color: var(--sb-dark-text) !important;
  background: rgba(var(--sb-white-rgb), 0.08);
}

.sb-footer .text-white-25 {
  color: rgba(var(--sb-white-rgb), 0.25) !important;
  font-size: 0.8rem;
  pointer-events: none;
}

.sb-footer .btn-language-switcher {
  color: rgba(var(--sb-white-rgb), 0.8) !important;
  border-color: rgba(var(--sb-white-rgb), 0.12) !important;
  background: rgba(var(--sb-white-rgb), 0.04) !important;
  font-weight: 600;
  transition: all var(--sb-transition-fast);
}

.sb-footer .btn-language-switcher:hover {
  background-color: rgba(var(--sb-white-rgb), 0.12) !important;
  color: var(--sb-dark-text) !important;
  border-color: rgba(var(--sb-white-rgb), 0.25) !important;
  transform: translateY(-1px);
}

/* Landing Page Specifics - Light Theme */
.hero-section {
  padding: 80px 0 60px;
  background: radial-gradient(circle at 10% 20%, rgba(var(--sb-primary-rgb), 0.04) 0%, rgba(var(--sb-bg-main-rgb), 1) 90%);
  color: var(--sb-text-main);
}

.hero-title {
  font-weight: 800;
  letter-spacing: -0.5px;
  color: var(--sb-text-main);
}

.hero-subtitle {
  color: var(--sb-text-muted);
  font-size: 1.15rem;
  line-height: 1.6;
}

.pricing-card {
  transition: transform var(--sb-transition-base), box-shadow var(--sb-transition-base);
  border: 1px solid var(--sb-border);
  background-color: var(--sb-bg-card);
  color: var(--sb-text-main);
}

.pricing-card:hover {
  transform: translateY(-5px);
  box-shadow: var(--sb-shadow-lg) !important;
  border-color: var(--sb-primary);
}

.pricing-card.featured {
  border: 2px solid var(--sb-primary);
  position: relative;
}

.pricing-card.featured .badge-featured {
  position: absolute;
  top: -12px;
  left: 50%;
  transform: translateX(-50%);
  background-color: var(--sb-primary);
  color: var(--sb-dark-text);
  padding: 4px 12px;
  border-radius: var(--sb-radius-full);
  font-size: 0.75rem;
  font-weight: 600;
}

.feature-card {
  border: 1px solid var(--sb-border);
  background-color: var(--sb-bg-card);
  color: var(--sb-text-main);
  transition: transform var(--sb-transition-base);
}

.feature-card:hover {
  transform: translateY(-3px);
  border-color: var(--sb-primary);
}

.feature-icon-wrapper {
  width: 48px;
  height: 48px;
  border-radius: var(--sb-radius-md);
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: var(--sb-sp-md);
}

/* Mock Dashboard Chart */
.mock-dashboard {
  background-color: var(--sb-dark-bg);
  border: 1px solid var(--sb-dark-border);
  border-radius: var(--sb-radius-lg);
  padding: var(--sb-sp-lg);
  box-shadow: var(--sb-shadow-lg);
}

.mock-dashboard .text-muted {
  color: rgba(var(--sb-white-rgb), 0.65) !important;
}

.mock-chart-bar {
  height: 8px;
  border-radius: var(--sb-radius-full);
}

.mock-status-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  display: inline-block;
}

/* Documentation Styling */
.docs-sidebar {
  border-right: 1px solid var(--sb-border);
}

.docs-nav-link {
  color: var(--sb-text-muted);
  text-decoration: none;
  padding: var(--sb-sp-sm) var(--sb-sp-md);
  border-radius: var(--sb-radius-sm);
  display: block;
  transition: all var(--sb-transition-fast);
}

.docs-nav-link:hover {
  background-color: var(--sb-border-light);
  color: var(--sb-text-main);
}

.docs-nav-link.active {
  background-color: var(--sb-primary-light);
  color: var(--sb-primary-dark);
  font-weight: 600;
}

.docs-content table {
  width: 100%;
  margin-bottom: var(--sb-sp-lg);
  border-collapse: collapse;
}

.docs-content th, .docs-content td {
  padding: var(--sb-sp-sm) var(--sb-sp-md);
  border: 1px solid var(--sb-border);
}

.docs-content th {
  background-color: var(--sb-border-light);
}

.docs-content pre {
  background-color: var(--sb-dark-bg);
  color: var(--sb-dark-text);
  padding: var(--sb-sp-md);
  border-radius: var(--sb-radius-md);
  overflow-x: auto;
}

.docs-content code {
  font-family: var(--sb-font-mono);
  font-size: 0.9em;
}

/* Store Catalog Styling */
.sb-store-card {
  transition: transform var(--sb-transition-base), box-shadow var(--sb-transition-base);
}

.sb-store-card:hover {
  transform: translateY(-5px);
  box-shadow: 0 1rem 3rem rgba(0,0,0,.175) !important;
}

.sb-gradient-primary {
  background: linear-gradient(135deg, #4f46e5 0%, #3b82f6 100%) !important;
}

.sb-gradient-success {
  background: linear-gradient(135deg, #10b981 0%, #059669 100%) !important;
}

.sb-gradient-warning {
  background: linear-gradient(135deg, #f59e0b 0%, #d97706 100%) !important;
}

.sb-gradient-info {
  background: linear-gradient(135deg, #06b6d4 0%, #0891b2 100%) !important;
}
/* SuperBox Design System: Preloader and Loading states */

/* Global Screen Preloader Overlay */
.sb-preloader {
  position: fixed;
  top: 0;
  left: 0;
  width: 100vw;
  height: 100vh;
  background-color: rgba(var(--sb-bg-main-rgb), 0.7); /* Soft blurred overlay */
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 99999; /* Make sure it's above other elements like navbar and modals */
  opacity: 0;
  transition: opacity var(--sb-transition-base);
  pointer-events: none;

  /* Component variables routing through design tokens */
  --sb-preloader-container-bg: rgba(var(--sb-white-rgb), 0.75);
  --sb-preloader-container-shadow: 0 20px 40px rgba(var(--sb-black-rgb), 0.1),
                                   inset 0 1px 1px rgba(var(--sb-white-rgb), 0.8);
  --sb-preloader-container-border: 1px solid rgba(var(--sb-primary-rgb), 0.15);
  --sb-preloader-text-bg: linear-gradient(90deg, var(--sb-text-muted) 0%, var(--sb-text-main) 50%, var(--sb-text-muted) 100%);
}

.dark .sb-preloader,
.dark-theme .sb-preloader,
[data-bs-theme="dark"] .sb-preloader {
  --sb-preloader-container-bg: rgba(var(--sb-dark-dropdown-bg-rgb), 0.75);
  --sb-preloader-container-shadow: 0 20px 40px rgba(var(--sb-black-rgb), 0.4),
                                   inset 0 1px 1px rgba(var(--sb-white-rgb), 0.1);
  --sb-preloader-container-border: 1px solid rgba(var(--sb-primary-rgb), 0.3);
  --sb-preloader-text-bg: linear-gradient(90deg, rgba(var(--sb-white-rgb), 0.6) 0%, rgba(var(--sb-white-rgb), 1) 50%, rgba(var(--sb-white-rgb), 0.6) 100%);
}

@media (prefers-color-scheme: dark) {
  .sb-preloader {
    --sb-preloader-container-bg: rgba(var(--sb-dark-dropdown-bg-rgb), 0.75);
    --sb-preloader-container-shadow: 0 20px 40px rgba(var(--sb-black-rgb), 0.4),
                                     inset 0 1px 1px rgba(var(--sb-white-rgb), 0.1);
    --sb-preloader-container-border: 1px solid rgba(var(--sb-primary-rgb), 0.3);
    --sb-preloader-text-bg: linear-gradient(90deg, rgba(var(--sb-white-rgb), 0.6) 0%, rgba(var(--sb-white-rgb), 1) 50%, rgba(var(--sb-white-rgb), 0.6) 100%);
  }
}

.sb-preloader.is-visible {
  opacity: 1;
  pointer-events: auto;
}

/* Glassmorphic Container */
.sb-preloader-spinner-container {
  display: flex;
  flex-direction: column;
  align-items: center;
  background: var(--sb-preloader-container-bg);
  backdrop-filter: blur(12px) saturate(180%);
  -webkit-backdrop-filter: blur(12px) saturate(180%);
  padding: var(--sb-sp-xl) var(--sb-sp-lg);
  border-radius: var(--sb-radius-xl);
  box-shadow: var(--sb-preloader-container-shadow);
  border: var(--sb-preloader-container-border);
  max-width: 90%;
  width: 260px;
  transform: scale(0.9);
  transition: transform var(--sb-transition-base);
  position: relative;
  overflow: hidden;
}

.sb-preloader.is-visible .sb-preloader-spinner-container {
  transform: scale(1);
}

/* Spinner Wrapper to hold pulse animations */
.sb-preloader-spinner-wrapper {
  position: relative;
  width: 56px;
  height: 56px;
  margin-bottom: var(--sb-sp-md);
  display: flex;
  align-items: center;
  justify-content: center;
}

/* Neon-Glow Spinner */
.sb-preloader-spinner {
  width: 100%;
  height: 100%;
  border: 3px solid rgba(var(--sb-primary-rgb), 0.1);
  border-top-color: var(--sb-primary);
  border-right-color: var(--sb-info);
  border-radius: 50%;
  animation: sb-spin 0.8s cubic-bezier(0.4, 0, 0.2, 1) infinite;
  filter: drop-shadow(0 0 6px rgba(var(--sb-primary-rgb), 0.45));
}

/* Pulsing background ripple ring */
.sb-preloader-spinner-wrapper::before {
  content: "";
  position: absolute;
  top: -4px;
  left: -4px;
  right: -4px;
  bottom: -4px;
  border-radius: 50%;
  border: 2px solid var(--sb-primary);
  opacity: 0;
  animation: sb-pulse 2s cubic-bezier(0.215, 0.61, 0.355, 1) infinite;
  pointer-events: none;
}

/* Metallic Shimmering Text */
.sb-preloader-text {
  font-family: var(--sb-font-main);
  font-size: var(--sb-font-sm);
  font-weight: 600;
  letter-spacing: 0.3px;
  background: var(--sb-preloader-text-bg);
  background-size: 200% 100%;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  animation: sb-shimmer 2s infinite linear;
}

/* Animations */
@keyframes sb-pulse {
  0% {
    transform: scale(0.9);
    opacity: 0.6;
  }
  100% {
    transform: scale(1.5);
    opacity: 0;
  }
}

@keyframes sb-shimmer {
  0% {
    background-position: 200% 0;
  }
  100% {
    background-position: -200% 0;
  }
}

/* Button Loading State */
.btn-sb.btn-loading {
  position: relative;
  color: transparent !important; /* Hide button text and icons */
  pointer-events: none;
  user-select: none;
}

.btn-sb.btn-loading::after {
  content: "";
  position: absolute;
  width: 18px;
  height: 18px;
  top: calc(50% - 9px);
  left: calc(50% - 9px);
  border: 2px solid rgba(var(--sb-white-rgb), 0.85); /* Solid white spinner by default (good for primary buttons) */
  border-right-color: transparent;
  border-radius: 50%;
  animation: sb-spin 0.6s linear infinite;
  z-index: 10;
}

/* For outline/soft buttons where background is light, use primary color for spinner */
.btn-outline-sb-primary.btn-loading::after,
.btn-sb-soft-primary.btn-loading::after,
.btn-sb-soft-secondary.btn-loading::after,
.btn-sb-soft-success.btn-loading::after,
.btn-sb-soft-danger.btn-loading::after,
.btn-sb-soft-warning.btn-loading::after,
.btn-sb-soft-info.btn-loading::after,
.btn-sb-ghost.btn-loading::after {
  border-color: var(--sb-primary);
  border-right-color: transparent;
}

/* Animation */
@keyframes sb-spin {
  from {
    transform: rotate(0deg);
  }
  to {
    transform: rotate(360deg);
  }
}

/* Transparent overlay to block all clicks and show wait cursor instantly */
.sb-action-blocker {
  position: fixed;
  top: 0;
  left: 0;
  width: 100vw;
  height: 100vh;
  z-index: 99999;
  background-color: transparent;
  cursor: wait;
  pointer-events: auto;
}

/* Iframe-local Preloader Overlay */
.sb-iframe-loading-overlay {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(var(--sb-bg-main-rgb), 0.7); /* Soft blurred overlay matching theme */
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 1050; /* Above all other elements on the dashboard */
  opacity: 0;
  transition: opacity var(--sb-transition-base);
  pointer-events: none;

  /* Component variables routing through design tokens */
  --sb-preloader-container-bg: rgba(var(--sb-white-rgb), 0.75);
  --sb-preloader-container-shadow: 0 20px 40px rgba(var(--sb-black-rgb), 0.1),
                                   inset 0 1px 1px rgba(var(--sb-white-rgb), 0.8);
  --sb-preloader-container-border: 1px solid rgba(var(--sb-primary-rgb), 0.15);
  --sb-preloader-text-bg: linear-gradient(90deg, var(--sb-text-muted) 0%, var(--sb-text-main) 50%, var(--sb-text-muted) 100%);
}

.dark .sb-iframe-loading-overlay,
.dark-theme .sb-iframe-loading-overlay,
[data-bs-theme="dark"] .sb-iframe-loading-overlay {
  --sb-preloader-container-bg: rgba(var(--sb-dark-dropdown-bg-rgb), 0.75);
  --sb-preloader-container-shadow: 0 20px 40px rgba(var(--sb-black-rgb), 0.4),
                                   inset 0 1px 1px rgba(var(--sb-white-rgb), 0.1);
  --sb-preloader-container-border: 1px solid rgba(var(--sb-primary-rgb), 0.3);
  --sb-preloader-text-bg: linear-gradient(90deg, rgba(var(--sb-white-rgb), 0.6) 0%, rgba(var(--sb-white-rgb), 1) 50%, rgba(var(--sb-white-rgb), 0.6) 100%);
}

@media (prefers-color-scheme: dark) {
  .sb-iframe-loading-overlay {
    --sb-preloader-container-bg: rgba(var(--sb-dark-dropdown-bg-rgb), 0.75);
    --sb-preloader-container-shadow: 0 20px 40px rgba(var(--sb-black-rgb), 0.4),
                                     inset 0 1px 1px rgba(var(--sb-white-rgb), 0.1);
    --sb-preloader-container-border: 1px solid rgba(var(--sb-primary-rgb), 0.3);
    --sb-preloader-text-bg: linear-gradient(90deg, rgba(var(--sb-white-rgb), 0.6) 0%, rgba(var(--sb-white-rgb), 1) 50%, rgba(var(--sb-white-rgb), 0.6) 100%);
  }
}

.sb-iframe-loading-overlay.is-visible {
  opacity: 1;
  pointer-events: auto;
}


:root {
  --primary-gradient: linear-gradient(135deg, var(--sb-primary) 0%, var(--sb-primary-dark) 100%);
  --soft-shadow: var(--sb-shadow-soft);
  --shadow-primary: var(--sb-shadow-primary);
}

.profile-page-wrapper { background-color: var(--sb-bg-main) !important; }
.shadow-soft { box-shadow: var(--sb-shadow-soft); }
.ls-1 { letter-spacing: 0.1em; }
.x-small { font-size: 0.7rem; }
.shadow-left { box-shadow: var(--sb-shadow-left) !important; }

.action-group {
  display: flex;
  gap: 6px;
  padding: 4px;
  background: rgba(var(--sb-black-rgb), 0.02);
  border-radius: 12px;
  width: fit-content;
}

.icon-shape { width: 48px; height: 48px; display: flex; align-items: center; justify-content: center; font-size: 1.25rem; }
.grayscale { filter: grayscale(1); }

/* Modal Settings Tabs Styles */
#settingsTabs .nav-link {
  color: var(--sb-gray-700) !important; /* Darker, more visible grey */
  border-radius: 12px;
  margin-bottom: 8px;
  font-weight: 600;
  transition: all 0.2s;
  border: 1px solid transparent;
}
#settingsTabs .nav-link:hover {
  background-color: rgba(var(--sb-black-rgb), 0.03);
  color: var(--sb-gray-900) !important;
}
#settingsTabs .nav-link.active {
  background-color: var(--sb-primary) !important;
  color: var(--sb-dark-text) !important;
  box-shadow: 0 4px 12px rgba(var(--sb-primary-rgb), 0.2);
}
#settingsTabs .nav-link i {
  font-size: 1.1rem;
  margin-right: 12px;
}

.modal-xl { max-width: 1100px; }
.tab-pane { animation: modalFadeIn 0.3s ease-out; }
@keyframes modalFadeIn {
  from { opacity: 0; transform: translateY(10px); }
  to { opacity: 1; transform: translateY(0); }
}

.hidden-inputs {
  display: none !important;
}

.opacity-50.grayscale {
  opacity: 0.6 !important;
  filter: grayscale(1);
}

/* Premium ROI Card Gradient */
.bg-gradient-premium {
  background: linear-gradient(135deg, var(--sb-dark-gradient-1) 0%, var(--sb-dark-gradient-2) 50%, var(--sb-dark-gradient-3) 100%) !important;
  border: 1px solid rgba(var(--sb-white-rgb), 0.1) !important;
}

/* Stats Overview Cards */
.sb-stat-card {
  background: var(--sb-bg-card);
  border: 1px solid var(--sb-border-light);
  border-radius: var(--sb-radius-lg);
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}
.sb-stat-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--sb-shadow-lg) !important;
  border-color: var(--sb-primary-light);
}

/* Action Items (Daily Tasks) */
.sb-action-item {
  transition: all 0.2s ease-in-out;
}
.sb-action-item:hover {
  border-color: var(--sb-primary-light) !important;
  background: rgba(var(--sb-primary-rgb), 0.03) !important;
}

/* ROI Grid Items */
.roi-item {
  background: rgba(var(--sb-white-rgb), 0.06) !important;
  border: 1px solid rgba(var(--sb-white-rgb), 0.08) !important;
  transition: all 0.2s ease-in-out;
}
.roi-item:hover {
  background: rgba(var(--sb-white-rgb), 0.12) !important;
  transform: translateY(-2px);
}

/* Outline Buttons */
.btn-sb-outline {
  background: transparent;
  border: 1px solid var(--sb-border-light);
  color: var(--sb-text-main);
  transition: all 0.2s;
}
.btn-sb-outline:hover {
  background: rgba(var(--sb-black-rgb), 0.03);
  border-color: var(--sb-text-muted);
  color: var(--sb-text-main);
}

/* Interactive link cards hover styling */
a.sb-stat-card.bg-primary.bg-opacity-10:hover {
  background-color: rgba(var(--sb-primary-rgb), 0.18) !important;
}

/*
 * This is a manifest file that'll be compiled into application.css, which will include all the files
 * listed below.
 *
 * Any CSS (and SCSS, if configured) file within this directory, lib/assets/stylesheets, or any plugin's
 * vendor/assets/stylesheets directory can be referenced here using a relative path.
 *
 * You're free to add application-wide styles to this file and they'll appear at the bottom of the
 * compiled file so the styles you add here take precedence over styles defined in any other CSS
 * files in this directory. Styles in this file should be added after the last require_* statement.
 * It is generally better to create a new file per style scope.
 *


















 */

body {
  font-family: var(--sb-font-main);
  background-color: var(--sb-bg-main);
}

.navbar {
  background-color: var(--sb-dark-bg) !important;
}

.navbar-brand {
  color: var(--sb-primary-text) !important;
  letter-spacing: 0.5px;
}

.text-superbox {
  color: var(--sb-primary-text);
}

/* Accessibility: Focus visible outline for keyboard navigation */
a:focus-visible,
button:focus-visible,
input:focus-visible,
select:focus-visible,
textarea:focus-visible,
.btn-sb:focus-visible {
  outline: 2px solid var(--sb-color-focus-ring) !important;
  outline-offset: 2px !important;
  box-shadow: var(--sb-focus-ring-shadow) !important;
}


/* Standardized Error Styling for both legacy and DS inputs */
.form-control.is-invalid, 
.form-select.is-invalid,
.sb-input.is-invalid,
.sb-select.is-invalid {
  border-color: var(--sb-danger) !important;
  background-color: var(--sb-danger-bg) !important;
}

/* Ensure standalone inputs show their border color when invalid */
.sb-input.is-invalid {
  border: 1px solid var(--sb-danger) !important;
}

.form-control.is-invalid:focus,
.form-select.is-invalid:focus,
.sb-input.is-invalid:focus,
.sb-select.is-invalid:focus {
  background-color: white !important;
  border-color: var(--sb-danger) !important;
  box-shadow: 0 0 0 0.25rem rgba(var(--sb-danger-rgb), 0.1) !important;
}
