@layer tokens {
:root {
    
    --sp-error: var(--sp-danger);
    --sp-info: var(--sp-accent);
    --sp-color-primary: var(--sp-accent);
    --sp-color-success: var(--sp-success);
    --sp-color-info: light-dark(oklch(0.62 0.18 260), oklch(0.70 0.14 250));
    --sp-color-warning: var(--sp-warning);
    --sp-accent-blue: light-dark(oklch(0.62 0.18 260), oklch(0.70 0.14 250));
    --sp-accent-surface: light-dark(
      color-mix(in oklch, var(--sp-accent) 6%, var(--sp-bg-surface)),
      color-mix(in oklch, var(--sp-accent) 8%, var(--sp-bg-surface))
    );

    
    --sp-bg-input: light-dark(oklch(1.0 0 0), oklch(0.19 0.01 47));
    --sp-bg-primary: var(--sp-bg-surface);
    --sp-bg-secondary: var(--sp-bg-surface-raised);
    --sp-bg-tertiary: light-dark(oklch(0.96 0.005 70), oklch(0.23 0.01 48));
    --sp-bg-warning: light-dark(
      color-mix(in oklch, var(--sp-warning) 10%, var(--sp-bg-surface)),
      color-mix(in oklch, var(--sp-warning) 12%, var(--sp-bg-surface))
    );
    --sp-surface-1: var(--sp-bg-surface);
    --sp-surface-2: var(--sp-bg-surface-raised);

    
    --sp-border: var(--sp-border-default);
    --sp-border-color: var(--sp-border-default);
    --sp-border-hover: var(--sp-border-strong);
    --sp-border-primary: light-dark(
      color-mix(in oklch, var(--sp-accent) 30%, var(--sp-border-default)),
      color-mix(in oklch, var(--sp-accent) 25%, var(--sp-border-default))
    );

    
    --sp-text-muted: var(--sp-text-tertiary);

    
    --sp-font-mono: "SF Mono", "Cascadia Code", "Fira Code", "JetBrains Mono", monospace;

    
    --sp-z-modal-backdrop: 1400;
    --sp-z-tooltip: 3000;

    
    --sp-color-primary: var(--sp-accent);
    --sp-color-success: var(--sp-success);
    --sp-color-border: var(--sp-border-default);
    --sp-color-surface: var(--sp-bg-surface);
    --sp-color-text: var(--sp-text-primary);
    --sp-color-text-secondary: var(--sp-text-secondary);
    --sp-font-size-sm: var(--sp-text-sm);
    --sp-font-size-md: var(--sp-text-base);
    --sp-font-size-xl: var(--sp-text-xl);
    --sp-space-xs: var(--sp-space-1);
    --sp-space-sm: var(--sp-space-2);
    --sp-space-md: var(--sp-space-4);
    --sp-space-lg: var(--sp-space-6);
    --sp-space-xl: var(--sp-space-8);
}
}

@layer tokens, reset, base, components, utilities, responsive;

@layer tokens {
:root {
    color-scheme: light dark;


    --sp-primitive-orange-50:  oklch(0.96 0.03 60);
    --sp-primitive-orange-100: oklch(0.93 0.06 58);
    --sp-primitive-orange-200: oklch(0.85 0.12 55);
    --sp-primitive-orange-300: oklch(0.78 0.15 53);
    --sp-primitive-orange-400: oklch(0.75 0.16 52);
    --sp-primitive-orange-500: oklch(0.72 0.17 52);
    --sp-primitive-orange-600: oklch(0.67 0.18 50);
    --sp-primitive-orange-700: oklch(0.57 0.16 48);
    --sp-primitive-orange-800: oklch(0.47 0.13 47);
    --sp-primitive-orange-900: oklch(0.37 0.09 46);
    --sp-primitive-orange-950: oklch(0.25 0.05 45);
    --sp-primitive-warm-50:  oklch(0.98 0.004 70);
    --sp-primitive-warm-100: oklch(0.96 0.005 70);
    --sp-primitive-warm-200: oklch(0.92 0.008 65);
    --sp-primitive-warm-300: oklch(0.86 0.010 60);
    --sp-primitive-warm-400: oklch(0.70 0.01 70);
    --sp-primitive-warm-500: oklch(0.53 0.01 65);
    --sp-primitive-warm-600: oklch(0.41 0.01 60);
    --sp-primitive-warm-700: oklch(0.34 0.01 55);
    --sp-primitive-warm-800: oklch(0.24 0.01 50);
    --sp-primitive-warm-900: oklch(0.20 0.01 50);
    --sp-primitive-warm-950: oklch(0.13 0.01 45);
    --sp-primitive-white: oklch(1.00 0 0);
    --sp-primitive-black: oklch(0 0 0);

    --sp-font-family: "Inter", system-ui, -apple-system, BlinkMacSystemFont, sans-serif;
    --sp-font-heading: "Inter", system-ui, -apple-system, BlinkMacSystemFont, sans-serif;
    --sp-text-xs: 0.6875rem;
    --sp-text-sm: 0.8125rem;
    --sp-text-base: 0.9375rem;
    --sp-text-md: 1rem;
    --sp-text-lg: 1.25rem;
    --sp-text-xl: 1.5rem;
    --sp-text-2xl: 2rem;

    --sp-primary-50:  light-dark(var(--sp-primitive-orange-50),  var(--sp-primitive-orange-950));
    --sp-primary-100: light-dark(var(--sp-primitive-orange-100), oklch(0.31 0.07 46));
    --sp-primary-200: light-dark(var(--sp-primitive-orange-200), oklch(0.42 0.11 47));
    --sp-primary-300: light-dark(var(--sp-primitive-orange-300), oklch(0.52 0.14 48));
    --sp-primary-400: light-dark(var(--sp-primitive-orange-400), var(--sp-primitive-orange-600));
    --sp-primary-500: light-dark(var(--sp-primitive-orange-500), var(--sp-primitive-orange-500));
    --sp-primary-600: light-dark(var(--sp-primitive-orange-600), var(--sp-primitive-orange-400));
    --sp-primary-700: light-dark(var(--sp-primitive-orange-700), var(--sp-primitive-orange-300));
    --sp-primary-800: light-dark(var(--sp-primitive-orange-800), var(--sp-primitive-orange-200));
    --sp-primary-900: light-dark(var(--sp-primitive-orange-900), var(--sp-primitive-orange-100));
    --sp-primary-950: light-dark(var(--sp-primitive-orange-950), var(--sp-primitive-orange-50));

    --sp-warm-50:  light-dark(var(--sp-primitive-warm-50),  var(--sp-primitive-warm-950));
    --sp-warm-100: light-dark(var(--sp-primitive-warm-100), var(--sp-primitive-warm-900));
    --sp-warm-200: light-dark(var(--sp-primitive-warm-200), var(--sp-primitive-warm-800));
    --sp-warm-300: light-dark(var(--sp-primitive-warm-300), var(--sp-primitive-warm-700));
    --sp-warm-400: light-dark(var(--sp-primitive-warm-400), var(--sp-primitive-warm-600));
    --sp-warm-500: light-dark(var(--sp-primitive-warm-500), var(--sp-primitive-warm-500));
    --sp-warm-600: light-dark(var(--sp-primitive-warm-600), var(--sp-primitive-warm-400));
    --sp-warm-700: light-dark(var(--sp-primitive-warm-700), var(--sp-primitive-warm-300));
    --sp-warm-800: light-dark(var(--sp-primitive-warm-800), var(--sp-primitive-warm-200));
    --sp-warm-900: light-dark(var(--sp-primitive-warm-900), var(--sp-primitive-warm-100));
    --sp-warm-950: light-dark(var(--sp-primitive-warm-950), var(--sp-primitive-warm-50));

    --sp-bg-base:            light-dark(oklch(0.96 0.004 70), oklch(0.16 0.01 45));
    --sp-bg-canvas:          light-dark(oklch(0.98 0.003 70), oklch(0.18 0.01 45));
    --sp-bg-surface:         light-dark(oklch(1.0 0 0), oklch(0.21 0.01 48));
    --sp-bg-surface-raised:  light-dark(oklch(1.0 0 0), oklch(0.24 0.01 48));
    --sp-bg-surface-overlay: light-dark(oklch(0.98 0.003 70), oklch(0.28 0.01 48));

    --sp-border-subtle:  light-dark(oklch(0.20 0.01 50 / 0.08), oklch(1.00 0 0 / 0.06));
    --sp-border-default: light-dark(oklch(0.20 0.01 50 / 0.12), oklch(1.00 0 0 / 0.10));
    --sp-border-strong:  light-dark(oklch(0.20 0.01 50 / 0.20), oklch(1.00 0 0 / 0.16));

    --sp-text-primary:   light-dark(var(--sp-primitive-warm-900), var(--sp-primitive-warm-50));
    --sp-text-secondary: light-dark(var(--sp-primitive-warm-600), var(--sp-primitive-warm-300));
    --sp-text-tertiary:  light-dark(var(--sp-primitive-warm-500), var(--sp-primitive-warm-400));
    --sp-text-disabled:  light-dark(var(--sp-primitive-warm-400), var(--sp-primitive-warm-600));
    --sp-text-on-accent: var(--sp-primitive-white);
    --sp-text-on-dark:   var(--sp-primitive-white);

    --sp-interactive:    light-dark(oklch(0.62 0.17 48), oklch(0.70 0.17 51));
    --sp-accent:         light-dark(oklch(0.62 0.17 48), oklch(0.70 0.17 51));
    --sp-accent-hover:   light-dark(oklch(0.55 0.16 47), oklch(0.72 0.17 52));
    --sp-accent-dim:     light-dark(
      color-mix(in oklch, var(--sp-accent) 10%, transparent),
      color-mix(in oklch, var(--sp-accent) 15%, transparent)
    );
    --sp-accent-strong:  light-dark(
      color-mix(in oklch, var(--sp-accent) 18%, transparent),
      color-mix(in oklch, var(--sp-accent) 25%, transparent)
    );

    --sp-sidebar-bg: light-dark(var(--sp-primitive-warm-50), oklch(0.22 0.03 50));
    --sp-sidebar-border: light-dark(var(--sp-primitive-warm-200), oklch(0.30 0.02 50));
    --sp-sidebar-text: light-dark(var(--sp-primitive-warm-600), oklch(1.00 0 0 / 0.75));
    --sp-sidebar-text-muted: light-dark(var(--sp-primitive-warm-500), oklch(1.00 0 0 / 0.45));
    --sp-sidebar-text-hover: light-dark(var(--sp-primitive-warm-900), var(--sp-primitive-white));
    --sp-sidebar-hover-bg: light-dark(var(--sp-primitive-warm-100), oklch(1.00 0 0 / 0.06));
    --sp-sidebar-active-bg: light-dark(oklch(0.95 0.015 55), oklch(0.62 0.17 48 / 0.15));
    --sp-sidebar-active-color: light-dark(var(--sp-primitive-orange-600), oklch(0.75 0.16 52));

    --sp-success: light-dark(oklch(0.69 0.17 165), oklch(0.78 0.16 165));
    --sp-success-dim: light-dark(
      color-mix(in oklch, var(--sp-success) 14%, transparent),
      color-mix(in oklch, var(--sp-success) 16%, transparent)
    );
    --sp-success-strong: light-dark(
      color-mix(in oklch, var(--sp-success) 22%, transparent),
      color-mix(in oklch, var(--sp-success) 25%, transparent)
    );

    --sp-warning: light-dark(oklch(0.76 0.16 75), oklch(0.83 0.16 85));
    --sp-warning-dim: light-dark(
      color-mix(in oklch, var(--sp-warning) 14%, transparent),
      color-mix(in oklch, var(--sp-warning) 16%, transparent)
    );
    --sp-warning-strong: light-dark(
      color-mix(in oklch, var(--sp-warning) 22%, transparent),
      color-mix(in oklch, var(--sp-warning) 25%, transparent)
    );

    --sp-danger: light-dark(oklch(0.63 0.21 25), oklch(0.70 0.17 20));
    --sp-danger-dim: light-dark(
      color-mix(in oklch, var(--sp-danger) 12%, transparent),
      color-mix(in oklch, var(--sp-danger) 14%, transparent)
    );
    --sp-danger-strong: light-dark(
      color-mix(in oklch, var(--sp-danger) 18%, transparent),
      color-mix(in oklch, var(--sp-danger) 20%, transparent)
    );

    --sp-section-dashboard: light-dark(oklch(0.67 0.18 50), oklch(0.70 0.17 51));
    --sp-section-users:     light-dark(oklch(0.55 0.22 295), oklch(0.68 0.16 295));
    --sp-section-plugins:   light-dark(oklch(0.62 0.18 260), oklch(0.70 0.14 250));
    --sp-section-skills:    light-dark(oklch(0.69 0.17 165), oklch(0.78 0.16 165));
    --sp-section-export:    light-dark(oklch(0.76 0.16 75), oklch(0.83 0.16 85));
    --sp-section-audit:     light-dark(oklch(0.63 0.21 25), oklch(0.70 0.17 20));
    --sp-section-dashboard-dim: light-dark(
      color-mix(in oklch, var(--sp-section-dashboard) 14%, transparent),
      color-mix(in oklch, var(--sp-section-dashboard) 16%, transparent)
    );
    --sp-section-users-dim: light-dark(
      color-mix(in oklch, var(--sp-section-users) 14%, transparent),
      color-mix(in oklch, var(--sp-section-users) 16%, transparent)
    );
    --sp-section-plugins-dim: light-dark(
      color-mix(in oklch, var(--sp-section-plugins) 14%, transparent),
      color-mix(in oklch, var(--sp-section-plugins) 16%, transparent)
    );
    --sp-section-skills-dim: light-dark(
      color-mix(in oklch, var(--sp-section-skills) 14%, transparent),
      color-mix(in oklch, var(--sp-section-skills) 16%, transparent)
    );
    --sp-section-export-dim: light-dark(
      color-mix(in oklch, var(--sp-section-export) 14%, transparent),
      color-mix(in oklch, var(--sp-section-export) 16%, transparent)
    );
    --sp-section-audit-dim: light-dark(
      color-mix(in oklch, var(--sp-section-audit) 14%, transparent),
      color-mix(in oklch, var(--sp-section-audit) 16%, transparent)
    );
}
}

@layer tokens {
:root {
    --sp-chart-purple: light-dark(oklch(0.55 0.22 295), oklch(0.68 0.16 295));
    --sp-chart-blue:   light-dark(oklch(0.62 0.18 260), oklch(0.70 0.14 250));
    --sp-chart-green:  light-dark(oklch(0.69 0.17 165), oklch(0.78 0.16 165));
    --sp-chart-amber:  light-dark(oklch(0.76 0.16 75), oklch(0.83 0.16 85));
    --sp-chart-red:    light-dark(oklch(0.63 0.21 25), oklch(0.70 0.17 20));
    --sp-chart-cyan:   light-dark(oklch(0.72 0.12 200), oklch(0.82 0.11 200));

    --sp-progress-green-from: light-dark(oklch(0.69 0.17 165), oklch(0.78 0.16 165));
    --sp-progress-green-to:   light-dark(oklch(0.78 0.16 165), oklch(0.85 0.13 160));
    --sp-progress-amber-from: light-dark(oklch(0.76 0.16 75), oklch(0.83 0.16 85));
    --sp-progress-amber-to:   light-dark(oklch(0.83 0.16 85), oklch(0.88 0.13 85));
    --sp-progress-red-from:   light-dark(oklch(0.63 0.21 25), oklch(0.70 0.17 20));
    --sp-progress-red-to:     light-dark(oklch(0.70 0.17 20), oklch(0.78 0.10 20));

    --sp-nav-label-1: light-dark(oklch(0.55 0.16 52), oklch(0.75 0.16 52));
    --sp-nav-label-2: light-dark(oklch(0.55 0.12 300), oklch(0.80 0.12 300));
    --sp-nav-label-3: light-dark(oklch(0.52 0.10 255), oklch(0.78 0.10 255));
    --sp-nav-label-4: light-dark(oklch(0.55 0.13 160), oklch(0.85 0.13 160));
    --sp-nav-label-5: light-dark(oklch(0.58 0.13 85), oklch(0.88 0.13 85));
    --sp-nav-badge-text: light-dark(oklch(0.55 0.10 20), oklch(0.78 0.10 20));

    --sp-feed-purple: light-dark(oklch(0.55 0.22 295), oklch(0.68 0.16 295));
    --sp-feed-cyan:   light-dark(oklch(0.72 0.12 200), oklch(0.82 0.11 200));
    --sp-feed-indigo: light-dark(oklch(0.57 0.18 280), oklch(0.65 0.14 280));
    --sp-feed-gold:   light-dark(oklch(0.76 0.16 75), oklch(0.83 0.16 85));
    --sp-badge-purple: light-dark(oklch(0.68 0.16 295), oklch(0.68 0.16 295));
    --sp-badge-purple-dim: light-dark(
      color-mix(in oklch, oklch(0.68 0.16 295) 15%, transparent),
      color-mix(in oklch, oklch(0.68 0.16 295) 18%, transparent)
    );

    
    --sp-rank-tier-1-color: light-dark(oklch(0.72 0.03 250), oklch(0.82 0.03 250));
    --sp-rank-tier-1-bg:    light-dark(oklch(0.50 0.03 250), oklch(0.55 0.03 250));
    --sp-rank-tier-2-color: light-dark(oklch(0.70 0.14 250), oklch(0.78 0.10 255));
    --sp-rank-tier-2-bg:    light-dark(oklch(0.55 0.14 250), oklch(0.50 0.14 255));
    --sp-rank-tier-3-color: light-dark(oklch(0.78 0.16 165), oklch(0.85 0.13 160));
    --sp-rank-tier-3-bg:    light-dark(oklch(0.58 0.16 165), oklch(0.55 0.16 160));
    --sp-rank-tier-4-color: light-dark(oklch(0.68 0.16 295), oklch(0.80 0.12 300));
    --sp-rank-tier-4-bg:    light-dark(oklch(0.55 0.16 295), oklch(0.50 0.16 300));
    --sp-rank-tier-5-color: light-dark(oklch(0.76 0.16 75), oklch(0.88 0.13 85));
    --sp-rank-tier-5-bg:    light-dark(oklch(0.56 0.16 75), oklch(0.52 0.16 85));
    --sp-rank-tier-6-color: light-dark(oklch(0.65 0.20 345), oklch(0.78 0.11 350));
    --sp-rank-tier-6-bg:    light-dark(oklch(0.52 0.18 345), oklch(0.48 0.18 350));
    --sp-rank-tier-7-color: light-dark(oklch(0.70 0.18 45), oklch(0.80 0.12 60));
    --sp-rank-tier-7-bg:    light-dark(oklch(0.55 0.18 45), oklch(0.52 0.18 60));
    --sp-rank-tier-8-color: light-dark(oklch(0.55 0.22 295), oklch(0.68 0.16 295));
    --sp-rank-tier-8-bg:    light-dark(oklch(0.45 0.20 295), oklch(0.42 0.20 295));
    --sp-rank-tier-9-color: light-dark(oklch(0.72 0.12 200), oklch(0.82 0.11 200));
    --sp-rank-tier-9-bg:    light-dark(oklch(0.52 0.14 200), oklch(0.48 0.14 200));
    --sp-rank-tier-10-color: light-dark(oklch(0.82 0.17 95), oklch(0.88 0.15 95));
    --sp-rank-tier-10-bg:    light-dark(oklch(0.58 0.17 95), oklch(0.55 0.17 95));

    --sp-rank-1-color: var(--sp-rank-tier-1-color);
    --sp-rank-2-color: var(--sp-rank-tier-1-color);
    --sp-rank-3-color: var(--sp-rank-tier-2-color);
    --sp-rank-4-color: var(--sp-rank-tier-2-color);
    --sp-rank-5-color: var(--sp-rank-tier-3-color);
    --sp-rank-6-color: var(--sp-rank-tier-3-color);
    --sp-rank-7-color: var(--sp-rank-tier-4-color);
    --sp-rank-8-color: var(--sp-rank-tier-5-color);
    --sp-rank-9-color: var(--sp-rank-tier-6-color);
    --sp-rank-10-color: var(--sp-rank-tier-7-color);
    --sp-rank-1-bg: var(--sp-rank-tier-1-bg);
    --sp-rank-2-bg: var(--sp-rank-tier-1-bg);
    --sp-rank-3-bg: var(--sp-rank-tier-2-bg);
    --sp-rank-4-bg: var(--sp-rank-tier-2-bg);
    --sp-rank-5-bg: var(--sp-rank-tier-3-bg);
    --sp-rank-6-bg: var(--sp-rank-tier-3-bg);
    --sp-rank-7-bg: var(--sp-rank-tier-4-bg);
    --sp-rank-8-bg: var(--sp-rank-tier-5-bg);
    --sp-rank-9-bg: var(--sp-rank-tier-6-bg);
    --sp-rank-10-bg: var(--sp-rank-tier-7-bg);
    --sp-rank-1-ladder-bg: var(--sp-rank-tier-1-bg);
    --sp-rank-3-ladder-bg: var(--sp-rank-tier-2-bg);
    --sp-rank-5-ladder-bg: var(--sp-rank-tier-3-bg);
    --sp-rank-7-ladder-bg: var(--sp-rank-tier-4-bg);
    --sp-rank-10-ladder-bg: var(--sp-rank-tier-7-bg);

    --sp-rarity-epic-bg: light-dark(
      color-mix(in oklch, oklch(0.60 0.20 295) 15%, transparent),
      color-mix(in oklch, oklch(0.60 0.20 295) 18%, transparent)
    );
    --sp-rarity-epic-fg: light-dark(oklch(0.65 0.20 295), oklch(0.70 0.20 295));

    --sp-bg-surface-alt: light-dark(oklch(0.96 0.006 68), oklch(0.22 0.01 47));
    --sp-badge-accent-bg: light-dark(
      color-mix(in oklch, var(--sp-accent) 8%, var(--sp-bg-surface)),
      color-mix(in oklch, var(--sp-accent) 12%, var(--sp-bg-surface))
    );
    --sp-badge-accent-fg: light-dark(oklch(0.50 0.12 48), oklch(0.75 0.14 52));
    --sp-badge-warning-bg: light-dark(
      color-mix(in oklch, var(--sp-warning) 8%, var(--sp-bg-surface)),
      color-mix(in oklch, var(--sp-warning) 12%, var(--sp-bg-surface))
    );
    --sp-badge-warning-fg: light-dark(oklch(0.52 0.10 80), oklch(0.75 0.12 80));
    --sp-badge-danger-bg: light-dark(
      color-mix(in oklch, var(--sp-danger) 8%, var(--sp-bg-surface)),
      color-mix(in oklch, var(--sp-danger) 10%, var(--sp-bg-surface))
    );
    --sp-badge-danger-fg: light-dark(oklch(0.48 0.12 20), oklch(0.72 0.12 20));
}
}

@layer tokens {
:root {
    --sp-radius-xs: 0.25rem;
    --sp-radius-sm: 0.375rem;
    --sp-radius-md: 0.625rem;
    --sp-radius-lg: 0.875rem;
    --sp-radius-xl: 1.25rem;
    --sp-radius-full: 9999px;
    --sp-radius-card: 1rem;
    --sp-radius-card-inner: 0.625rem;
    --sp-radius-widget: 1.25rem;
    --sp-radius-button: 0.5rem;
    --sp-radius-badge: 0.375rem;
    --sp-radius-brand-tr: 0.375rem;
    --sp-radius-card-brand: var(--sp-corners-md);
    --sp-radius-card-inner-brand: var(--sp-corners-inner-md);
    --sp-radius-widget-brand: 1.25rem 0.375rem 1.25rem 1.25rem;

    --sp-space-1:  0.25rem;
    --sp-space-2:  0.5rem;
    --sp-space-3:  0.75rem;
    --sp-space-4:  1rem;
    --sp-space-5:  1.25rem;
    --sp-space-6:  1.5rem;
    --sp-space-7:  1.75rem;
    --sp-space-8:  2rem;
    --sp-space-10: 2.5rem;
    --sp-space-12: 3rem;

    --sp-ease-out: cubic-bezier(0.16, 1, 0.3, 1);
    --sp-ease-in-out: cubic-bezier(0.4, 0, 0.2, 1);
    --sp-ease-spring: cubic-bezier(0.34, 1.56, 0.64, 1);
    --sp-duration-micro: 80ms;
    --sp-duration-fast: 150ms;
    --sp-duration-normal: 200ms;
    --sp-duration-slow: 350ms;

    --sp-z-sticky: 1;
    --sp-z-sticky-header: 3;
    --sp-z-sidebar: 900;
    --sp-z-sidebar-drawer: 950;
    --sp-z-dropdown: 1000;
    --sp-z-panel: 1100;
    --sp-z-modal: 1500;
    --sp-z-lightbox: 2000;
    --sp-z-toast: 2500;

    --sp-overlay-light:  light-dark(oklch(0.20 0.01 50 / 0.3), oklch(0 0 0 / 0.5));
    --sp-overlay-medium: light-dark(oklch(0.20 0.01 50 / 0.5), oklch(0 0 0 / 0.65));
    --sp-overlay-heavy:  light-dark(oklch(0.20 0.01 50 / 0.7), oklch(0 0 0 / 0.8));
}
}



:root {
  
  --sp-primitive-orange-50:  oklch(0.96 0.03 60);
  --sp-primitive-orange-100: oklch(0.93 0.06 58);
  --sp-primitive-orange-200: oklch(0.85 0.12 55);
  --sp-primitive-orange-300: oklch(0.78 0.15 53);
  --sp-primitive-orange-400: oklch(0.75 0.16 52);
  --sp-primitive-orange-500: oklch(0.72 0.17 52);
  --sp-primitive-orange-600: oklch(0.67 0.18 50);
  --sp-primitive-orange-700: oklch(0.57 0.16 48);
  --sp-primitive-orange-800: oklch(0.47 0.13 47);
  --sp-primitive-orange-900: oklch(0.37 0.09 46);
  --sp-primitive-orange-950: oklch(0.25 0.05 45);

  
  --sp-primitive-warm-50:  oklch(0.98 0.004 70);
  --sp-primitive-warm-100: oklch(0.96 0.005 70);
  --sp-primitive-warm-200: oklch(0.92 0.008 65);
  --sp-primitive-warm-300: oklch(0.86 0.010 60);
  --sp-primitive-warm-400: oklch(0.70 0.01 70);
  --sp-primitive-warm-500: oklch(0.53 0.01 65);
  --sp-primitive-warm-600: oklch(0.41 0.01 60);
  --sp-primitive-warm-700: oklch(0.34 0.01 55);
  --sp-primitive-warm-800: oklch(0.24 0.01 50);
  --sp-primitive-warm-900: oklch(0.20 0.01 50);
  --sp-primitive-warm-950: oklch(0.13 0.01 45);

  
  --sp-primitive-white: oklch(1.00 0 0);
  --sp-primitive-black: oklch(0 0 0);

  
  --sp-primitive-green-500:  oklch(0.72 0.19 155);
  --sp-primitive-green-400:  oklch(0.78 0.16 165);
  --sp-primitive-green-300:  oklch(0.80 0.18 155);
  --sp-primitive-amber-500:  oklch(0.83 0.16 85);
  --sp-primitive-amber-400:  oklch(0.76 0.16 75);
  --sp-primitive-red-500:    oklch(0.63 0.21 25);
  --sp-primitive-red-400:    oklch(0.70 0.17 20);
  --sp-primitive-blue-500:   oklch(0.62 0.18 260);
  --sp-primitive-blue-400:   oklch(0.70 0.14 250);

  
  --sp-primitive-accent-blue:        oklch(0.70 0.14 250);
  --sp-primitive-accent-blue-light:  oklch(0.78 0.10 255);
  --sp-primitive-accent-purple:      oklch(0.68 0.18 300);
  --sp-primitive-accent-purple-light: oklch(0.80 0.12 300);
  --sp-primitive-accent-green:       oklch(0.80 0.18 155);
  --sp-primitive-accent-green-light: oklch(0.88 0.14 155);
  --sp-primitive-accent-pink:        oklch(0.70 0.17 350);
  --sp-primitive-accent-pink-light:  oklch(0.80 0.12 350);
  --sp-primitive-accent-cyan:        oklch(0.79 0.13 200);
  --sp-primitive-accent-cyan-light:  oklch(0.87 0.10 200);

  
  --sp-text-xs:   clamp(0.7rem, 0.66rem + 0.2vw, 0.75rem);
  --sp-text-sm:   clamp(0.8rem, 0.75rem + 0.25vw, 0.875rem);
  --sp-text-base: clamp(0.875rem, 0.82rem + 0.28vw, 0.9375rem);
  --sp-text-md:   clamp(0.9375rem, 0.87rem + 0.33vw, 1rem);
  --sp-text-lg:   clamp(1rem, 0.93rem + 0.35vw, 1.125rem);
  --sp-text-xl:   clamp(1.125rem, 1rem + 0.5vw, 1.25rem);
  --sp-text-2xl:  clamp(1.4rem, 1.2rem + 1vw, 1.75rem);
  --sp-text-3xl:  clamp(1.75rem, 1.4rem + 1.75vw, 2.5rem);
  --sp-text-4xl:  clamp(2.25rem, 1.6rem + 3.2vw, 4rem);

  
  --sp-leading-tight:   1.1;
  --sp-leading-snug:    1.25;
  --sp-leading-normal:  1.5;
  --sp-leading-relaxed: 1.625;

  
  --sp-tracking-tight:  -0.02em;
  --sp-tracking-normal: 0;
  --sp-tracking-wide:   0.05em;

  
  --sp-font-normal:   400;
  --sp-font-medium:   500;
  --sp-font-semibold: 600;
  --sp-font-bold:     700;

  
  --sp-space-1:  0.25rem;
  --sp-space-2:  0.5rem;
  --sp-space-3:  0.75rem;
  --sp-space-4:  1rem;
  --sp-space-5:  1.25rem;
  --sp-space-6:  1.5rem;
  --sp-space-8:  2rem;
  --sp-space-10: 2.5rem;
  --sp-space-12: 3rem;
  --sp-space-16: 4rem;
  --sp-space-20: 5rem;
  --sp-space-24: 6rem;
  --sp-space-32: 8rem;

  
  --sp-radius-xs:   0.125rem;
  --sp-radius-sm:   0.25rem;
  --sp-radius-md:   0.5rem;
  --sp-radius-lg:   0.75rem;
  --sp-radius-xl:   1rem;
  --sp-radius-full: 9999px;

  
  --sp-corners-sm: 0.375rem 0.125rem 0.375rem 0.375rem;
  --sp-corners-md: 1.125rem 0.375rem 1.125rem 1.125rem;
  --sp-corners-lg: 1.5rem 0.5rem 1.5rem 1.5rem;
  --sp-corners-inner-sm: 0.25rem 0.0625rem 0.25rem 0.25rem;
  --sp-corners-inner-md: 0.625rem 0.25rem 0.625rem 0.625rem;
  --sp-corners-inner-lg: 1.125rem 0.375rem 1.125rem 1.125rem;

  
  --sp-duration-instant:  50ms;
  --sp-duration-fast:     100ms;
  --sp-duration-normal:   200ms;
  --sp-duration-moderate: 300ms;
  --sp-duration-slow:     400ms;
  --sp-duration-slower:   600ms;

  
  --sp-ease-default: ease-out;
  --sp-ease-in:      ease-in;
  --sp-ease-out:     ease-out;
  --sp-ease-in-out:  ease-in-out;
  --sp-ease-bounce:  cubic-bezier(0.34, 1.56, 0.64, 1);
  --sp-ease-spring:  cubic-bezier(0.175, 0.885, 0.32, 1.275);

  
  --sp-shadow-xs: 0 1px 2px oklch(0.30 0.02 50 / 0.06);
  --sp-shadow-sm: 0 1px 3px oklch(0.30 0.02 50 / 0.08), 0 1px 2px oklch(0.30 0.02 50 / 0.06);
  --sp-shadow-md: 0 4px 6px oklch(0.30 0.02 50 / 0.08), 0 2px 4px oklch(0.30 0.02 50 / 0.06);
  --sp-shadow-lg: 0 10px 15px oklch(0.30 0.02 50 / 0.08), 0 4px 6px oklch(0.30 0.02 50 / 0.04);
  --sp-shadow-xl: 0 20px 25px oklch(0.30 0.02 50 / 0.10), 0 8px 10px oklch(0.30 0.02 50 / 0.05);
}

@layer tokens {
:root {
    --sp-shadow-xs: light-dark(
      0 1px 2px oklch(0.20 0.01 50 / 0.06),
      0 1px 2px oklch(0 0 0 / 0.2)
    );
    --sp-shadow-sm: light-dark(
      0 1px 3px oklch(0.20 0.01 50 / 0.08), 0 1px 2px oklch(0.20 0.01 50 / 0.06),
      0 1px 3px oklch(0 0 0 / 0.3), 0 1px 2px oklch(0 0 0 / 0.2)
    );
    --sp-shadow-md: light-dark(
      0 4px 8px oklch(0.20 0.01 50 / 0.09), 0 2px 4px oklch(0.20 0.01 50 / 0.06),
      0 4px 8px oklch(0 0 0 / 0.35), 0 2px 4px oklch(0 0 0 / 0.2)
    );
    --sp-shadow-lg: light-dark(
      0 10px 25px oklch(0.20 0.01 50 / 0.12), 0 4px 10px oklch(0.20 0.01 50 / 0.07),
      0 10px 25px oklch(0 0 0 / 0.4), 0 4px 10px oklch(0 0 0 / 0.25)
    );
    --sp-shadow-xl: light-dark(
      0 20px 40px oklch(0.20 0.01 50 / 0.14), 0 8px 16px oklch(0.20 0.01 50 / 0.08),
      0 20px 40px oklch(0 0 0 / 0.5), 0 8px 16px oklch(0 0 0 / 0.3)
    );
    --sp-shadow-inset-sm: light-dark(
      inset 0 1px 2px oklch(0.20 0.01 50 / 0.06),
      inset 0 1px 2px oklch(0 0 0 / 0.2)
    );
    --sp-shadow-card: light-dark(
      0 1px 3px oklch(0.20 0.01 50 / 0.09), 0 1px 2px oklch(0.20 0.01 50 / 0.06), 0 0 0 1px oklch(0.20 0.01 50 / 0.05),
      0 1px 3px oklch(0 0 0 / 0.4), 0 1px 2px oklch(0 0 0 / 0.3), 0 0 0 1px oklch(1.00 0 0 / 0.03)
    );
    --sp-shadow-card-hover: light-dark(
      0 8px 24px oklch(0.20 0.01 50 / 0.14), 0 2px 6px oklch(0.20 0.01 50 / 0.08), 0 0 0 1px oklch(0.20 0.01 50 / 0.06),
      0 8px 24px oklch(0 0 0 / 0.5), 0 2px 6px oklch(0 0 0 / 0.3), 0 0 0 1px oklch(1.00 0 0 / 0.05)
    );
    --sp-shadow-elevated: light-dark(
      0 4px 16px oklch(0.20 0.01 50 / 0.12), 0 2px 6px oklch(0.20 0.01 50 / 0.07), 0 0 1px oklch(0.20 0.01 50 / 0.15),
      0 4px 16px oklch(0 0 0 / 0.5), 0 2px 6px oklch(0 0 0 / 0.35), 0 0 0 1px oklch(1.00 0 0 / 0.04)
    );
    --sp-shadow-float: light-dark(
      0 12px 40px oklch(0.20 0.01 50 / 0.16), 0 4px 12px oklch(0.20 0.01 50 / 0.08),
      0 12px 40px oklch(0 0 0 / 0.55), 0 4px 12px oklch(0 0 0 / 0.3)
    );
    --sp-shadow-accent-sm: light-dark(
      0 2px 8px color-mix(in oklch, var(--sp-accent) 16%, transparent),
      0 2px 8px color-mix(in oklch, var(--sp-accent) 18%, transparent)
    );
    --sp-shadow-accent-md: light-dark(
      0 4px 16px color-mix(in oklch, var(--sp-accent) 20%, transparent),
      0 4px 20px color-mix(in oklch, var(--sp-accent) 22%, transparent)
    );
    --sp-shadow-inner-glow: light-dark(
      inset 0 1px 0 oklch(1.00 0 0 / 0.5),
      inset 0 1px 0 oklch(1.00 0 0 / 0.04)
    );
    --sp-shadow-hero: light-dark(
      0 4px 16px oklch(0.20 0.01 50 / 0.10), 0 2px 4px oklch(0.20 0.01 50 / 0.06), 0 0 0 1px oklch(0.20 0.01 50 / 0.06),
      0 4px 16px oklch(0 0 0 / 0.4), 0 2px 4px oklch(0 0 0 / 0.3), 0 0 0 1px oklch(1.00 0 0 / 0.04)
    );
    --sp-shadow-lift: light-dark(
      0 6px 20px oklch(0.20 0.01 50 / 0.12), 0 2px 6px oklch(0.20 0.01 50 / 0.07), 0 0 0 1px oklch(0.20 0.01 50 / 0.06),
      0 6px 20px oklch(0 0 0 / 0.45), 0 2px 6px oklch(0 0 0 / 0.3), 0 0 0 1px oklch(1.00 0 0 / 0.05)
    );
}
}

@layer tokens {
:root {
    --sp-bg-surface-gradient: light-dark(
      linear-gradient(180deg, oklch(1.0 0 0) 0%, oklch(0.98 0.004 70) 60%, oklch(0.96 0.005 70) 100%),
      linear-gradient(180deg, oklch(0.23 0.01 48) 0%, oklch(0.21 0.01 48) 60%, oklch(0.19 0.01 47) 100%)
    );
    --sp-bg-surface-raised-gradient: light-dark(
      linear-gradient(135deg, oklch(1.0 0 0) 0%, oklch(0.97 0.004 70) 100%),
      linear-gradient(135deg, oklch(0.25 0.01 48) 0%, oklch(0.23 0.01 48) 100%)
    );
    --sp-bg-card-header: light-dark(
      linear-gradient(180deg, oklch(0.97 0.005 65) 0%, oklch(0.95 0.006 65) 100%),
      linear-gradient(180deg, oklch(0.24 0.01 48) 0%, oklch(0.22 0.01 47) 100%)
    );
    --sp-bg-accent-wash: light-dark(
      linear-gradient(135deg, color-mix(in oklch, var(--sp-accent) 6%, oklch(0.99 0.003 70)) 0%, oklch(0.99 0.003 70) 100%),
      linear-gradient(135deg, color-mix(in oklch, var(--sp-accent) 5%, oklch(0.21 0.01 48)) 0%, oklch(0.21 0.01 48) 100%)
    );
    --sp-bg-main: light-dark(oklch(0.95 0.005 70), oklch(0.18 0.01 45));
    --sp-bg-main-gradient: light-dark(
      linear-gradient(180deg, oklch(0.97 0.003 70) 0%, oklch(0.95 0.005 68) 50%, oklch(0.94 0.006 65) 100%),
      linear-gradient(180deg, oklch(0.18 0.01 45) 0%, oklch(0.16 0.01 43) 50%, oklch(0.15 0.01 42) 100%)
    );
    --sp-bg-main-accent-tl: light-dark(
      radial-gradient(ellipse at 0% 0%, oklch(0.72 0.15 45 / 0.07) 0%, transparent 60%),
      radial-gradient(ellipse at 0% 0%, oklch(0.72 0.15 45 / 0.06) 0%, transparent 60%)
    );
    --sp-bg-main-accent-br: light-dark(
      radial-gradient(ellipse at 100% 100%, oklch(0.67 0.18 40 / 0.05) 0%, transparent 50%),
      radial-gradient(ellipse at 100% 100%, oklch(0.67 0.18 40 / 0.04) 0%, transparent 50%)
    );
    --sp-bg-glass: light-dark(oklch(1.00 0 0 / 0.65), oklch(0.21 0.01 48 / 0.78));
    --sp-bg-glass-border: light-dark(oklch(0.20 0.01 50 / 0.08), oklch(1.00 0 0 / 0.06));
    --sp-bg-hero-gradient: light-dark(
      linear-gradient(180deg, oklch(1.0 0 0) 0%, oklch(0.98 0.004 70) 100%),
      var(--sp-bg-surface-raised-gradient)
    );

    --sp-scrollbar-width: 6px;
    --sp-scrollbar-track: transparent;
    --sp-scrollbar-thumb: light-dark(var(--sp-warm-300), var(--sp-warm-300));
    --sp-scrollbar-thumb-hover: light-dark(var(--sp-warm-400), var(--sp-warm-400));
    --sp-toggle-knob: light-dark(var(--sp-primitive-white), var(--sp-primitive-warm-50));
    --sp-shimmer-from: light-dark(var(--sp-warm-100), var(--sp-warm-100));
    --sp-shimmer-via:  light-dark(var(--sp-warm-50), var(--sp-warm-50));
    --sp-shimmer-to:   light-dark(var(--sp-warm-100), var(--sp-warm-100));
}
}

@layer base {

.header-actions-toggle {
    display: none;
    align-items: center;
    justify-content: center;
    width: 36px;
    height: 36px;
    padding: 0;
    border: 1px solid var(--sp-border-default);
    border-radius: var(--sp-radius-md);
    background: var(--sp-bg-surface);
    color: var(--sp-text-secondary);
    cursor: pointer;
    flex-shrink: 0;
    transition: color var(--sp-duration-fast), background var(--sp-duration-fast), border-color var(--sp-duration-fast);
}

.header-actions-toggle:hover {
    color: var(--sp-text-primary);
    background: var(--sp-bg-surface-raised);
    border-color: var(--sp-border-strong);
}

.header-actions-menu {
    display: flex;
    align-items: center;
    gap: var(--sp-space-2);
}

.user-widget-row {
    display: flex;
    align-items: center;
    gap: var(--sp-space-2);
}

.header-help-link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 36px;
    height: 36px;
    margin-left: var(--sp-space-2);
    padding: 0;
    flex-shrink: 0;
    border-radius: var(--sp-radius-md);
    background: var(--sp-bg-surface);
    border: 1px solid var(--sp-border-default);
    color: var(--sp-text-secondary);
    cursor: pointer;
    transition: color var(--sp-duration-fast), background var(--sp-duration-fast), border-color var(--sp-duration-fast);
}
.header-help-link:hover {
    color: var(--sp-text-primary);
    background: var(--sp-bg-surface-raised);
    border-color: var(--sp-border-strong);
}
.header-help-link:focus-visible {
    outline: none;
    box-shadow: 0 0 0 2px var(--sp-bg-canvas), 0 0 0 4px color-mix(in oklch, var(--sp-accent) 50%, transparent);
}
.header-help-link svg {
    display: block;
}

.admin-layout h1, .admin-layout h2, .admin-layout h3 {
    font-family: var(--sp-font-heading);
}

.admin-layout a {
    color: var(--sp-text-secondary);
    text-decoration: none;
    transition: color var(--sp-duration-fast);
}

.admin-layout a:hover {
    color: var(--sp-text-primary);
}

.admin-layout .data-table a,
.admin-layout .clickable-row a {
    color: var(--sp-text-primary);
    font-weight: 500;
}

.admin-layout .data-table a:hover,
.admin-layout .clickable-row a:hover {
    color: var(--sp-accent);
}

[data-section="dashboard"]                          { --sp-section-color: var(--sp-section-dashboard); }
[data-section="users"],  [data-section="user-detail"] { --sp-section-color: var(--sp-section-users); }
[data-section="plugins"],[data-section="plugin-create"],
[data-section="plugin-edit"]                          { --sp-section-color: var(--sp-section-plugins); }
[data-section="skills"], [data-section="skill-edit"]  { --sp-section-color: var(--sp-section-skills); }
[data-section="export"]                               { --sp-section-color: var(--sp-section-export); }
[data-section="audit"]                                { --sp-section-color: var(--sp-section-audit); }
[data-section="agents"], [data-section="agent-edit"]  { --sp-section-color: var(--sp-section-dashboard); }
[data-section="hooks"],  [data-section="hook-edit"]   { --sp-section-color: var(--sp-section-dashboard); }
[data-section="mcp-servers"],[data-section="mcp-edit"]{ --sp-section-color: var(--sp-section-dashboard); }
[data-section="jobs"],   [data-section="events"]      { --sp-section-color: var(--sp-section-users); }
[data-section="leaderboard"],[data-section="achievements"] { --sp-section-color: var(--sp-section-dashboard); }

.section-title {
    font-size: var(--sp-text-md);
    font-weight: 600;
    margin: var(--sp-space-8) 0 var(--sp-space-5);
    color: var(--sp-text-primary);
    letter-spacing: -0.01em;
    display: flex;
    align-items: center;
    gap: var(--sp-space-2);
}

}

@layer base {

.section-title::before {
    content: '';
    display: inline-block;
    width: 2px;
    height: 1em;
    background: var(--sp-section-color);
    border-radius: var(--sp-radius-xs);
    flex-shrink: 0;
    box-shadow: 0 0 8px color-mix(in oklch, var(--sp-section-color) 30%, transparent);
}

input[type="checkbox"] {
    accent-color: var(--sp-accent);
    cursor: pointer;
}

select {
    background: var(--sp-bg-surface);
    color: var(--sp-text-primary);
}

select option {
    background: var(--sp-bg-surface-overlay);
    color: var(--sp-text-primary);
}

a:focus-visible,
button:focus-visible,
input:focus-visible,
select:focus-visible,
textarea:focus-visible {
    outline: none;
    box-shadow: 0 0 0 2px var(--sp-bg-canvas), 0 0 0 4px color-mix(in oklch, var(--sp-accent) 50%, transparent);
}

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

@keyframes fadeIn {
    from { opacity: 0; }
    to { opacity: 1; }
}

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

@keyframes toastIn {
    from { opacity: 0; transform: translateX(24px); }
    to { opacity: 1; transform: translateX(0); }
}

.toast--leaving {
    opacity: 0;
    transition: opacity 350ms var(--sp-ease-out);
}

.value-lg { font-weight: 700; font-size: var(--sp-text-lg); }
.empty-placeholder { color: var(--sp-text-tertiary); text-align: center; padding: var(--sp-space-8); }
.loading-text { color: var(--sp-text-secondary); padding: var(--sp-space-4); }

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

.admin-layout {
    scrollbar-width: thin;
    scrollbar-color: var(--sp-scrollbar-thumb) var(--sp-scrollbar-track);
}

.live-feed,
.activity-feed,
.alert-list,
.table-scroll {
    scrollbar-gutter: stable;
}

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

}

@layer reset {
*, *::before, *::after { box-sizing: border-box; }
body {
    margin: 0;
    font-family: var(--sp-font-family);
    color: var(--sp-text-primary);
    background: var(--sp-bg-base);
    line-height: 1.5;

}
}

@layer base {
.admin-layout {
    display: flex;
    height: 100vh;
    overflow: hidden;
    background: var(--sp-bg-base);
    color: var(--sp-text-primary);
    font-family: var(--sp-font-family);
    font-size: var(--sp-text-base);
    line-height: 1.5;

}

.admin-main {
    flex: 1;
    min-width: 0;
    overflow-y: auto;
    overflow-x: hidden;
    background: var(--sp-bg-main-gradient);
    position: relative;
    display: flex;
    flex-direction: column;
    contain: layout style;
}

.sr-only {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}

.admin-main > *:not(.admin-footer) {
    padding-left: var(--sp-space-10);
    padding-right: var(--sp-space-10);
}

header.admin-header,
.admin-main > .admin-header {
    padding-top: var(--sp-space-8);
}

.admin-main > .admin-footer {
    margin-top: auto;
}

.admin-main::before,
.admin-main::after {
    content: '';
    position: fixed;
    pointer-events: none;
    z-index: var(--sp-z-sticky);
}

.admin-main::before {
    top: 0;
    left: 220px;
    right: 0;
    bottom: 0;
    background: var(--sp-bg-main-accent-tl);
}

.admin-main::after {
    top: 0;
    left: 220px;
    right: 0;
    bottom: 0;
    background: var(--sp-bg-main-accent-br);
}

.admin-main > * {
    position: relative;
    z-index: var(--sp-z-sticky);
}

.admin-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    z-index: var(--sp-z-sticky-header);
    margin-bottom: var(--sp-space-7);
    padding-bottom: var(--sp-space-5);
    border-bottom: none;
    background-image: linear-gradient(90deg, var(--sp-border-subtle), var(--sp-border-subtle), transparent);
    background-size: 100% 1px;
    background-position: bottom;
    background-repeat: no-repeat;
}

.admin-header h1 {
    font-size: var(--sp-text-xl);
    font-weight: 600;
    margin: 0;
    color: var(--sp-text-primary);
    letter-spacing: -0.01em;
    font-family: var(--sp-font-heading);
    flex: 1;
}

.header-actions {
    display: flex;
    align-items: center;
    gap: var(--sp-space-2);
}

}

@layer utilities {

.loading-shimmer {
    background: linear-gradient(90deg, var(--sp-shimmer-from) 25%, var(--sp-shimmer-via) 50%, var(--sp-shimmer-to) 75%);
    background-size: 200% 100%;
    animation: shimmer 1.5s ease-in-out infinite;
    border-radius: var(--sp-radius-sm);
}

.admin-main .table-container,
.admin-main .metric-ribbon,
.admin-main .cc-tabs,
.admin-main .toolbar,
.admin-main .usage-chart-container,
.admin-main .cc-stats-bar {
    margin-left: calc(-1 * var(--sp-space-6));
    border-radius: 0 0.375rem 1.125rem 0;
    border-left: none;
}

.admin-main .cc-tabs {
    border-radius: 0 var(--sp-radius-brand-tr) 0 0;
}

.admin-main .toolbar .search-input,
.admin-main .toolbar .filter-select {
    border-radius: 0 var(--sp-radius-button) var(--sp-radius-button) 0;
}

.admin-main .card,
.admin-main .alert-section,
.admin-main .quick-stat-card,
.admin-main .stat-card,
.admin-main .sf-session-card,
.admin-main .realtime-pulse-card {
    border-radius: 0 0.375rem 1.125rem 0;
}

.admin-main .card-header {
    border-radius: 0 var(--sp-radius-brand-tr) 0 0;
}

.admin-main .dashboard-grid,
.admin-main .stats-grid-3col,
.admin-main .quick-stats-grid,
.admin-main .realtime-pulse-grid,
.admin-main .health-cards,
.admin-main .dashboard-stats {
    margin-left: calc(-1 * var(--sp-space-6));
    padding-left: var(--sp-space-6);
}

.admin-main .dashboard-tabs {
    margin-left: calc(-1 * var(--sp-space-6));
}

.admin-main .dashboard-two-col,
.admin-main .alerts-row {
    margin-left: calc(-1 * var(--sp-space-6));
    padding-left: var(--sp-space-6);
}

.admin-main .card .table-container,
.admin-main .card-body--flush .table-container {
    margin-left: 0;
    border-radius: 0;
    border-left: none;
}

.admin-main .dashboard-two-col > *:nth-child(2n) > .card,
.admin-main .dashboard-two-col > *:nth-child(2n) > .table-container,
.admin-main .alerts-row > *:nth-child(2n) {
    border-radius: var(--sp-radius-card-brand);
    border-left: 1px solid var(--sp-border-subtle);
    margin-left: 0;
}

.admin-main .alert-danger {
    border-left: 4px solid var(--sp-danger);
}
.admin-main .alert-warning {
    border-left: 4px solid var(--sp-warning);
}

.px-6 { padding-left: var(--sp-space-6); padding-right: var(--sp-space-6); }

.entity-row-checkbox { width: 16px; height: 16px; cursor: pointer; accent-color: var(--sp-accent); }
.events-row { cursor: pointer; }
.events-row:hover { background: var(--sp-accent-dim); }
.events-detail-row > td { padding: 0; background: var(--sp-bg-surface-raised); }
.group-header-row { background: var(--sp-bg-surface-raised); font-weight: 600; }
.group-header-row td { border-bottom: 2px solid var(--sp-border-default); }

.field-label {
    font-size: var(--sp-text-sm);
    font-weight: 600;
    color: var(--sp-text-primary);
    margin-bottom: var(--sp-space-1);
    display: block;
}
.field-input {
    width: 100%;
    padding: var(--sp-space-2) var(--sp-space-3);
    font-size: var(--sp-text-sm);
    font-family: inherit;
    color: var(--sp-text-primary);
    background: var(--sp-bg-surface);
    border: 1px solid var(--sp-border-default);
    border-radius: var(--sp-radius-button);
    transition: border-color var(--sp-duration-fast);
}
.field-input:focus { outline: none; border-color: var(--sp-accent); box-shadow: 0 0 0 2px color-mix(in oklch, var(--sp-accent) 20%, transparent); }
}

@layer utilities {
.text-semibold { font-weight: 600; }
.text-bold { font-weight: 700; }
.text-center { text-align: center; }
.text-right { text-align: right; }
.text-danger { color: var(--sp-danger); }
.text-success { color: var(--sp-success); }
.text-warning { color: var(--sp-warning); }
.text-muted { color: var(--sp-text-secondary); }
.text-tertiary { color: var(--sp-text-tertiary); }
.text-accent { color: var(--sp-accent); }
.text-xs { font-size: var(--sp-text-xs); }
.text-sm { font-size: var(--sp-text-sm); }
.text-lg { font-size: var(--sp-text-lg); }
.link-accent { color: var(--sp-accent); text-decoration: none; }
.clickable { cursor: pointer; }
.relative { position: relative; }
.flex { display: flex; }
.flex-col { display: flex; flex-direction: column; }
.flex-1 { flex: 1; }
.flex-wrap { flex-wrap: wrap; }
.items-start { align-items: flex-start; }
.items-center { align-items: center; }
.justify-between { justify-content: space-between; }
.gap-1 { gap: var(--sp-space-1); }
.gap-2 { gap: var(--sp-space-2); }
.gap-3 { gap: var(--sp-space-3); }
.gap-4 { gap: var(--sp-space-4); }
.gap-6 { gap: var(--sp-space-6); }
.mt-1 { margin-top: var(--sp-space-1); }
.mt-2 { margin-top: var(--sp-space-2); }
.mt-3 { margin-top: var(--sp-space-3); }
.mt-4 { margin-top: var(--sp-space-4); }
.mt-6 { margin-top: var(--sp-space-6); }
.mt-8 { margin-top: var(--sp-space-8); }
.mb-0 { margin-bottom: 0; }
.mb-2 { margin-bottom: var(--sp-space-2); }
.mb-3 { margin-bottom: var(--sp-space-3); }
.mb-4 { margin-bottom: var(--sp-space-4); }
.mb-6 { margin-bottom: var(--sp-space-6); }
.mb-8 { margin-bottom: var(--sp-space-8); }
.ml-auto { margin-left: auto; }
.m-0 { margin: 0; }
.p-3 { padding: var(--sp-space-3); }
.p-4 { padding: var(--sp-space-4); }
.p-6 { padding: var(--sp-space-6); }
.p-8 { padding: var(--sp-space-8); }
.w-full { width: 100%; }
.hidden { display: none; }
.block { display: block; }
.inline-block { display: inline-block; }
.border-top { border-top: 1px solid var(--sp-border-subtle); }
.border-bottom { border-bottom: 1px solid var(--sp-border-subtle); }
.rounded { border-radius: var(--sp-radius-sm); }
.overflow-auto { overflow: auto; }
.overflow-x-auto { overflow-x: auto; }
.truncate { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.no-wrap { white-space: nowrap; }
.empty-center { text-align: center; padding: var(--sp-space-12); color: var(--sp-text-tertiary); }
.font-mono { font-family: 'Menlo', 'Consolas', monospace; }
.grid-2col { display: grid; grid-template-columns: 1fr 1fr; gap: var(--sp-space-3); }
.grid-auto-fill { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: var(--sp-space-4); }
.grid-3col { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--sp-space-3); }
.p-5 { padding: var(--sp-space-5); }
.stat-label { font-size: var(--sp-text-xs); color: var(--sp-text-tertiary); }
.stat-value { font-size: var(--sp-text-lg); font-weight: 700; color: var(--sp-text-primary); }
.card-title { font-weight: 600; font-size: var(--sp-text-md); color: var(--sp-text-primary); margin-bottom: var(--sp-space-3); }
.col-rank { width: 40px; }
.col-number { text-align: right; }
.sp-skip-link {
    position: absolute;
    top: -100%;
    left: var(--sp-space-2);
    padding: var(--sp-space-2) var(--sp-space-4);
    background: var(--sp-accent);
    color: var(--sp-text-on-accent);
    border-radius: 0 0 var(--sp-radius-sm) var(--sp-radius-sm);
    z-index: var(--sp-z-toast);
    text-decoration: none;
    font-weight: 600;
    transition: top var(--sp-duration-fast) var(--sp-ease-out);
}
.sp-skip-link:focus-visible {
    top: 0;
}

.sr-only {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}

.health-value,
.metric-ribbon-value,
.stat-card .value,
.bar-value,
.skill-bar-count {
    font-variant-numeric: tabular-nums;
    font-feature-settings: "tnum";
}

}

@layer components {

.sidebar-toggle {
    display: none;
    background: none;
    border: none;
    color: var(--sp-text-secondary);
    cursor: pointer;
    padding: var(--sp-space-2);
    border-radius: var(--sp-radius-sm);
    min-width: 44px;
    min-height: 44px;
    align-items: center;
    justify-content: center;
    transition: color var(--sp-duration-fast), background var(--sp-duration-fast);
    flex-shrink: 0;
}

.sidebar-toggle:hover {
    background: var(--sp-accent-dim);
    color: var(--sp-text-primary);
}

.sidebar-toggle:focus-visible {
    outline: none;
    box-shadow: 0 0 0 2px var(--sp-bg-canvas), 0 0 0 4px var(--sp-accent);
}

.sidebar-overlay {
    display: none;
    position: fixed;
    inset: 0;
    background: oklch(0 0 0 / 0);
    z-index: var(--sp-z-sidebar);
    transition: background var(--sp-duration-slow) var(--sp-ease-in-out);
}

.sidebar-overlay.open {
    display: block;
    background: var(--sp-overlay-light);
    backdrop-filter: blur(2px);
}

.sidebar-close-btn {
    display: none;
    position: absolute;
    top: var(--sp-space-3);
    right: var(--sp-space-3);
    width: 36px;
    height: 36px;
    border: none;
    background: light-dark(var(--sp-primitive-warm-200), oklch(1.00 0 0 / 0.1));
    color: var(--sp-sidebar-text);
    border-radius: var(--sp-radius-sm);
    cursor: pointer;
    font-size: var(--sp-text-md);
    line-height: 1;
    z-index: var(--sp-z-sticky);
    align-items: center;
    justify-content: center;
    transition: background var(--sp-duration-fast), color var(--sp-duration-fast);
}

.sidebar-close-btn:hover {
    background: light-dark(var(--sp-primitive-warm-300), oklch(1.00 0 0 / 0.15));
    color: var(--sp-sidebar-text-hover);
}

.sidebar-close-btn:focus-visible {
    outline: none;
    box-shadow: 0 0 0 2px var(--sp-sidebar-bg), 0 0 0 4px var(--sp-sidebar-active-color);
}

.admin-sidebar {
    scrollbar-width: thin;
    scrollbar-color: light-dark(var(--sp-primitive-warm-300), oklch(1.00 0 0 / 0.15)) transparent;
}

.sidebar-footer {
    padding: var(--sp-space-3) var(--sp-space-4);
    border-top: 1px solid var(--sp-sidebar-border);
    flex-shrink: 0;
}

.theme-toggle {
    display: flex;
    align-items: center;
    gap: var(--sp-space-3);
    width: 100%;
    padding: var(--sp-space-2) var(--sp-space-3);
    border: none;
    border-radius: var(--sp-radius-sm);
    background: transparent;
    color: var(--sp-sidebar-text);
    font-size: var(--sp-text-sm);
    font-weight: 500;
    font-family: inherit;
    cursor: pointer;
    transition: background var(--sp-duration-fast) var(--sp-ease-in-out),
                color var(--sp-duration-fast) var(--sp-ease-in-out);
}

.theme-toggle:hover {
    background: var(--sp-sidebar-hover-bg);
    color: var(--sp-sidebar-text-hover);
    border-radius: var(--sp-radius-button);
}

.theme-toggle:focus-visible {
    outline: none;
    box-shadow: 0 0 0 2px var(--sp-sidebar-bg), 0 0 0 4px var(--sp-sidebar-active-color);
}

.theme-icon {
    width: 16px;
    height: 16px;
    flex-shrink: 0;
    opacity: 0.6;
    transition: opacity var(--sp-duration-fast);
}

.theme-toggle:hover .theme-icon {
    opacity: 0.85;
}

.theme-icon--dark { display: none; }

[data-theme="dark"] .theme-icon--light { display: none; }
[data-theme="dark"] .theme-icon--dark { display: inline; }

@media (prefers-reduced-motion: reduce) {
    .sidebar-overlay {
        transition: none;
    }
}

}

@layer components {
.admin-sidebar {
    width: 220px;
    background: var(--sp-sidebar-bg);
    border-right: 1px solid var(--sp-sidebar-border);
    box-shadow: light-dark(none, inset -1px 0 0 oklch(1.00 0 0 / 0.04));
    padding: 0;
    flex-shrink: 0;
    overflow-y: auto;
    display: flex;
    flex-direction: column;
}

.admin-sidebar-brand {
    padding: var(--sp-space-6) var(--sp-space-5);
    text-decoration: none;
    display: flex;
    align-items: center;
    border-bottom: 1px solid var(--sp-sidebar-border);
    background: light-dark(none, linear-gradient(180deg, oklch(1.00 0 0 / 0.03) 0%, transparent 100%));
}

.admin-logo {
    width: 160px;
    height: auto;
}

.admin-logo--dark { display: none; }
[data-theme="dark"] .admin-logo--light { display: none; }
[data-theme="dark"] .admin-logo--dark { display: inline; }

.admin-sidebar nav {
    flex: 1;
    padding: var(--sp-space-3) 0;
}

.nav-label {
    padding: var(--sp-space-5) var(--sp-space-5) var(--sp-space-2);
    font-size: var(--sp-text-xs);
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--sp-sidebar-text-muted);
}

.nav-label:first-child {
    padding-top: var(--sp-space-3);
}

.admin-sidebar nav h2.nav-label:nth-of-type(1) { color: var(--sp-nav-label-1); }
.admin-sidebar nav h2.nav-label:nth-of-type(2) { color: var(--sp-nav-label-2); }
.admin-sidebar nav h2.nav-label:nth-of-type(3) { color: var(--sp-nav-label-3); }
.admin-sidebar nav h2.nav-label:nth-of-type(4) { color: var(--sp-nav-label-4); }
.admin-sidebar nav h2.nav-label:nth-of-type(5) { color: var(--sp-nav-label-5); }

h2.nav-label {
    margin: 0;
    font-weight: inherit;
}

.nav-label-sub {
    font-size: var(--sp-text-xs);
    padding: var(--sp-space-4) var(--sp-space-5) var(--sp-space-1);
}

.admin-sidebar nav a {
    display: flex;
    align-items: center;
    gap: var(--sp-space-3);
    padding: var(--sp-space-2) var(--sp-space-5);
    margin: 0.0625rem var(--sp-space-2);
    color: var(--sp-sidebar-text);
    text-decoration: none;
    transition: background var(--sp-duration-fast) var(--sp-ease-in-out),
                color var(--sp-duration-fast) var(--sp-ease-in-out);
    font-size: var(--sp-text-sm);
    font-weight: 500;
    border-radius: var(--sp-radius-sm);
    min-width: 0;
    overflow: hidden;
}

.admin-sidebar nav a:hover {
    background: var(--sp-sidebar-hover-bg);
    color: var(--sp-sidebar-text-hover);
}

.admin-sidebar nav a.active {
    background: var(--sp-sidebar-active-bg);
    color: var(--sp-sidebar-active-color);
    font-weight: 600;
    position: relative;
    padding-left: var(--sp-space-5);
}

.admin-sidebar nav a.active::before {
    content: '';
    position: absolute;
    left: 0;
    top: 20%;
    bottom: 20%;
    width: 3px;
    border-radius: var(--sp-radius-full);
    background: var(--sp-sidebar-active-color);
    box-shadow: 0 0 8px color-mix(in oklch, var(--sp-sidebar-active-color) 40%, transparent);
}

.admin-sidebar nav a .icon {
    width: 16px;
    height: 16px;
    flex-shrink: 0;
    opacity: 0.6;
    transition: opacity var(--sp-duration-fast);
}

.admin-sidebar nav a:hover .icon { opacity: 0.85; }
.admin-sidebar nav a.active .icon { opacity: 1; }

.admin-sidebar nav a:focus-visible {
    outline: none;
    box-shadow: 0 0 0 2px var(--sp-sidebar-bg), 0 0 0 4px var(--sp-sidebar-active-color);
}

.nav-badge {
    margin-left: auto;
    flex-shrink: 0;
    background: color-mix(in oklch, var(--sp-danger) 20%, transparent);
    color: var(--sp-nav-badge-text);
    font-size: var(--sp-text-xs);
    font-weight: 600;
    padding: 0.0625rem 0.4375rem;
    border-radius: var(--sp-radius-full);
}

}

@layer components {
.table-container {
    background: var(--sp-bg-surface);
    border: 1px solid var(--sp-border-subtle);
    border-radius: var(--sp-radius-card-brand);
    overflow-x: auto;
    overflow-y: auto;
    max-height: calc(100vh - 230px);
    max-width: 100%;
}

.table-scroll {
    overflow-x: auto;
    overflow-y: auto;
    max-height: calc(100vh - 230px);
}

.admin-main > .table-container {
    flex: 1 1 0;
    min-height: 200px;
    display: flex;
    flex-direction: column;
}

.admin-main > .table-container > .table-scroll {
    flex: 1 1 0;
    min-height: 0;
    max-height: none;
}

.data-table {
    min-width: 100%;
    border-collapse: collapse;
    table-layout: auto;
}

.data-table .col-thumbnail   { width: 56px; min-width: 56px; max-width: 56px; }
.data-table .col-date        { width: 100px; min-width: 90px; }
.data-table .col-currency    { width: 110px; min-width: 95px; }
.data-table .col-status      { width: 110px; min-width: 90px; }
.data-table .col-boolean     { width: 70px; min-width: 60px; }
.data-table .col-badge_count { width: 80px; min-width: 70px; }
.data-table .col-tags        { width: 150px; min-width: 120px; }
.data-table .col-text        { min-width: 100px; }

.data-table th {
    background: var(--sp-bg-card-header);
    padding: var(--sp-space-3) var(--sp-space-4);
    text-align: left;
    font-size: var(--sp-text-xs);
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--sp-text-tertiary);
    border-bottom: 1px solid var(--sp-border-default);
    background-image: linear-gradient(90deg, transparent, var(--sp-border-subtle), transparent);
    background-size: 100% 1px;
    background-position: bottom;
    background-repeat: no-repeat;
    cursor: pointer;
    user-select: none;
    white-space: nowrap;
    position: sticky;
    top: 0;
    z-index: var(--sp-z-sticky);
}

.data-table th:hover {
    color: var(--sp-text-secondary);
}

.data-table th .sort-icon {
    display: inline-block;
    margin-left: var(--sp-space-1);
    opacity: 0.3;
    transition: opacity var(--sp-duration-fast);
}

.data-table th.sorted .sort-icon {
    opacity: 1;
    color: var(--sp-accent);
}

.data-table td {
    padding: var(--sp-space-3) var(--sp-space-4);
    border-bottom: 1px solid var(--sp-border-subtle);
    font-size: var(--sp-text-sm);
    line-height: 1.5;
    color: var(--sp-text-secondary);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.data-table td.truncate {
    max-width: 250px;
    overflow: hidden;
    text-overflow: ellipsis;
}

.data-table td:first-child {
    color: var(--sp-text-primary);
    font-weight: 500;
}

.data-table tbody tr:nth-child(even) td {
    background: color-mix(in oklch, var(--sp-warm-900) 2%, transparent);
}

.data-table tr:hover td {
    background: color-mix(in oklch, var(--sp-warm-900) 4%, transparent);
}

.data-table tbody tr:hover td:first-child {
    box-shadow: inset 3px 0 0 var(--sp-section-color);
}

.data-table tr.selected td {
    background: var(--sp-accent-dim);
}

.data-table tbody tr:nth-child(even) td.col-actions,
.data-table tr:hover td.col-actions,
.data-table .clickable-row:hover td.col-actions {
    background: var(--sp-bg-surface);
}

.data-table td.col-actions {
    white-space: nowrap;
    text-align: center;
    padding: var(--sp-space-2) var(--sp-space-3) var(--sp-space-2) var(--sp-space-4);
    position: sticky;
    right: 0;
    background: var(--sp-bg-surface);
    border-left: 1px solid var(--sp-border-subtle);
    z-index: var(--sp-z-sticky-header);
    vertical-align: middle;
}

.data-table th.col-actions {
    width: 60px;
    text-align: center;
    position: sticky;
    right: 0;
    background: var(--sp-bg-surface-raised);
    border-left: 1px solid var(--sp-border-subtle);
    z-index: var(--sp-z-sticky-header);
}

.data-table td.numeric {
    text-align: right;
    font-variant-numeric: tabular-nums;
}

.data-table td.date {
    white-space: nowrap;
    color: var(--sp-text-tertiary);
}

.data-table th.numeric { text-align: right; }

.data-table th.rate-col,
.data-table td.rate-col {
    text-align: right;
    min-width: 120px;
    white-space: nowrap;
}

.data-table .empty-state {
    text-align: center;
    padding: var(--sp-space-12) var(--sp-space-4);
    color: var(--sp-text-tertiary);
    font-size: var(--sp-text-base);
}

.clickable-row {
    cursor: pointer;
    transition: background var(--sp-duration-fast);
}

.clickable-row:hover td {
    background: var(--sp-accent-dim);
}

}

@layer components {

.badge-purple {
    background: var(--sp-badge-purple-dim);
    color: var(--sp-badge-purple);
}

.badge-blue {
    background: var(--sp-accent-dim);
    color: var(--sp-accent);
}

.badge-yellow {
    background: var(--sp-warning-dim);
    color: var(--sp-warning);
}

.evolution-card {
    background: var(--sp-bg-surface);
    border: 1px solid var(--sp-border-subtle);
    border-radius: var(--sp-radius-card-brand);
    padding: var(--sp-space-5);
    margin-bottom: var(--sp-space-5);
}

.evolution-card h4 {
    color: var(--sp-text-primary);
}

.evolution-table {
    font-size: var(--sp-text-sm);
}

.insurance-badge {
    font-size: var(--sp-text-xs);
    margin-left: var(--sp-space-1);
    vertical-align: middle;
}

.table-preview {
    max-height: 200px;
    overflow: auto;
}

.detail-data-table {
    width: 100%;
    font-size: var(--sp-text-sm);
    border-collapse: collapse;
}
.detail-data-table th,
.detail-data-table td {
    padding: var(--sp-space-2) var(--sp-space-1);
}
.detail-data-table thead tr {
    text-align: left;
    border-bottom: 2px solid var(--sp-border-default);
}
.detail-data-table tbody tr {
    border-bottom: 1px solid var(--sp-border-default);
}

@media (max-width: 768px) {
    .table-container {
        margin-left: calc(-1 * var(--sp-space-3));
        margin-right: calc(-1 * var(--sp-space-3));
        border-radius: 0;
        border-left: none;
        border-right: none;
        overflow-x: auto;
        overflow-y: visible;
    }

    
    .admin-main > .table-container {
        flex: none;
        min-height: 0;
    }

    .admin-main > .table-container > .table-scroll {
        flex: none;
        max-height: 60vh;
    }

    .table-scroll {
        max-height: 60vh;
        overflow-x: auto;
    }

    .data-table th {
        padding: var(--sp-space-2) var(--sp-space-3);
        font-size: var(--sp-text-xs);
    }

    .data-table td {
        padding: var(--sp-space-2) var(--sp-space-3);
        font-size: var(--sp-text-sm);
    }

    .data-table td.col-actions {
        padding: var(--sp-space-1) var(--sp-space-2);
    }

    .col-checkbox input[type="checkbox"] {
        min-width: 44px;
        min-height: 44px;
    }

    .pagination {
        flex-direction: column;
        gap: var(--sp-space-2);
        padding: var(--sp-space-2) var(--sp-space-3);
        font-size: var(--sp-text-xs);
    }

    .pagination-controls button {
        min-width: 44px;
        min-height: 44px;
    }
}

@media (max-width: 767px) {
    .data-table th:first-child,
    .data-table td:first-child {
        position: sticky;
        left: 0;
        z-index: 1;
        background: var(--sp-bg-surface);
    }

    .data-table th:first-child {
        background: var(--sp-bg-card-header);
    }
}

@media (max-width: 480px) {
    .table-container {
        margin-left: calc(-1 * var(--sp-space-2));
        margin-right: calc(-1 * var(--sp-space-2));
    }
}

}

@layer components {

.pagination {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: var(--sp-space-3) var(--sp-space-4);
    border-top: 1px solid var(--sp-border-subtle);
    font-size: var(--sp-text-sm);
    color: var(--sp-text-secondary);
}

.pagination-info {
    display: flex;
    align-items: center;
    gap: var(--sp-space-4);
}

.pagination-controls {
    display: flex;
    align-items: center;
    gap: var(--sp-space-1);
}

.pagination-controls button {
    background: none;
    border: 1px solid var(--sp-border-default);
    border-radius: var(--sp-radius-button);
    color: var(--sp-text-secondary);
    padding: var(--sp-space-1) var(--sp-space-3);
    cursor: pointer;
    font-size: var(--sp-text-sm);
    font-family: inherit;
    transition: background var(--sp-duration-fast), border-color var(--sp-duration-fast), color var(--sp-duration-fast);
}

.pagination-controls button:hover:not(:disabled) {
    background: color-mix(in oklch, var(--sp-warm-900) 4%, transparent);
    border-color: var(--sp-border-strong);
    color: var(--sp-text-primary);
}

.pagination-controls button:disabled {
    opacity: 0.3;
    cursor: default;
}

.pagination-controls .current-page {
    padding: var(--sp-space-1) var(--sp-space-3);
    color: var(--sp-accent);
    font-weight: 600;
}

.per-page-select {
    background: transparent;
    border: 1px solid var(--sp-border-default);
    border-radius: var(--sp-radius-button);
    color: var(--sp-text-secondary);
    padding: var(--sp-space-1) var(--sp-space-2);
    font-size: var(--sp-text-sm);
    font-family: inherit;
}

.per-page-select:focus-visible,
.pagination-controls button:focus-visible {
    outline: none;
    box-shadow: 0 0 0 2px var(--sp-bg-canvas), 0 0 0 4px var(--sp-accent);
}

.data-table tfoot tr {
    background: var(--sp-bg-surface-raised);
}

.data-table tfoot td {
    background: inherit;
    border-top: 2px solid var(--sp-border-default);
    border-bottom: none;
    font-weight: 700;
    color: var(--sp-text-primary);
    padding: var(--sp-space-3) var(--sp-space-4);
    font-size: var(--sp-text-sm);
    white-space: nowrap;
}

.data-table tfoot td.col-actions {
    background: inherit;
}

.invoice-link {
    color: var(--sp-accent);
    text-decoration: none;
    font-weight: 600;
}

.invoice-link:hover {
    text-decoration: underline;
    opacity: 0.85;
}

.data-table .thumbnail-cell {
    width: 56px;
    padding: var(--sp-space-1);
    text-align: center;
}

.table-thumbnail {
    width: 48px;
    height: 36px;
    object-fit: cover;
    border-radius: var(--sp-radius-sm);
    border: 1px solid var(--sp-border-subtle);
}

.table-thumbnail-empty {
    display: inline-block;
    width: 48px;
    height: 36px;
    line-height: 36px;
    text-align: center;
    color: var(--sp-text-tertiary);
}

.data-table .col-checkbox {
    width: 40px;
    min-width: 40px;
    max-width: 40px;
    text-align: center;
    padding: var(--sp-space-2);
}

.col-checkbox input[type="checkbox"] {
    width: 16px;
    height: 16px;
}

.data-table .col-multiline {
    white-space: normal;
    line-height: 1.4;
}

.cell-primary {
    font-weight: 500;
    color: var(--sp-text-primary);
}

.cell-secondary {
    font-size: 0.8em;
    color: var(--sp-text-tertiary);
    margin-top: 0.125rem;
}

}

@layer components {

.activity-feed {
    background: var(--sp-bg-surface-gradient);
    border: 1px solid var(--sp-border-subtle);
    border-radius: var(--sp-radius-card-brand);
    padding: var(--sp-space-4);
    max-height: 360px;
    overflow-y: auto;
    box-shadow: var(--sp-shadow-card), var(--sp-shadow-inner-glow);
}

.activity-item {
    display: flex;
    align-items: flex-start;
    gap: var(--sp-space-3);
    padding: var(--sp-space-3) 0;
    border-bottom: 1px solid var(--sp-border-subtle);
}

.activity-item:last-child { border-bottom: none; }

.activity-icon {
    width: 32px;
    height: 32px;
    border-radius: var(--sp-radius-full);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: var(--sp-text-xs);
    font-weight: 700;
    flex-shrink: 0;
    letter-spacing: 0.02em;
}

.activity-green {
    background: linear-gradient(135deg, var(--sp-success-dim), color-mix(in oklch, var(--sp-success-dim) 60%, var(--sp-bg-surface)));
    color: var(--sp-success);
    box-shadow: 0 2px 6px color-mix(in oklch, var(--sp-success) 15%, transparent);
}

.activity-amber {
    background: linear-gradient(135deg, var(--sp-warning-dim), color-mix(in oklch, var(--sp-warning-dim) 60%, var(--sp-bg-surface)));
    color: var(--sp-warning);
    box-shadow: 0 2px 6px color-mix(in oklch, var(--sp-warning) 15%, transparent);
}

.activity-red {
    background: linear-gradient(135deg, var(--sp-danger-dim), color-mix(in oklch, var(--sp-danger-dim) 60%, var(--sp-bg-surface)));
    color: var(--sp-danger);
    box-shadow: 0 2px 6px color-mix(in oklch, var(--sp-danger) 15%, transparent);
}

.activity-content { flex: 1; min-width: 0; }

.activity-text {
    font-size: var(--sp-text-sm);
    color: var(--sp-text-secondary);
    display: block;
}

.activity-time {
    font-size: var(--sp-text-xs);
    color: var(--sp-text-tertiary);
    margin-top: 0.125rem;
}


.live-dot {
    display: inline-block;
    width: 8px;
    height: 8px;
    border-radius: var(--sp-radius-full);
    background: var(--sp-success);
    margin-left: var(--sp-space-2);
    vertical-align: middle;
    position: relative;
}

.live-dot::after {
    content: '';
    position: absolute;
    inset: -3px;
    border-radius: var(--sp-radius-full);
    border: 2px solid var(--sp-success);
    animation: livePing 2s cubic-bezier(0, 0, 0.2, 1) infinite;
}

.live-dot.disconnected::after {
    animation: none;
    border-color: var(--sp-danger);
}

.live-dot.disconnected {
    background: var(--sp-danger);
}

@keyframes livePing {
    0% { transform: scale(1); opacity: 0.6; }
    75%, 100% { transform: scale(2); opacity: 0; }
}

.live-feed {
    max-height: 360px;
    overflow-y: auto;
}

.feed-item {
    display: flex;
    align-items: center;
    gap: var(--sp-space-2);
    padding: var(--sp-space-3) var(--sp-space-4);
    border-radius: var(--sp-radius-sm);
    transition: background var(--sp-duration-fast),
                padding-left var(--sp-duration-fast),
                border-left var(--sp-duration-fast);
}

.feed-item + .feed-item {
    margin-top: 0;
    border-top: 1px solid color-mix(in oklch, var(--sp-border-subtle) 40%, transparent);
}

.feed-item:hover {
    background: color-mix(in oklch, var(--sp-warm-900) 3%, transparent);
    padding-left: calc(var(--sp-space-4) + 0.125rem);
    border-left: 2px solid var(--sp-accent);
    border-radius: 0;
}

.feed-item.new-item {
    animation: feedSlideIn 0.3s var(--sp-ease-out);
}

@keyframes feedSlideIn {
    from { opacity: 0; transform: translateY(-12px) scale(0.98); background: var(--sp-accent-dim); }
    to { opacity: 1; transform: translateY(0) scale(1); background: transparent; }
}

.feed-icon {
    width: 12px;
    height: 12px;
    border-radius: var(--sp-radius-full);
    flex-shrink: 0;
    box-shadow: 0 0 8px currentColor;
}

.feed-blue { background: var(--sp-accent); }
.feed-purple { background: var(--sp-feed-purple); }
.feed-green { background: var(--sp-success); }
.feed-orange { background: var(--sp-warning); }
.feed-cyan { background: var(--sp-feed-cyan); }
.feed-indigo { background: var(--sp-feed-indigo); }
.feed-teal { background: var(--sp-success); }
.feed-gold { background: var(--sp-feed-gold); }

.feed-content {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    flex: 1;
    min-width: 0;
    gap: var(--sp-space-2);
}

.feed-text {
    font-size: var(--sp-text-sm);
    color: var(--sp-text-secondary);
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.feed-time {
    font-size: var(--sp-text-xs);
    color: var(--sp-text-tertiary);
    flex-shrink: 0;
}

.feed-item--error {
    border-left: 3px solid var(--sp-danger);
    background: color-mix(in oklch, var(--sp-danger) 3%, transparent);
}

@media (prefers-reduced-motion: reduce) {
    .live-dot::after {
        animation: none;
    }
    .feed-item.new-item {
        animation: none;
    }
}

}

@layer components {


.usage-chart-container {
    background: var(--sp-bg-surface-gradient);
    border: 1px solid var(--sp-border-subtle);
    border-radius: var(--sp-radius-card-brand);
    padding: var(--sp-space-6);
    margin-bottom: var(--sp-space-6);
    position: relative;
    overflow: hidden;
    box-shadow: var(--sp-shadow-elevated);
    contain: layout style;
    min-height: 340px;
}

.usage-chart-container::before {
    content: '';
    position: absolute;
    top: 0;
    left: var(--sp-space-6);
    right: var(--sp-space-6);
    height: 2px;
    background: linear-gradient(90deg, transparent, var(--sp-accent), transparent);
    border-radius: 0 0 var(--sp-radius-xs) var(--sp-radius-xs);
    opacity: 0.6;
}

.usage-chart-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: var(--sp-space-5);
    flex-wrap: wrap;
    gap: var(--sp-space-3);
}

.usage-chart-title {
    font-size: var(--sp-text-lg);
    font-weight: 700;
    color: var(--sp-text-primary);
}

.usage-chart-legend {
    display: flex;
    gap: var(--sp-space-4);
    flex-wrap: wrap;
}

.legend-item {
    font-size: var(--sp-text-xs);
    color: var(--sp-text-secondary);
    display: flex;
    align-items: center;
    gap: var(--sp-space-1);
}

.legend-item::before {
    content: '';
    width: 10px;
    height: 10px;
    border-radius: var(--sp-radius-xs);
}

.legend-sessions::before { background: var(--sp-chart-purple); }
.legend-active-users::before { background: var(--sp-chart-green); }
.legend-prompts::before { background: var(--sp-chart-blue); }
.legend-tools::before { background: var(--sp-accent); }
.legend-errors::before { background: var(--sp-chart-red); }

.chart-range-tabs {
    display: flex;
    gap: var(--sp-space-1);
}

.chart-range-tab {
    padding: var(--sp-space-1) var(--sp-space-3);
    font-size: var(--sp-text-xs);
    font-weight: 600;
    color: var(--sp-text-tertiary);
    background: transparent;
    border: 1px solid var(--sp-border-subtle);
    border-radius: var(--sp-radius-button);
    text-decoration: none;
    transition: color var(--sp-duration-fast), background var(--sp-duration-fast), border-color var(--sp-duration-fast), box-shadow var(--sp-duration-fast);
    cursor: pointer;
}

.chart-range-tab:hover {
    color: var(--sp-text-secondary);
    border-color: var(--sp-border-default);
}

.chart-range-tab.active {
    color: var(--sp-accent);
    background: var(--sp-accent-dim);
    border-color: color-mix(in oklch, var(--sp-accent) 40%, transparent);
    box-shadow: 0 1px 3px color-mix(in oklch, var(--sp-accent) 20%, transparent);
    font-weight: 700;
}

.usage-chart-peak {
    font-size: var(--sp-text-xs);
    color: var(--sp-text-tertiary);
    font-variant-numeric: tabular-nums;
}

.usage-chart-body {
    position: relative;
}

.usage-chart-empty {
    display: flex;
    align-items: center;
    justify-content: center;
    height: 240px;
    color: var(--sp-text-tertiary);
    font-size: var(--sp-text-sm);
}

.usage-svg {
    width: 100%;
    height: 240px;
    display: block;
}

.area-path {
    opacity: 0;
    animation: areaFadeIn 1.2s var(--sp-ease-out) forwards;
}

.area-path:nth-child(8) { animation-delay: 0s; }
.area-path:nth-child(9) { animation-delay: 0.1s; }
.area-path:nth-child(10) { animation-delay: 0.2s; }
.area-path:nth-child(11) { animation-delay: 0.3s; }
.area-path:nth-child(12) { animation-delay: 0.4s; }

.line-path {
    stroke-dasharray: 3000;
    stroke-dashoffset: 3000;
    animation: lineReveal 2s var(--sp-ease-out) 0.5s forwards;
}

@keyframes areaFadeIn {
    from { opacity: 0; }
    to { opacity: 1; }
}

@keyframes lineReveal {
    to { stroke-dashoffset: 0; }
}

.chart-grid-line {
    stroke: var(--sp-border-subtle);
    stroke-width: 0.5;
}

.area-sessions { fill: url(#grad-sessions); }
.area-active-users { fill: url(#grad-active-users); }
.area-prompts { fill: url(#grad-prompts); }
.area-tools { fill: url(#grad-tools); }
.area-errors { fill: url(#grad-errors); }
.line-top { stroke: var(--sp-accent); }

.chart-axis-label {
    font-size: var(--sp-text-xs);
    fill: var(--sp-text-tertiary);
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', system-ui, sans-serif;
    font-variant-numeric: tabular-nums;
}

.usage-chart-x-axis {
    display: flex;
    justify-content: space-between;
    padding-top: var(--sp-space-2);
    font-size: var(--sp-text-xs);
    color: var(--sp-text-tertiary);
    font-family: var(--sp-font-family);
    font-variant-numeric: tabular-nums;
}

@media (prefers-reduced-motion: reduce) {
    .area-path {
        animation: none;
        opacity: 1;
    }
    .line-path {
        animation: none;
        stroke-dasharray: none;
        stroke-dashoffset: 0;
    }
}

}

@layer components {

.form-group {
    margin-bottom: var(--sp-space-4);
}

.form-group label {
    display: block;
    font-size: var(--sp-text-sm);
    font-weight: 500;
    margin-bottom: var(--sp-space-1);
    color: var(--sp-text-secondary);
}

.form-input {
    width: 100%;
    padding: var(--sp-space-2) var(--sp-space-4);
    border: 1px solid var(--sp-border-default);
    border-radius: var(--sp-radius-sm);
    font-size: var(--sp-text-sm);
    background: var(--sp-bg-surface);
    color: var(--sp-text-primary);
    font-family: inherit;
    outline: none;
    box-sizing: border-box;
    transition: border-color var(--sp-duration-fast), box-shadow var(--sp-duration-fast);
}

.form-input:focus-visible {
    border-color: var(--sp-accent);
    outline: 2px solid var(--sp-accent-dim);
    outline-offset: -1px;
}

.form-input[readonly] {
    background: var(--sp-bg-surface-raised);
    color: var(--sp-text-tertiary);
    cursor: not-allowed;
}

.form-textarea {
    width: 100%;
    padding: var(--sp-space-2) var(--sp-space-4);
    border: 1px solid var(--sp-border-default);
    border-radius: var(--sp-radius-sm);
    font-size: var(--sp-text-sm);
    font-family: monospace;
    background: var(--sp-bg-surface);
    color: var(--sp-text-primary);
    resize: vertical;
    outline: none;
    box-sizing: border-box;
    transition: border-color var(--sp-duration-fast), box-shadow var(--sp-duration-fast);
}

.form-textarea:focus-visible {
    border-color: var(--sp-accent);
    outline: 2px solid var(--sp-accent-dim);
    outline-offset: -1px;
}

.form-actions {
    display: flex;
    gap: var(--sp-space-3);
    margin-top: var(--sp-space-6);
}

.toggle-switch {
    position: relative;
    display: inline-block;
    width: 44px;
    height: 24px;
    vertical-align: middle;
}

.toggle-switch input {
    opacity: 0;
    width: 0;
    height: 0;
}

.toggle-slider {
    position: absolute;
    cursor: pointer;
    inset: 0;
    background: var(--sp-border-default);
    border-radius: var(--sp-radius-xl);
    transition: background var(--sp-duration-normal);
}

.toggle-slider::before {
    content: '';
    position: absolute;
    height: 18px;
    width: 18px;
    left: 3px;
    bottom: 3px;
    background: var(--sp-toggle-knob);
    border-radius: var(--sp-radius-full);
    transition: transform var(--sp-duration-normal);
}

.toggle-switch input:checked + .toggle-slider {
    background: var(--sp-success);
}

.toggle-switch input:checked + .toggle-slider::before {
    transform: translateX(20px);
}

.skill-editor {
    max-width: 800px;
}


.checklist-item {
    display: flex;
    align-items: center;
    gap: var(--sp-space-2);
    padding: var(--sp-space-1) var(--sp-space-2);
}

.checklist-item input[type="checkbox"] {
    flex-shrink: 0;
    width: 16px;
    height: 16px;
    margin: 0;
    cursor: pointer;
}

.checklist-item label {
    display: inline;
    margin-bottom: 0;
    font-size: var(--sp-text-sm);
    cursor: pointer;
}

}

@layer components {


.health-cards {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--sp-space-3);
    margin-bottom: var(--sp-space-4);
}

.health-card {
    background: var(--sp-bg-surface-gradient);
    border: 1px solid var(--sp-border-subtle);
    border-radius: var(--sp-radius-card-inner-brand);
    padding: var(--sp-space-5) var(--sp-space-4);
    text-align: center;
    box-shadow: var(--sp-shadow-card), var(--sp-shadow-inner-glow);
    position: relative;
    overflow: hidden;
    transition: transform var(--sp-duration-fast) var(--sp-ease-out),
                box-shadow var(--sp-duration-fast);
}

.health-card::before {
    content: '';
    position: absolute;
    top: 0;
    left: 15%;
    right: 15%;
    height: 2px;
    background: linear-gradient(90deg, transparent, var(--sp-border-strong), transparent);
    border-radius: 0 0 var(--sp-radius-xs) var(--sp-radius-xs);
}

.health-card:hover {
    transform: translateY(-1px);
    box-shadow: var(--sp-shadow-md);
}

.health-label {
    font-size: var(--sp-text-xs);
    color: var(--sp-text-tertiary);
    letter-spacing: 0.02em;
    margin-bottom: var(--sp-space-2);
}

.health-value {
    font-size: var(--sp-text-xl);
    font-weight: 700;
    color: var(--sp-text-primary);
    font-variant-numeric: tabular-nums;
    line-height: 1.2;
    margin-bottom: var(--sp-space-1);
}

.health-bar {
    height: 4px;
    background: color-mix(in oklch, var(--sp-warm-900) 6%, transparent);
    border-radius: var(--sp-radius-xs);
    margin-top: var(--sp-space-2);
    overflow: hidden;
}

.health-bar-fill {
    height: 100%;
    width: var(--sp-fill);
    border-radius: var(--sp-radius-xs);
    transition: width 600ms var(--sp-ease-out);
}

.health-bar-success {
    background: linear-gradient(90deg, var(--sp-progress-green-from), var(--sp-progress-green-to));
    box-shadow: 0 0 6px color-mix(in oklch, var(--sp-progress-green-from) 40%, transparent);
}

.health-bar-danger {
    background: linear-gradient(90deg, var(--sp-progress-red-from), var(--sp-progress-red-to));
    box-shadow: 0 0 6px color-mix(in oklch, var(--sp-progress-red-from) 40%, transparent);
}


.mini-chart {
    display: flex;
    align-items: flex-end;
    gap: 0.125rem;
    height: 120px;
    padding-bottom: var(--sp-space-4);
}

.mini-chart-bar {
    flex: 1;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: flex-end;
    height: 100%;
    position: relative;
}

.mini-chart-fill {
    width: 100%;
    height: var(--sp-fill);
    background: linear-gradient(180deg, var(--sp-accent), var(--sp-primary-700));
    border-radius: var(--sp-radius-xs) var(--sp-radius-xs) 1px 1px;
    min-height: 2px;
    transition: height 600ms var(--sp-ease-out);
}

.mini-chart-bar:hover .mini-chart-fill {
    background: linear-gradient(180deg, var(--sp-primary-400), var(--sp-accent));
    box-shadow: 0 -3px 8px color-mix(in oklch, var(--sp-accent) 35%, transparent);
}

.mini-chart-label {
    font-size: var(--sp-text-xs);
    color: var(--sp-text-tertiary);
    margin-top: var(--sp-space-1);
    height: 14px;
}

}

@layer components {

.dashboard-two-col {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--sp-space-6);
    margin-bottom: var(--sp-space-6);
}

.dashboard-two-col > div > .table-container {
    max-height: 360px;
}

.dashboard-two-col > div > .table-container > .table-scroll {
    max-height: 360px;
}

.dashboard-two-col .col-rank {
    width: 48px;
    min-width: 48px;
}

.dashboard-two-col .data-table {
    width: 100%;
}

.dashboard-two-col .data-table th:nth-child(1) { width: 48px; }
.dashboard-two-col .data-table th:nth-child(2) { width: auto; }
.dashboard-two-col .data-table th:nth-child(3) { width: 80px; }

@media (max-width: 768px) {
    .dashboard-two-col {
        grid-template-columns: 1fr;
    }
    .quick-stats-grid {
        grid-template-columns: 1fr;
    }
}

@media (min-width: 1200px) {
    .dashboard-two-col {
        grid-template-columns: 1fr 1fr;
    }
}

.empty-state {
    text-align: center;
    padding: var(--sp-space-12);
    color: var(--sp-text-tertiary);
}

.cc-tab-panel--loading {
    opacity: 0.5;
    pointer-events: none;
    transition: opacity 150ms ease;
}

}

@layer components {

.dashboard-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: var(--sp-space-4);
    margin-bottom: var(--sp-space-7);
}

.quick-stats-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: var(--sp-space-3);
    margin-bottom: var(--sp-space-4);
}

.quick-stat-card {
    background: var(--sp-bg-surface-gradient);
    border: 1px solid var(--sp-border-subtle);
    border-radius: var(--sp-radius-card-brand);
    padding: var(--sp-space-4);
    box-shadow: var(--sp-shadow-card), var(--sp-shadow-inner-glow);
    contain: layout style;
    transition: transform var(--sp-duration-fast) var(--sp-ease-out),
                border-color var(--sp-duration-fast),
                box-shadow var(--sp-duration-fast);
}

.quick-stat-card:hover {
    transform: translateY(-1px);
    border-color: var(--sp-border-default);
    box-shadow: var(--sp-shadow-card-hover);
}

.quick-stat-label {
    font-size: var(--sp-text-xs);
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--sp-text-secondary);
    margin-bottom: var(--sp-space-2);
}

.quick-stat-value {
    font-size: var(--sp-text-2xl);
    font-weight: 700;
    font-variant-numeric: tabular-nums;
    color: var(--sp-text-primary);
}

.dashboard-grid-2col {
    grid-template-columns: repeat(2, 1fr);
}

.progress-cell {
    min-width: 120px;
}

.alerts-row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--sp-space-4);
    margin-bottom: var(--sp-space-6);
}

.alert-section {
    background: var(--sp-bg-surface);
    border: 1px solid var(--sp-border-subtle);
    border-radius: var(--sp-radius-card-brand);
    padding: var(--sp-space-5);
    overflow: hidden;
    border-left: 4px solid transparent;
    box-shadow: var(--sp-shadow-card);
}

.alert-section h3 {
    font-size: var(--sp-text-sm);
    font-weight: 600;
    margin: 0 0 var(--sp-space-3);
}

.alert-danger { border-left-color: var(--sp-danger); }
.alert-danger h3 { color: var(--sp-danger); }
.alert-warning { border-left-color: var(--sp-warning); }
.alert-warning h3 { color: var(--sp-warning); }

.alert-list {
    display: flex;
    flex-direction: column;
    gap: var(--sp-space-1);
    max-height: 260px;
    overflow-y: auto;
}

.alert-item {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: var(--sp-space-2) var(--sp-space-3);
    background: color-mix(in oklch, var(--sp-warm-900) 2%, transparent);
    border-radius: var(--sp-radius-sm);
    gap: var(--sp-space-3);
    transition: background var(--sp-duration-fast);
}

.alert-item:hover { background: color-mix(in oklch, var(--sp-warm-900) 4%, transparent); }

.alert-item-main {
    display: flex;
    flex-direction: column;
    gap: 0.0625rem;
    min-width: 0;
    flex: 1;
}

.alert-item-title {
    font-size: var(--sp-text-sm);
    font-weight: 500;
    color: var(--sp-text-primary);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.alert-item-subtitle {
    font-size: var(--sp-text-xs);
    color: var(--sp-text-tertiary);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.alert-item-value {
    font-size: var(--sp-text-sm);
    font-weight: 600;
    text-align: right;
    white-space: nowrap;
    flex-shrink: 0;
}

.alert-danger .alert-item-value { color: var(--sp-danger); }
.alert-warning .alert-item-value { color: var(--sp-warning); }

.alert-link {
    display: inline-block;
    margin-top: var(--sp-space-3);
    font-size: var(--sp-text-sm);
    color: var(--sp-accent);
    text-decoration: none;
    font-weight: 500;
    transition: opacity var(--sp-duration-fast);
}

.alert-link:hover { opacity: 0.8; }


.dashboard-two-col {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--sp-space-6);
    margin-bottom: var(--sp-space-6);
}

.dashboard-two-col > div {
    min-width: 0;
}

.dashboard-two-col > div > .table-container {
    max-height: 360px;
}

.dashboard-two-col > div > .table-container > .table-scroll {
    max-height: 360px;
}

.dashboard-two-col .col-rank {
    width: 48px;
    min-width: 48px;
}

.dashboard-two-col .data-table {
    width: 100%;
}

.dashboard-two-col .data-table th:nth-child(1) { width: 48px; }
.dashboard-two-col .data-table th:nth-child(2) { width: auto; }
.dashboard-two-col .data-table th:nth-child(3) { width: 80px; }

@media (max-width: 768px) {
    .dashboard-two-col {
        grid-template-columns: 1fr;
    }
    .quick-stats-grid {
        grid-template-columns: 1fr;
    }
}

@media (min-width: 1200px) {
    .dashboard-two-col {
        grid-template-columns: 1fr 1fr;
    }
}

.empty-state {
    text-align: center;
    padding: var(--sp-space-12);
    color: var(--sp-text-tertiary);
}

.cc-tab-panel--loading {
    opacity: 0.5;
    pointer-events: none;
    transition: opacity 150ms ease;
}

}

@layer components {


.metric-ribbon {
    display: flex;
    gap: 0;
    margin-bottom: var(--sp-space-6);
    padding: 0;
    background: var(--sp-bg-surface-overlay);
    border: 1px solid var(--sp-border-default);
    border-top: 2px solid var(--sp-accent);
    border-radius: var(--sp-radius-widget-brand);
    overflow: hidden;
    box-shadow: var(--sp-shadow-elevated), var(--sp-shadow-inner-glow);
    font-variant-numeric: tabular-nums;
}

.metric-ribbon-item {
    display: flex;
    flex-direction: column;
    align-items: center;
    padding: var(--sp-space-5) var(--sp-space-6);
    min-width: 80px;
    flex: 1;
    position: relative;
    transition: background var(--sp-duration-fast);
}

.metric-ribbon-item::after {
    content: '';
    position: absolute;
    right: 0;
    top: 20%;
    bottom: 20%;
    width: 1px;
    background: linear-gradient(180deg, transparent, var(--sp-border-default), transparent);
}

.metric-ribbon-item:last-child::after {
    display: none;
}

.metric-ribbon-item:hover {
    background: color-mix(in oklch, var(--sp-warm-900) 2%, transparent);
}

.metric-ribbon-value {
    font-size: var(--sp-text-2xl);
    font-weight: 700;
    color: var(--sp-text-primary);
    line-height: 1.1;
}

.metric-ribbon-label {
    font-size: var(--sp-text-xs);
    color: var(--sp-text-tertiary);
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    margin-top: var(--sp-space-1);
}

.metric-ribbon-delta {
    font-size: var(--sp-text-xs);
    color: var(--sp-text-secondary);
    font-weight: 500;
    margin-top: 0.125rem;
    font-variant-numeric: tabular-nums;
}

.metric-ribbon-delta:empty {
    display: none;
}

.metric-ribbon-period {
    font-size: var(--sp-text-xs);
    color: var(--sp-text-muted, var(--sp-text-tertiary));
    font-weight: 400;
    margin-top: 0.0625rem;
}

.metric-ribbon-period:empty {
    display: none;
}

.metric-ribbon-danger .metric-ribbon-value { color: color-mix(in oklch, var(--sp-danger) 85%, var(--sp-text-primary)); }
.metric-ribbon-accent .metric-ribbon-value { color: color-mix(in oklch, var(--sp-accent) 85%, var(--sp-text-primary)); }

@keyframes metricFlash {
    0% { color: var(--sp-accent); transform: scale(1.15); }
    100% { transform: scale(1); }
}

.metric-flash { animation: metricFlash 0.6s var(--sp-ease-out); }

.metric-ribbon-health--healthy .metric-ribbon-value {
    color: oklch(0.65 0.2 145);
}
.metric-ribbon-health--warning .metric-ribbon-value {
    color: oklch(0.75 0.15 65);
}
.metric-ribbon-health--critical .metric-ribbon-value {
    color: oklch(0.65 0.25 25);
}

}

@layer components {


.detail-item {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: var(--sp-space-3) var(--sp-space-4);
    border-bottom: 1px solid var(--sp-border-subtle);
    gap: var(--sp-space-3);
    transition: background var(--sp-duration-fast);
}

.detail-item:last-child {
    border-bottom: none;
}

.detail-item:hover {
    background: color-mix(in oklch, var(--sp-warm-900) 3%, transparent);
}

.detail-item-info {
    flex: 1;
    min-width: 0;
}

.detail-item-name {
    font-size: var(--sp-text-sm);
    font-weight: 500;
    color: var(--sp-text-primary);
    display: flex;
    align-items: center;
    gap: var(--sp-space-2);
    flex-wrap: wrap;
}

.detail-item-desc {
    font-size: var(--sp-text-sm);
    color: var(--sp-text-secondary);
    margin-top: var(--sp-space-1);
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}


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

.plugin-header .expand-icon {
    flex-shrink: 0;
    margin-top: var(--sp-space-1);
}


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

.plugin-action-btn {
    background: transparent;
    border: 1px solid var(--sp-border-default);
    border-radius: var(--sp-radius-sm);
    color: var(--sp-text-secondary);
    font-size: var(--sp-text-xs);
    font-weight: 500;
    font-family: inherit;
    padding: var(--sp-space-1) var(--sp-space-3);
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    gap: var(--sp-space-1);
    transition: background var(--sp-duration-fast), border-color var(--sp-duration-fast), color var(--sp-duration-fast);
    white-space: nowrap;
}

.plugin-action-btn:hover {
    background: color-mix(in oklch, var(--sp-warm-900) 4%, transparent);
    border-color: var(--sp-border-strong);
    color: var(--sp-text-primary);
}

.plugin-action-btn--export {
    border-color: color-mix(in oklch, var(--sp-section-export) 30%, transparent);
    color: var(--sp-section-export);
}

.plugin-action-btn--export:hover {
    background: color-mix(in oklch, var(--sp-section-export) 10%, transparent);
    border-color: var(--sp-section-export);
}

.plugin-action-btn--danger {
    border-color: color-mix(in oklch, var(--sp-danger) 30%, transparent);
    color: var(--sp-danger);
}

.plugin-action-btn--danger:hover {
    background: var(--sp-danger-dim);
    border-color: var(--sp-danger);
}

}

@layer components {

.plugin-cards {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
    gap: var(--sp-space-4);
}

.plugin-card {
    background: var(--sp-bg-surface-gradient);
    border: 1px solid var(--sp-border-subtle);
    border-radius: var(--sp-radius-card-brand);
    overflow: visible;
    box-shadow: var(--sp-shadow-card), var(--sp-shadow-inner-glow);
    transition: border-color var(--sp-duration-fast), box-shadow var(--sp-duration-fast);
}

.plugin-card:hover {
    border-color: var(--sp-border-default);
    box-shadow: var(--sp-shadow-card-hover);
}

.plugin-header {
    padding: var(--sp-space-5) var(--sp-space-6);
    cursor: pointer;
    transition: background var(--sp-duration-fast);
    overflow: visible;
    position: relative;
}

.plugin-header:hover {
    background: color-mix(in oklch, var(--sp-warm-900) 2%, transparent);
}

.plugin-details {
    padding: 0 var(--sp-space-6) var(--sp-space-6);
}

.plugin-section-title {
    font-size: var(--sp-text-xs);
    font-weight: 600;
    color: var(--sp-text-tertiary);
    text-transform: uppercase;
    letter-spacing: 0.04em;
    margin-bottom: var(--sp-space-2);
}

.plugin-skill-item {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: var(--sp-space-2) 0;
    font-size: var(--sp-text-sm);
    color: var(--sp-text-secondary);
    border-bottom: 1px solid var(--sp-border-subtle);
}

.plugin-skill-item:last-child {
    border-bottom: none;
}

.skill-source-badge {
    font-size: var(--sp-text-xs);
    font-weight: 600;
    padding: 0.125rem var(--sp-space-2);
    border-radius: var(--sp-radius-full);
    background: var(--sp-accent-dim);
    color: var(--sp-accent);
}

.property-cell {
    display: flex;
    align-items: center;
    gap: var(--sp-space-3);
}

.property-avatar {
    width: 32px;
    height: 32px;
    border-radius: var(--sp-radius-sm);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: var(--sp-text-sm);
    font-weight: 700;
    color: var(--sp-text-on-dark);
    flex-shrink: 0;
}

.property-name {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}


.plugin-tab {
    background: transparent;
    border: 1px solid var(--sp-border-default);
    border-radius: var(--sp-radius-sm);
    padding: var(--sp-space-2) var(--sp-space-4);
    font-size: var(--sp-text-sm);
    font-weight: 500;
    font-family: inherit;
    color: var(--sp-text-secondary);
    cursor: pointer;
    transition: background var(--sp-duration-fast) var(--sp-ease-in-out),
                border-color var(--sp-duration-fast) var(--sp-ease-in-out),
                color var(--sp-duration-fast) var(--sp-ease-in-out);
}

.plugin-tab:hover {
    background: color-mix(in oklch, var(--sp-warm-900) 4%, transparent);
    border-color: var(--sp-border-strong);
    color: var(--sp-text-primary);
}

.plugin-tab.active {
    background: var(--sp-accent-dim);
    border-color: var(--sp-accent);
    color: var(--sp-accent);
}

.plugin-tab-count {
    font-weight: 700;
    margin-left: 0.125rem;
}

}

@layer components {

@media (max-width: 768px) {
    .traffic-kpi-grid {
        grid-template-columns: repeat(2, 1fr);
        gap: var(--sp-space-2);
    }
    .traffic-kpi-card {
        padding: var(--sp-space-3);
    }
    .kpi-value {
        font-size: var(--sp-text-base);
    }
    .kpi-label {
        font-size: var(--sp-text-xs);
    }
    .kpi-trend {
        font-size: var(--sp-text-xs);
    }
}

@media (max-width: 640px) {
    .realtime-pulse-grid {
        grid-template-columns: repeat(3, 1fr);
        gap: 0;
        margin-bottom: var(--sp-space-4);
        background: var(--sp-bg-surface-overlay);
        border: 1px solid var(--sp-border-subtle);
        border-radius: var(--sp-radius-card-brand);
        overflow: hidden;
    }
    .realtime-pulse-card {
        background: none;
        border: none;
        border-radius: 0;
        padding: var(--sp-space-3) var(--sp-space-2);
        box-shadow: none;
        position: relative;
    }
    .realtime-pulse-card:hover {
        transform: none;
        box-shadow: none;
    }
    .realtime-pulse-card:not(:last-child)::after {
        content: '';
        position: absolute;
        right: 0;
        top: 20%;
        bottom: 20%;
        width: 1px;
        background: linear-gradient(180deg, transparent, var(--sp-border-default), transparent);
    }
    .pulse-value {
        font-size: var(--sp-text-lg);
    }
    .pulse-label {
        font-size: 0.6rem;
        letter-spacing: 0.02em;
        line-height: 1.2;
        overflow: hidden;
        display: -webkit-box;
        -webkit-line-clamp: 2;
        -webkit-box-orient: vertical;
    }
    .quick-stats-grid {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 480px) {
    .stats-grid-3col {
        grid-template-columns: 1fr;
    }

    .health-cards,
    .dashboard-stats {
        grid-template-columns: 1fr;
    }

    .stat-card {
        padding: var(--sp-space-2) var(--sp-space-3);
    }

    .cc-hero-title {
        font-size: var(--sp-text-lg);
    }

    .cc-hero-actions {
        flex-direction: column;
        align-items: stretch;
    }

    .cc-stats-grid {
        grid-template-columns: 1fr 1fr;
    }
}

}

@layer components {


@media (max-width: 768px) {
    .dashboard-grid {
        grid-template-columns: 1fr;
        gap: var(--sp-space-2);
        margin-bottom: var(--sp-space-3);
    }

    .stats-grid-3col {
        grid-template-columns: 1fr;
        gap: var(--sp-space-2);
    }

    .dashboard-two-col,
    .cc-three-col,
    .cc-main-grid,
    .detail-grid,
    .alerts-row {
        grid-template-columns: 1fr;
    }

    .cc-stats-bar {
        gap: var(--sp-space-2);
        padding: var(--sp-space-2) var(--sp-space-3);
    }

    .cc-stat-value {
        font-size: var(--sp-text-base);
    }

    .cc-hero {
        padding: var(--sp-space-6) var(--sp-space-4);
    }

    .health-cards {
        grid-template-columns: 1fr 1fr;
    }

    .dashboard-stats {
        grid-template-columns: 1fr 1fr;
    }

    .stat-card {
        padding: var(--sp-space-3) var(--sp-space-4);
    }

    .stat-card .value {
        font-size: var(--sp-text-lg);
    }

    .stat-card .label {
        margin-bottom: var(--sp-space-1);
    }

    .kpi-subtitle {
        font-size: var(--sp-text-xs);
    }

    .metric-ribbon {
        padding: 0;
        flex-wrap: nowrap;
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
        scrollbar-width: none;
    }

    .metric-ribbon::-webkit-scrollbar { display: none; }

    .metric-ribbon-item {
        flex: 0 0 auto;
        min-width: 120px;
        padding: var(--sp-space-3) var(--sp-space-4);
    }

    .metric-ribbon-value {
        font-size: var(--sp-text-base);
    }

    .skill-bar-label {
        min-width: 80px;
        flex: 0 1 auto;
        max-width: 40%;
    }

    .skill-bar-track {
        min-width: 0;
    }

    .dashboard-two-col .card {
        overflow: visible;
    }

    .usage-chart-header {
        flex-direction: column;
        align-items: flex-start;
        gap: var(--sp-space-2);
    }

    .alert-section {
        padding: var(--sp-space-3);
    }

    .alert-section h3 {
        margin-bottom: var(--sp-space-2);
        font-size: var(--sp-text-xs);
    }

    .alert-list {
        max-height: 200px;
    }

    .activity-feed {
        padding: var(--sp-space-3);
        max-height: 280px;
    }

    .activity-item {
        gap: var(--sp-space-2);
        padding: var(--sp-space-2) 0;
    }

    .activity-icon {
        width: 24px;
        height: 24px;
        font-size: var(--sp-text-xs);
    }

    .cc-feed-icon {
        width: 24px;
        height: 24px;
    }

    .cc-feed-icon svg {
        width: 12px;
        height: 12px;
    }

    .cc-session-stats {
        flex-wrap: wrap;
        gap: var(--sp-space-2);
    }

    .sf-session-header {
        padding: var(--sp-space-3);
        gap: var(--sp-space-2);
        flex-wrap: wrap;
    }

    .sf-session-badges {
        order: 10;
        width: 100%;
    }

    .sf-turns {
        padding: var(--sp-space-3);
    }

    .sf-tools-bar {
        padding: var(--sp-space-2) var(--sp-space-3);
    }

    .card {
        border-color: var(--sp-border-default);
        background: var(--sp-bg-surface);
    }

    .feed-item {
        align-items: flex-start;
        padding: var(--sp-space-2) var(--sp-space-3);
    }

    .feed-icon {
        width: 10px;
        height: 10px;
        margin-top: var(--sp-space-1);
        box-shadow: none;
    }

    .feed-content {
        flex-direction: column;
        gap: var(--sp-space-1);
    }

    .feed-text {
        white-space: normal;
        word-break: break-word;
    }
}

}

@layer components {

.stat-card {
    background: var(--sp-bg-surface-gradient);
    border: 1px solid var(--sp-border-subtle);
    border-radius: var(--sp-radius-card-brand);
    padding: var(--sp-space-6);
    position: relative;
    overflow: hidden;
    box-shadow: var(--sp-shadow-card), var(--sp-shadow-inner-glow);
    transition: transform var(--sp-duration-fast) var(--sp-ease-out),
                border-color var(--sp-duration-fast),
                box-shadow var(--sp-duration-fast);
}

.stat-card:hover {
    transform: translateY(-1px);
    border-color: var(--sp-border-default);
    box-shadow: var(--sp-shadow-card-hover);
}

.stat-card::before {
    content: '';
    position: absolute;
    top: var(--sp-space-4);
    left: 0;
    bottom: var(--sp-space-4);
    width: 4px;
    border-radius: 0 var(--sp-radius-xs) var(--sp-radius-xs) 0;
    background: var(--sp-accent);
    box-shadow: 3px 0 8px -2px var(--sp-accent);
    opacity: 0.8;
}

.stat-card.success::before { background: var(--sp-success); }
.stat-card.warning::before { background: var(--sp-warning); }
.stat-card.error::before { background: var(--sp-danger); }

.stat-card .label {
    font-size: var(--sp-text-xs);
    color: var(--sp-text-secondary);
    text-transform: uppercase;
    letter-spacing: 0.06em;
    font-weight: 600;
    margin-bottom: var(--sp-space-2);
}

.stat-card .value {
    font-size: var(--sp-text-2xl);
    font-weight: 700;
    color: var(--sp-text-primary);
    font-variant-numeric: tabular-nums;
    letter-spacing: -0.02em;
    line-height: 1.2;
}

.stat-card .value.currency::before {
    content: '\20AC';
    font-size: var(--sp-text-lg);
    margin-right: 0.125rem;
    opacity: 0.5;
}

.kpi-subtitle {
    font-size: var(--sp-text-sm);
    color: var(--sp-text-tertiary);
    margin-top: var(--sp-space-1);
}

.progress-bar {
    height: 5px;
    background: color-mix(in oklch, var(--sp-warm-900) 6%, transparent);
    border-radius: var(--sp-radius-xs);
    overflow: hidden;
    display: inline-block;
    width: 100%;
    vertical-align: middle;
    box-shadow: var(--sp-shadow-inset-sm);
}

.progress-fill {
    height: 100%;
    width: var(--sp-fill);
    border-radius: var(--sp-radius-xs);
    transition: width 600ms var(--sp-ease-out);
    box-shadow: 0 0 4px color-mix(in oklch, currentColor 25%, transparent);
}

.progress-green { background: linear-gradient(90deg, var(--sp-progress-green-from), var(--sp-progress-green-to)); }
.progress-amber { background: linear-gradient(90deg, var(--sp-progress-amber-from), var(--sp-progress-amber-to)); }
.progress-red { background: linear-gradient(90deg, var(--sp-progress-red-from), var(--sp-progress-red-to)); }
.progress-blue { background: linear-gradient(90deg, var(--sp-accent), var(--sp-primary-400)); }


.dashboard-stats {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: var(--sp-space-4);
    margin-bottom: var(--sp-space-6);
}


.trend-up {
    color: var(--sp-success);
    font-size: var(--sp-text-xs);
    margin-left: 0.125rem;
}

.trend-down {
    color: var(--sp-danger);
    font-size: var(--sp-text-xs);
    margin-left: 0.125rem;
}

}

@layer components {


.leaderboard-rank {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 26px;
    height: 26px;
    border-radius: var(--sp-radius-full);
    font-size: var(--sp-text-xs);
    font-weight: 700;
    color: var(--sp-text-tertiary);
    background: color-mix(in oklch, var(--sp-warm-900) 6%, transparent);
    transition: transform var(--sp-duration-fast) var(--sp-ease-out);
}

.leaderboard-rank-1 {
    width: 26px;
    height: 26px;
    font-size: var(--sp-text-xs);
    background: linear-gradient(135deg, var(--sp-warning-dim), color-mix(in oklch, var(--sp-warning) 20%, var(--sp-warning-dim)));
    color: var(--sp-warning);
}

.leaderboard-rank-1:hover {
    box-shadow: 0 2px 8px color-mix(in oklch, var(--sp-warning) 25%, transparent);
}

.leaderboard-rank-2 {
    width: 24px;
    height: 24px;
    background: linear-gradient(135deg, var(--sp-accent-dim), color-mix(in oklch, var(--sp-accent) 15%, var(--sp-accent-dim)));
    color: var(--sp-accent);
}

.leaderboard-rank-2:hover {
    box-shadow: 0 2px 6px color-mix(in oklch, var(--sp-accent) 20%, transparent);
}

.leaderboard-rank-3 {
    width: 24px;
    height: 24px;
    background: linear-gradient(135deg, var(--sp-success-dim), color-mix(in oklch, var(--sp-success) 15%, var(--sp-success-dim)));
    color: var(--sp-success);
}

.leaderboard-rank-3:hover {
    box-shadow: 0 2px 6px color-mix(in oklch, var(--sp-success) 20%, transparent);
}


.bar-row {
    display: flex;
    align-items: center;
    gap: var(--sp-space-3);
    padding: var(--sp-space-2) 0;
    border-bottom: 1px solid var(--sp-border-subtle);
}

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

.bar-label {
    width: 120px;
    flex-shrink: 0;
    font-size: var(--sp-text-sm);
    font-weight: 500;
    color: var(--sp-text-secondary);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.bar-track {
    flex: 1;
    height: 6px;
    background: color-mix(in oklch, var(--sp-warm-900) 6%, transparent);
    border-radius: var(--sp-radius-xs);
    overflow: hidden;
}

.bar-fill {
    height: 100%;
    width: var(--sp-fill);
    background: linear-gradient(90deg, var(--sp-accent), var(--sp-primary-400));
    border-radius: var(--sp-radius-xs);
    transition: width 600ms var(--sp-ease-out);
    box-shadow: 0 1px 3px color-mix(in oklch, var(--sp-accent) 20%, transparent);
}

.bar-value {
    flex-shrink: 0;
    font-size: var(--sp-text-xs);
    color: var(--sp-text-tertiary);
    font-variant-numeric: tabular-nums;
    white-space: nowrap;
}


.dept-table {
    width: 100%;
    border-collapse: collapse;
}

.dept-table th {
    font-size: var(--sp-text-xs);
    color: var(--sp-text-tertiary);
    text-transform: uppercase;
    letter-spacing: 0.04em;
    font-weight: 600;
    padding: var(--sp-space-2) var(--sp-space-3);
    text-align: right;
    border-bottom: 1px solid var(--sp-border-subtle);
}

.dept-table th:first-child {
    text-align: left;
}

.dept-table td {
    font-size: var(--sp-text-sm);
    color: var(--sp-text-secondary);
    padding: var(--sp-space-3);
    border-bottom: 1px solid var(--sp-border-subtle);
    text-align: right;
    font-variant-numeric: tabular-nums;
}

.dept-table td:first-child {
    text-align: left;
    font-weight: 500;
    color: var(--sp-text-primary);
}

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

.dept-table tr:hover td {
    background: color-mix(in oklch, var(--sp-warm-900) 2%, transparent);
}

.dept-bar-cell {
    min-width: 80px;
}


.skill-bar-row {
    display: flex;
    align-items: center;
    gap: var(--sp-space-3);
    padding: var(--sp-space-2) 0;
    border-bottom: 1px solid var(--sp-border-subtle);
}

.skill-bar-row:last-child { border-bottom: none; }

.skill-bar-label {
    min-width: 120px;
    flex: 1;
    font-size: var(--sp-text-sm);
    font-weight: 500;
    color: var(--sp-text-secondary);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.skill-bar-track { flex: 1; }

.skill-bar-count {
    width: 40px;
    text-align: right;
    font-size: var(--sp-text-sm);
    font-weight: 600;
    color: var(--sp-text-primary);
    font-variant-numeric: tabular-nums;
}

}

@layer components {
    .traffic-period-selector,
    .content-period-selector {
        display: flex;
        gap: var(--sp-space-2);
        margin-bottom: var(--sp-space-5);
    }

    .traffic-kpi-grid {
        display: grid;
        grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
        gap: var(--sp-space-4);
        margin-bottom: var(--sp-space-5);
    }

    .traffic-kpi-card {
        background: var(--sp-bg-surface-gradient);
        border: 1px solid var(--sp-border-subtle);
        border-radius: var(--sp-radius-card-brand);
        padding: var(--sp-space-4) var(--sp-space-5);
        display: flex;
        flex-direction: column;
        gap: var(--sp-space-1);
        box-shadow: var(--sp-shadow-card), var(--sp-shadow-inner-glow);
        contain: layout style;
        transition: transform var(--sp-duration-fast) var(--sp-ease-out),
                    border-color var(--sp-duration-fast),
                    box-shadow var(--sp-duration-fast);
    }

    .traffic-chart-container {
        min-height: 340px;
        contain: layout style;
    }

    .traffic-kpi-card:hover {
        transform: translateY(-1px);
        border-color: var(--sp-border-default);
        box-shadow: var(--sp-shadow-card-hover);
    }

    .kpi-label {
        font-size: var(--sp-text-sm);
        font-weight: 500;
        color: var(--sp-text-tertiary);
        text-transform: uppercase;
        letter-spacing: 0.04em;
    }

    .kpi-value {
        font-size: var(--sp-text-lg);
        font-weight: 700;
        line-height: 1.2;
        color: var(--sp-text-primary);
        font-variant-numeric: tabular-nums;
    }

    .kpi-trend {
        font-size: var(--sp-text-sm);
        font-weight: 500;
        display: flex;
        align-items: center;
        gap: 0.25em;
    }

    .kpi-trend.trend-up {
        color: var(--sp-success);
    }

    .kpi-trend.trend-down {
        color: var(--sp-danger);
    }

    .kpi-trend.trend-flat {
        color: var(--sp-text-tertiary);
    }

    .kpi-arrow {
        font-size: 0.65rem;
    }

    .kpi-period {
        font-size: var(--sp-text-xs);
        color: var(--sp-text-muted, var(--sp-text-tertiary));
        font-weight: 400;
    }

    .top-pages-views {
        font-weight: 700;
        font-variant-numeric: tabular-nums;
    }

    .top-pages-trend {
        font-size: var(--sp-text-xs);
        margin-left: var(--sp-space-1);
    }

    .top-pages-sparkline-col {
        width: 70px;
        padding: 0;
    }

    .top-pages-sparkline-cell {
        padding: var(--sp-space-1) var(--sp-space-2);
        vertical-align: middle;
    }

    @media (max-width: 768px) {
        .top-pages-sparkline-col,
        .top-pages-sparkline-cell {
            display: none;
        }
    }
}

@layer components {
    .realtime-pulse-grid {
        display: grid;
        grid-template-columns: repeat(3, 1fr);
        gap: var(--sp-space-4);
        margin-bottom: var(--sp-space-6);
    }

    .realtime-pulse-card {
        background: var(--sp-bg-surface-gradient);
        border: 1px solid var(--sp-border-subtle);
        border-radius: var(--sp-radius-card-brand);
        padding: var(--sp-space-5);
        text-align: center;
        box-shadow: var(--sp-shadow-card), var(--sp-shadow-inner-glow);
        contain: layout style;
        transition: transform var(--sp-duration-fast) var(--sp-ease-out),
                    border-color var(--sp-duration-fast),
                    box-shadow var(--sp-duration-fast);
    }

    .realtime-pulse-card:hover {
        transform: translateY(-1px);
        border-color: var(--sp-border-default);
        box-shadow: var(--sp-shadow-card-hover);
    }

    .pulse-value {
        font-size: var(--sp-text-xl);
        font-weight: 700;
        font-variant-numeric: tabular-nums;
        line-height: 1.2;
        color: var(--sp-text-primary);
    }

    .pulse-label {
        font-size: var(--sp-text-xs);
        font-weight: 600;
        text-transform: uppercase;
        letter-spacing: 0.04em;
        color: var(--sp-text-tertiary);
        margin-top: var(--sp-space-1);
    }

    .legend-dot {
        display: inline-block;
        width: 8px;
        height: 8px;
        border-radius: var(--sp-radius-full);
        margin-right: var(--sp-space-1);
        vertical-align: middle;
        background: var(--sp-legend-bg);
    }

    .metric-ribbon-traffic .metric-ribbon-value {
        color: var(--sp-chart-green);
    }

    .dashboard-tabs {
        margin-bottom: var(--sp-space-4);
    }

    .dashboard-tabs .cc-tabs {
        margin-bottom: 0;
    }

    .traffic-page-url {
        display: block;
        max-width: min(600px, 70vw);
        overflow: hidden;
        text-overflow: ellipsis;
        white-space: nowrap;
        font-size: 0.85em;
    }

    .top-pages-grid {
        display: flex;
        flex-direction: column;
        gap: var(--sp-space-3);
    }

    .top-page-card {
        background: var(--sp-bg-surface-gradient);
        border: 1px solid var(--sp-border-subtle);
        border-radius: var(--sp-radius-card-brand);
        padding: var(--sp-space-4) var(--sp-space-5);
        box-shadow: var(--sp-shadow-card), var(--sp-shadow-inner-glow);
        contain: layout style;
        transition: transform var(--sp-duration-fast) var(--sp-ease-out),
                    border-color var(--sp-duration-fast);
    }

    .top-page-card:hover {
        transform: translateY(-1px);
        border-color: var(--sp-border-default);
        box-shadow: var(--sp-shadow-card-hover);
    }

    .top-page-header {
        margin-bottom: var(--sp-space-3);
        border-bottom: 1px solid var(--sp-border-subtle);
        padding-bottom: var(--sp-space-2);
    }

    .top-page-url {
        display: block;
        max-width: 100%;
        overflow: hidden;
        text-overflow: ellipsis;
        white-space: nowrap;
        font-size: var(--sp-text-sm);
        font-weight: 600;
        color: var(--sp-text-primary);
    }

    .top-page-horizons {
        display: grid;
        grid-template-columns: repeat(3, 1fr);
        gap: var(--sp-space-4);
    }

    .top-page-horizon {
        display: flex;
        flex-direction: column;
        gap: var(--sp-space-2);
    }

    .horizon-label {
        font-size: var(--sp-text-xs);
        font-weight: 600;
        text-transform: uppercase;
        letter-spacing: 0.04em;
        color: var(--sp-text-tertiary);
    }

    .horizon-sparkline {
        width: 100%;
        min-height: 28px;
    }

    .horizon-metrics {
        display: flex;
        flex-direction: column;
        gap: var(--sp-space-1);
    }

    .horizon-metric {
        display: flex;
        align-items: baseline;
        gap: var(--sp-space-1);
        flex-wrap: wrap;
    }

    .horizon-value {
        font-size: var(--sp-text-base);
        font-weight: 700;
        font-variant-numeric: tabular-nums;
        color: var(--sp-text-primary);
    }

    .horizon-sublabel {
        font-size: var(--sp-text-xs);
        color: var(--sp-text-tertiary);
    }

    @media (max-width: 768px) {
        .traffic-page-url {
            max-width: min(200px, 45vw);
        }
    }

    .progress-fill.progress-purple {
        background: var(--sp-chart-purple);
    }

    .progress-fill.progress-amber {
        background: var(--sp-chart-amber);
    }

    .progress-fill.progress-green {
        background: var(--sp-chart-green);
    }


    .traffic-period-selector,
    .content-period-selector {
        display: flex;
        gap: var(--sp-space-2);
        margin-bottom: var(--sp-space-5);
    }

    .traffic-kpi-grid {
        display: grid;
        grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
        gap: var(--sp-space-4);
        margin-bottom: var(--sp-space-5);
    }

    .traffic-kpi-card {
        background: var(--sp-bg-surface-gradient);
        border: 1px solid var(--sp-border-subtle);
        border-radius: var(--sp-radius-card-brand);
        padding: var(--sp-space-4) var(--sp-space-5);
        display: flex;
        flex-direction: column;
        gap: var(--sp-space-1);
        box-shadow: var(--sp-shadow-card), var(--sp-shadow-inner-glow);
        contain: layout style;
        transition: transform var(--sp-duration-fast) var(--sp-ease-out),
                    border-color var(--sp-duration-fast),
                    box-shadow var(--sp-duration-fast);
    }

    .traffic-chart-container {
        min-height: 340px;
        contain: layout style;
    }

    .traffic-kpi-card:hover {
        transform: translateY(-1px);
        border-color: var(--sp-border-default);
        box-shadow: var(--sp-shadow-card-hover);
    }

    .kpi-label {
        font-size: var(--sp-text-sm);
        font-weight: 500;
        color: var(--sp-text-tertiary);
        text-transform: uppercase;
        letter-spacing: 0.04em;
    }

    .kpi-value {
        font-size: var(--sp-text-lg);
        font-weight: 700;
        line-height: 1.2;
        color: var(--sp-text-primary);
        font-variant-numeric: tabular-nums;
    }

    .kpi-trend {
        font-size: var(--sp-text-sm);
        font-weight: 500;
        display: flex;
        align-items: center;
        gap: 0.25em;
    }

    .kpi-trend.trend-up {
        color: var(--sp-success);
    }

    .kpi-trend.trend-down {
        color: var(--sp-danger);
    }

    .kpi-trend.trend-flat {
        color: var(--sp-text-tertiary);
    }

    .kpi-arrow {
        font-size: 0.65rem;
    }

    .kpi-period {
        font-size: var(--sp-text-xs);
        color: var(--sp-text-muted, var(--sp-text-tertiary));
        font-weight: 400;
    }

    .section-title + .table-container {
        max-height: 360px;
    }

    .section-title + .table-container > .table-scroll {
        max-height: 360px;
    }

    .top-pages-views {
        font-weight: 700;
        font-variant-numeric: tabular-nums;
        display: block;
        text-align: right;
    }

    .top-pages-trend {
        font-size: var(--sp-text-xs);
        display: block;
        text-align: right;
    }

    .top-pages-sparkline-col {
        width: 70px;
        padding: 0;
    }

    .top-pages-sparkline-cell {
        padding: var(--sp-space-1) var(--sp-space-2);
        vertical-align: middle;
    }

    @media (max-width: 768px) {
        .top-pages-sparkline-col,
        .top-pages-sparkline-cell {
            display: none;
        }
    }

}

@layer components {



.cc-profile-section {
    display: flex;
    flex-direction: column;
    gap: var(--sp-space-2);
    min-width: 180px;
}

.cc-profile-rank-block {
    display: flex;
    align-items: center;
    gap: var(--sp-space-3);
}

.cc-rank-badge--md {
    width: 2.25rem;
    height: 2.25rem;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: var(--sp-radius-full);
    font-weight: 700;
    font-size: var(--sp-text-sm);
    color: var(--sp-text-on-accent);
    background: var(--sp-accent);
    flex-shrink: 0;
    box-shadow: 0 0 0 2px color-mix(in oklch, var(--sp-accent) 20%, transparent);
}

.cc-profile-section .cc-rank-info {
    display: flex;
    flex-direction: column;
    gap: 0.1875rem;
    min-width: 0;
}

.cc-profile-section .cc-rank-name {
    font-size: var(--sp-text-sm);
    font-weight: 700;
    color: var(--sp-text-primary);
    line-height: 1.2;
}

.cc-xp-bar--compact {
    max-width: 140px;
    height: 5px;
    background: color-mix(in oklch, var(--sp-text-tertiary) 15%, transparent);
    border-radius: var(--sp-radius-full);
    overflow: hidden;
}

.cc-xp-bar--compact .cc-xp-fill {
    height: 100%;
    width: var(--sp-xp-pct);
    background: linear-gradient(90deg, var(--sp-accent), var(--sp-primary-400));
    border-radius: var(--sp-radius-full);
    transition: width 600ms var(--sp-ease-out);
}

@media (prefers-reduced-motion: reduce) {
    .cc-xp-bar--compact .cc-xp-fill {
        transition: none;
    }
}

.cc-xp-detail {
    font-size: var(--sp-text-xs);
    color: var(--sp-text-tertiary);
    font-variant-numeric: tabular-nums;
    white-space: nowrap;
    line-height: 1.2;
}



.cc-profile-meta {
    display: flex;
    gap: var(--sp-space-3);
    padding-top: var(--sp-space-1);
}

.cc-profile-meta-item {
    display: flex;
    align-items: baseline;
    gap: var(--sp-space-1);
}

.cc-profile-meta-icon {
    font-size: var(--sp-text-xs);
    line-height: 1;
}

.cc-profile-meta-icon--streak {
    filter: saturate(0.8);
}

.cc-profile-meta-value {
    font-size: var(--sp-text-sm);
    font-weight: 700;
    color: var(--sp-text-primary);
    font-variant-numeric: tabular-nums;
    line-height: 1;
}

.cc-profile-meta-label {
    font-size: var(--sp-text-xs);
    color: var(--sp-text-tertiary);
    text-transform: uppercase;
    letter-spacing: 0.04em;
    font-weight: 500;
    line-height: 1;
}



.global-limit-warnings {
    display: flex;
    flex-direction: column;
    gap: var(--sp-space-2);
    padding: 0 0 var(--sp-space-3) 0;
}

.global-limit-warnings .cc-limit-warning {
    font-size: var(--sp-text-xs);
    padding: var(--sp-space-2) var(--sp-space-3);
    border-radius: var(--sp-radius-sm);
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--sp-space-2);
    line-height: 1.4;
}

.global-limit-warnings .cc-limit-warning--caution {
    background: color-mix(in oklch, var(--sp-warning) 10%, transparent);
    color: var(--sp-warning);
    border: 1px solid color-mix(in oklch, var(--sp-warning) 20%, transparent);
}

.global-limit-warnings .cc-limit-warning--critical {
    background: color-mix(in oklch, var(--sp-danger) 10%, transparent);
    color: var(--sp-danger);
    border: 1px solid color-mix(in oklch, var(--sp-danger) 20%, transparent);
}

}

@layer components {

.cc-compact-header {
    background: var(--sp-bg-hero-gradient);
    border: 1px solid var(--sp-border-default);
    border-top: 3px solid var(--sp-accent);
    border-radius: var(--sp-radius-card-brand);
    border-top-left-radius: 0;
    border-bottom-left-radius: 0;
    padding: var(--sp-space-4) var(--sp-space-5);
    margin-bottom: var(--sp-space-4);
    box-shadow: var(--sp-shadow-hero), var(--sp-shadow-inner-glow);
    display: flex;
    flex-direction: row;
    align-items: stretch;
    gap: var(--sp-space-4);
    contain: layout style;
}



.cc-compact-col--stats {
    flex: 1;
    min-width: 0;
    display: flex;
    align-items: center;
}

.cc-compact-col--profile {
    flex-shrink: 0;
    display: flex;
    align-items: center;
    padding-left: var(--sp-space-4);
    border-left: 1px solid var(--sp-border-subtle);
}



.cc-compact-stats {
    display: flex;
    align-items: center;
    gap: var(--sp-space-2);
    flex-wrap: wrap;
    width: 100%;
}

.cc-stat-group {
    display: flex;
    align-items: center;
    gap: var(--sp-space-2);
    flex-wrap: wrap;
}


.cc-stat-group--secondary {
    padding-left: var(--sp-space-2);
    border-left: 1px solid var(--sp-border-subtle);
}



.cc-compact-stats .cc-stat-item {
    display: inline-flex;
    align-items: center;
    gap: 0.375rem;
    background: color-mix(in oklch, var(--sp-bg-surface-overlay) 60%, transparent);
    border: 1px solid var(--sp-border-subtle);
    border-radius: var(--sp-corners-sm);
    padding: 0.375rem var(--sp-space-3);
    white-space: nowrap;
    line-height: 1;
    box-shadow: 0 1px 2px color-mix(in oklch, #000 4%, transparent);
    transition:
        background var(--sp-duration-fast),
        border-color var(--sp-duration-fast),
        box-shadow var(--sp-duration-fast),
        transform var(--sp-duration-fast);
}

.cc-compact-stats .cc-stat-item:hover {
    background: color-mix(in oklch, var(--sp-bg-surface-overlay) 90%, transparent);
}

.cc-compact-stats .cc-stat-link {
    text-decoration: none;
    color: inherit;
}

.cc-compact-stats .cc-stat-link:hover .cc-stat-item {
    border-color: var(--sp-border-default);
    transform: translateY(-1px);
    box-shadow: 0 2px 6px color-mix(in oklch, #000 8%, transparent);
}

.cc-compact-stats .cc-stat-link:hover .cc-stat-label {
    color: var(--sp-text-secondary);
}



.cc-compact-stats .cc-stat-value {
    font-size: var(--sp-text-base);
    font-weight: 700;
    font-variant-numeric: tabular-nums;
    color: var(--sp-text-primary);
    line-height: 1;
}

.cc-compact-stats .cc-stat-label {
    font-size: var(--sp-text-xs);
    color: var(--sp-text-tertiary);
    text-transform: uppercase;
    letter-spacing: 0.05em;
    font-weight: 500;
    line-height: 1;
}

.cc-compact-stats .cc-stat-sep {
    display: none;
}



.cc-compact-stats .cc-stat-item--hero {
    background: linear-gradient(
        135deg,
        color-mix(in oklch, var(--sp-success) 15%, transparent),
        color-mix(in oklch, var(--sp-success) 8%, transparent)
    );
    border-color: color-mix(in oklch, var(--sp-success) 30%, transparent);
    padding: 0.375rem var(--sp-space-3);
    box-shadow:
        0 1px 3px color-mix(in oklch, var(--sp-success) 10%, transparent),
        inset 0 1px 0 color-mix(in oklch, #fff 5%, transparent);
}

.cc-compact-stats .cc-stat-item--hero .cc-stat-value {
    font-size: var(--sp-text-lg);
    color: var(--sp-success);
}


.cc-compact-stats .cc-stat-item--hero .live-dot {
    flex-shrink: 0;
}


.cc-compact-stats .cc-stat-item[data-stat="active_now"] .cc-stat-value {
    color: var(--sp-success);
}

@media (prefers-reduced-motion: reduce) {
    .cc-compact-stats .cc-stat-item,
    .cc-compact-stats .cc-stat-link:hover .cc-stat-item {
        transition: none;
        transform: none;
    }
}

}

@layer components {




.cc-feed-icon {
    width: 28px;
    height: 28px;
    border-radius: var(--sp-radius-full);
    flex-shrink: 0;
    display: flex;
    align-items: center;
    justify-content: center;
}

.cc-icon-file { background: color-mix(in oklch, var(--sp-chart-blue) 15%, transparent); color: var(--sp-chart-blue); }
.cc-icon-terminal { background: color-mix(in oklch, var(--sp-success) 15%, transparent); color: var(--sp-success); }
.cc-icon-search { background: color-mix(in oklch, var(--sp-chart-purple) 15%, transparent); color: var(--sp-chart-purple); }
.cc-icon-globe { background: color-mix(in oklch, var(--sp-chart-cyan) 15%, transparent); color: var(--sp-chart-cyan); }
.cc-icon-prompt { background: color-mix(in oklch, var(--sp-chart-purple) 15%, transparent); color: var(--sp-chart-purple); }
.cc-icon-play { background: color-mix(in oklch, var(--sp-success) 15%, transparent); color: var(--sp-success); }
.cc-icon-check { background: color-mix(in oklch, var(--sp-text-tertiary) 15%, transparent); color: var(--sp-text-tertiary); }
.cc-icon-error { background: color-mix(in oklch, var(--sp-danger) 15%, transparent); color: var(--sp-danger); }
.cc-icon-users { background: color-mix(in oklch, var(--sp-warning) 15%, transparent); color: var(--sp-warning); }
.cc-icon-task { background: color-mix(in oklch, var(--sp-success) 15%, transparent); color: var(--sp-success); }
.cc-icon-tool { background: color-mix(in oklch, var(--sp-chart-blue) 15%, transparent); color: var(--sp-chart-blue); }
.cc-icon-dot { background: color-mix(in oklch, var(--sp-text-tertiary) 15%, transparent); color: var(--sp-text-tertiary); }


.cc-feed-body {
    flex: 1;
    min-width: 0;
    overflow: hidden;
}

.cc-feed-description {
    font-size: var(--sp-text-sm);
    color: var(--sp-text-secondary);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    line-height: 1.4;
}

.cc-feed-prompt-preview {
    font-size: var(--sp-text-xs);
    color: var(--sp-text-tertiary);
    font-style: italic;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    margin-top: 0.125rem;
    max-width: 100%;
}

.cc-feed-session-badge {
    display: inline-block;
    font-size: 0.625rem;
    font-weight: 600;
    color: var(--sp-accent);
    background: var(--sp-accent-dim);
    padding: 0.0625rem var(--sp-space-2);
    border-radius: var(--sp-radius-full);
    margin-top: 0.1875rem;
    max-width: 100%;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}



.cc-next-jobs {
    display: flex;
    align-items: center;
    gap: var(--sp-space-2);
    padding: var(--sp-space-1) 0;
    font-size: var(--sp-text-xs);
    color: var(--sp-text-tertiary);
}
.cc-next-job-sep {
    opacity: 0.5;
}

.cc-tasks-list {
    display: flex;
    flex-direction: column;
    gap: var(--sp-space-2);
    margin-bottom: var(--sp-space-6);
}

.cc-task-card {
    display: flex;
    align-items: flex-start;
    gap: var(--sp-space-3);
    background: var(--sp-bg-surface);
    border: 1px solid var(--sp-border-subtle);
    border-radius: var(--sp-radius-card-inner-brand);
    padding: var(--sp-space-3) var(--sp-space-4);
    box-shadow: var(--sp-shadow-card);
}

.cc-task-icon {
    width: 28px;
    height: 28px;
    border-radius: var(--sp-radius-full);
    background: color-mix(in oklch, var(--sp-success) 15%, transparent);
    color: var(--sp-success);
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

.cc-task-body {
    flex: 1;
    min-width: 0;
}

.cc-task-subject {
    font-size: var(--sp-text-sm);
    font-weight: 600;
    color: var(--sp-text-primary);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.cc-task-desc {
    font-size: var(--sp-text-xs);
    color: var(--sp-text-tertiary);
    margin-top: 0.125rem;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

}

@layer components {




.cc-hero {
    background: linear-gradient(135deg,
        color-mix(in oklch, var(--sp-accent) 8%, var(--sp-bg-surface)) 0%,
        var(--sp-bg-surface) 100%);
    border: 1px solid var(--sp-border-subtle);
    border-radius: var(--sp-radius-xl);
    padding: var(--sp-space-8) var(--sp-space-8);
    text-align: center;
    margin-bottom: var(--sp-space-6);
}

.cc-hero-title {
    font-size: var(--sp-text-2xl);
    font-weight: 700;
    color: var(--sp-text-primary);
    margin: 0 0 var(--sp-space-2);
    letter-spacing: -0.02em;
}

.cc-hero-meta {
    font-size: var(--sp-text-base);
    color: var(--sp-text-secondary);
    margin: 0 0 var(--sp-space-5);
}

.cc-hero-actions {
    display: flex;
    gap: var(--sp-space-3);
    justify-content: center;
    flex-wrap: wrap;
}

.cc-hero-actions .btn {
    display: inline-flex;
    align-items: center;
    gap: var(--sp-space-2);
}


.cc-stats-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: var(--sp-space-4);
    margin-bottom: var(--sp-space-6);
}


.cc-three-col {
    display: grid;
    grid-template-columns: 1fr 1fr 1fr;
    gap: var(--sp-space-5);
    margin-bottom: var(--sp-space-6);
}

.cc-col-card {
    min-width: 0;
}


.cc-section-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: var(--sp-space-4);
}

.cc-section-header h3 {
    margin: 0;
    font-size: var(--sp-text-base);
    font-weight: 700;
    color: var(--sp-text-primary);
}

.cc-view-all {
    font-size: var(--sp-text-xs);
    font-weight: 500;
    color: var(--sp-accent);
    text-decoration: none;
    transition: opacity var(--sp-duration-fast);
}

.cc-view-all:hover { opacity: 0.8; }

.cc-empty-section {
    text-align: center;
    padding: var(--sp-space-8);
    background: var(--sp-bg-surface);
    border: 1px solid var(--sp-border-subtle);
    border-radius: var(--sp-radius-card-inner-brand);
    color: var(--sp-text-tertiary);
    font-size: var(--sp-text-sm);
    margin-bottom: var(--sp-space-4);
}

.cc-empty-section .btn {
    margin-top: var(--sp-space-3);
}

.cc-getting-started {
    text-align: center;
    padding: var(--sp-space-12) var(--sp-space-6);
    max-width: 32rem;
    margin: 0 auto;
}

.cc-getting-started__icon {
    color: var(--sp-accent);
    margin-bottom: var(--sp-space-4);
}

.cc-getting-started h2 {
    font-size: var(--sp-text-xl);
    font-weight: 700;
    margin: 0 0 var(--sp-space-2);
    color: var(--sp-text-primary);
}

.cc-getting-started p {
    color: var(--sp-text-secondary);
    line-height: 1.6;
    margin: 0 0 var(--sp-space-6);
    font-size: var(--sp-text-sm);
}

.cc-getting-started__btn {
    display: inline-flex;
    align-items: center;
    gap: var(--sp-space-2);
    padding: var(--sp-space-2) var(--sp-space-5);
    background: var(--sp-accent);
    color: var(--sp-text-on-accent);
    font-weight: 600;
    font-size: var(--sp-text-sm);
    border-radius: var(--sp-radius-sm);
    text-decoration: none;
    transition: opacity 0.15s ease;
}

.cc-getting-started__btn:hover {
    opacity: 0.9;
}


}

@layer responsive {

.cc-tab-panel .table-scroll {
    max-height: none;
}

@media (max-width: 768px) {

    .cc-batch-bar {
        position: sticky;
        bottom: 0;
        z-index: 10;
        border-top: 1px solid var(--sp-border-default);
        box-shadow: 0 -2px 8px color-mix(in oklch, #000 8%, transparent);
    }

    .cc-select-all-label,
    .cc-select-check {
        min-width: 44px;
        min-height: 44px;
        display: flex;
        align-items: center;
        justify-content: center;
    }

    .cc-session-checkbox {
        min-width: 20px;
        min-height: 20px;
    }

    .cc-filter-bar {
        flex-wrap: wrap;
    }

    .cc-compact-header {
        flex-direction: column;
    }

    .cc-compact-col--profile {
        border-left: none;
        padding-left: 0;
        border-top: 1px solid var(--sp-border-subtle);
        padding-top: var(--sp-space-3);
    }

    .cc-profile-section {
        flex-direction: row;
        align-items: center;
        gap: var(--sp-space-4);
        width: 100%;
    }

    .cc-profile-rank-block {
        flex: 1;
        min-width: 0;
    }

    .cc-profile-meta {
        gap: var(--sp-space-4);
        flex-shrink: 0;
    }

    .cc-compact-stats {
        flex-wrap: wrap;
        gap: var(--sp-space-2);
    }

    .cc-stat-sep {
        display: none;
    }

    .cc-tabs {
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
        scrollbar-width: none;
        gap: 0;
    }

    .cc-tabs::-webkit-scrollbar {
        display: none;
    }

    .cc-tab {
        white-space: nowrap;
        flex-shrink: 0;
    }

    .cc-insights-grid {
        grid-template-columns: 1fr;
    }

    .cc-insight-card {
        max-height: none;
    }

    .cc-suggestions-section .data-table th:nth-child(2),
    .cc-suggestions-section .data-table td:nth-child(2),
    .cc-suggestions-section .data-table th:nth-child(4),
    .cc-suggestions-section .data-table td:nth-child(4),
    .cc-suggestions-section .data-table th:nth-child(5),
    .cc-suggestions-section .data-table td:nth-child(5),
    .cc-suggestions-section .data-table th:nth-child(6),
    .cc-suggestions-section .data-table td:nth-child(6) {
        display: none;
    }

    .cc-suggestions-session-title {
        max-width: 180px;
        overflow: hidden;
        text-overflow: ellipsis;
        white-space: nowrap;
    }

    .cc-report-section .data-table .cc-report-session-title {
        min-width: 120px;
        max-width: 200px;
    }

    .cc-report-session-outcome {
        max-width: 180px;
    }

    .cc-health-banner {
        flex-direction: column;
        gap: var(--sp-space-2);
        padding: var(--sp-space-2) var(--sp-space-3);
    }

    .cc-health-rec {
        text-align: left;
        margin-left: 0;
        max-width: none;
    }

    .cc-session-model {
        word-break: break-word;
        white-space: normal;
    }

    .cc-hourly-chart-tabs {
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
        scrollbar-width: none;
        flex-wrap: nowrap;
    }

    .cc-hourly-chart-tabs::-webkit-scrollbar {
        display: none;
    }

    .cc-chart-tab {
        flex-shrink: 0;
    }
}

@media (max-width: 480px) {

    .cc-compact-header {
        padding: var(--sp-space-3) var(--sp-space-3);
    }

    .cc-profile-section {
        flex-direction: column;
        align-items: flex-start;
    }

    .cc-profile-rank-block {
        width: 100%;
    }

    .cc-xp-bar--compact {
        max-width: none;
        width: 100%;
    }

    .cc-stat-group--secondary {
        border-left: none;
        padding-left: 0;
    }

    .cc-stat-item[data-stat="tool_diversity"],
    .cc-stat-item[data-stat="multitasking"],
    .cc-stat-item[data-stat="throughput"] {
        display: none;
    }

    .cc-suggestions-session-title {
        max-width: 120px;
    }

    .cc-report-session-outcome {
        max-width: 120px;
    }
}

}

@layer components {


.cc-plugin-list {
    display: flex;
    flex-direction: column;
    gap: var(--sp-space-3);
    margin-bottom: var(--sp-space-4);
}

.cc-plugin-list .marketplace-card {
    text-decoration: none;
}

.cc-plugin-list .marketplace-card-accent--disabled {
    background: var(--sp-text-tertiary);
}


.cc-plugin-status {
    width: 8px;
    height: 8px;
    border-radius: var(--sp-radius-full);
    flex-shrink: 0;
}

.cc-plugin-status--active {
    background: var(--sp-success);
    box-shadow: 0 0 6px var(--sp-success);
}

.cc-plugin-status--inactive {
    background: var(--sp-text-tertiary);
}


.cc-rank-card {
    background: var(--sp-bg-surface);
    border: 1px solid var(--sp-border-subtle);
    border-left: 4px solid var(--sp-accent);
    border-radius: var(--sp-radius-card-brand);
    padding: var(--sp-space-4) var(--sp-space-5);
    margin-top: var(--sp-space-4);
    box-shadow: var(--sp-shadow-card);
}

.cc-rank-card-header {
    display: flex;
    align-items: center;
    gap: var(--sp-space-3);
    margin-bottom: var(--sp-space-3);
    flex-wrap: wrap;
}

.cc-rank-badge {
    font-weight: 700;
    font-size: var(--sp-text-base);
    color: var(--sp-accent);
    background: var(--sp-accent-dim);
    padding: var(--sp-space-1) var(--sp-space-3);
    border-radius: var(--sp-radius-full);
}

.cc-rank-xp {
    font-weight: 600;
    font-size: var(--sp-text-sm);
    color: var(--sp-text-primary);
    font-variant-numeric: tabular-nums;
}

.cc-streak {
    font-size: var(--sp-text-xs);
    font-weight: 600;
    color: var(--sp-warning);
    background: var(--sp-warning-dim);
    padding: 0.125rem var(--sp-space-2);
    border-radius: var(--sp-radius-full);
}

.cc-xp-bar {
    height: 8px;
    background: var(--sp-bg-tertiary);
    border-radius: var(--sp-radius-sm);
    overflow: hidden;
    margin-bottom: var(--sp-space-1);
}

.cc-xp-bar-fill {
    height: 100%;
    background: linear-gradient(90deg, var(--sp-accent), var(--sp-primary-400));
    border-radius: var(--sp-radius-sm);
    transition: width 600ms var(--sp-ease-out);
}

.cc-xp-target {
    font-size: var(--sp-text-xs);
    color: var(--sp-text-tertiary);
    display: block;
    text-align: right;
}


.cc-activity-feed {
    background: var(--sp-bg-surface);
    border: 1px solid var(--sp-border-subtle);
    border-radius: var(--sp-radius-card-inner-brand);
    overflow: hidden;
    box-shadow: var(--sp-shadow-card);
    max-height: 480px;
    overflow-y: auto;
}

.cc-activity-feed .feed-item {
    padding: var(--sp-space-3) var(--sp-space-4);
}


.cc-timeline-dot {
    width: 8px;
    height: 8px;
    border-radius: var(--sp-radius-full);
    flex-shrink: 0;
}

.cc-dot-blue { background: var(--sp-accent); }
.cc-dot-red { background: var(--sp-danger); box-shadow: 0 0 6px var(--sp-danger); }
.cc-dot-green { background: var(--sp-success); }
.cc-dot-yellow { background: var(--sp-warning); }
.cc-dot-purple { background: var(--sp-feed-purple); }
.cc-dot-gray { background: var(--sp-text-tertiary); }

.cc-timeline-content {
    flex: 1;
    min-width: 0;
    display: flex;
    align-items: center;
    gap: var(--sp-space-2);
}

.cc-timeline-type {
    font-size: var(--sp-text-sm);
    font-weight: 500;
    color: var(--sp-text-secondary);
    white-space: nowrap;
}

.cc-timeline-time {
    font-size: var(--sp-text-xs);
    color: var(--sp-text-tertiary);
    flex-shrink: 0;
    white-space: nowrap;
}

}

@layer components {

.cc-report-share-wrapper {
    position: relative;
}

.cc-report-share-menu {
    position: absolute;
    right: 0;
    top: calc(100% + var(--sp-space-2));
    background: var(--sp-bg-surface);
    border: 1px solid var(--sp-border-default);
    border-radius: var(--sp-radius-md);
    box-shadow: var(--sp-shadow-card), 0 8px 24px color-mix(in oklch, var(--sp-accent) 8%, transparent);
    z-index: var(--sp-z-dropdown);
    min-width: 200px;
    padding: var(--sp-space-2);
    opacity: 0;
    transform: translateY(-4px);
    pointer-events: none;
    transition: opacity var(--sp-duration-fast) var(--sp-ease-out), transform var(--sp-duration-fast) var(--sp-ease-out);
}

.cc-report-share-menu--open {
    opacity: 1;
    transform: translateY(0);
    pointer-events: auto;
}
.cc-report-share-item {
    display: flex;
    align-items: center;
    gap: var(--sp-space-2);
    width: 100%;
    padding: var(--sp-space-2) var(--sp-space-3);
    font-size: var(--sp-text-xs);
    font-weight: 500;
    font-family: inherit;
    color: var(--sp-text-secondary);
    background: none;
    border: none;
    border-radius: var(--sp-radius-sm);
    cursor: pointer;
    text-align: left;
    transition: all var(--sp-duration-fast) var(--sp-ease-out);
}

.cc-report-share-item:hover {
    background: color-mix(in oklch, var(--sp-accent) 8%, transparent);
    color: var(--sp-accent);
}
.cc-report-share-item svg {
    flex-shrink: 0;
    opacity: 0.6;
}

.cc-report-share-item:hover svg {
    opacity: 1;
}
.cc-report-toast {
    position: fixed;
    bottom: var(--sp-space-6);
    left: 50%;
    transform: translateX(-50%) translateY(20px);
    background: var(--sp-bg-surface);
    color: var(--sp-accent);
    border: 1px solid color-mix(in oklch, var(--sp-accent) 30%, transparent);
    border-radius: var(--sp-radius-full);
    box-shadow: var(--sp-shadow-card), 0 4px 16px color-mix(in oklch, var(--sp-accent) 12%, transparent);
    padding: var(--sp-space-2) var(--sp-space-5);
    font-size: var(--sp-text-sm);
    font-weight: 600;
    z-index: var(--sp-z-toast);
    opacity: 0;
    pointer-events: none;
    transition: opacity var(--sp-duration-normal), transform var(--sp-duration-normal);
}

.cc-report-toast--visible {
    opacity: 1;
    transform: translateX(-50%) translateY(0);
}
.cc-report-streak {
    display: inline-flex;
    align-items: center;
    gap: var(--sp-space-1);
    font-size: var(--sp-text-xs);
    font-weight: 600;
    color: var(--sp-accent);
}

.cc-compact-row--stats { display: flex; gap: var(--sp-space-4); align-items: center; }
.cc-stat-group--primary { font-weight: 600; color: var(--sp-accent); }
.cc-xp-fill {
    height: 100%;
    background: var(--sp-accent);
    border-radius: var(--sp-radius-xs);
    transition: width var(--sp-duration-slow) var(--sp-ease-out);
}

.traffic-chart-container {
    position: relative;
    width: 100%;
    overflow: hidden;
}
.traffic-chart-tooltip {
    position: absolute;
    background: var(--sp-bg-surface-overlay);
    border: 1px solid var(--sp-border-default);
    border-radius: var(--sp-radius-md);
    padding: var(--sp-space-2) var(--sp-space-3);
    font-size: var(--sp-text-xs);
    box-shadow: var(--sp-shadow-float);
    pointer-events: none;
    z-index: var(--sp-z-tooltip);
    white-space: nowrap;
}
.traffic-svg { display: block; width: 100%; height: auto; }

.cc-report-section-title {
    font-size: var(--sp-text-sm);
    font-weight: 700;
    color: var(--sp-text-primary);
    text-transform: uppercase;
    letter-spacing: 0.04em;
    margin-bottom: var(--sp-space-3);
}
.cc-report-metric {
    display: flex;
    flex-direction: column;
    gap: 0.125rem;
}
.cc-report-value {
    font-size: var(--sp-text-lg);
    font-weight: 700;
    color: var(--sp-text-primary);
    font-variant-numeric: tabular-nums;
    text-align: right;
}
.cc-report-delta {
    font-size: var(--sp-text-xs);
    font-weight: 600;
    text-align: right;
}
.cc-report-delta--positive { color: var(--sp-success); }
.cc-report-delta--negative { color: var(--sp-danger); }
.cc-report-delta--neutral { color: var(--sp-text-tertiary); }
.cc-report-arrow { font-size: var(--sp-text-xs); }
.cc-report-countdown-label { font-size: var(--sp-text-xs); color: var(--sp-text-tertiary); }
.cc-report-category-list { display: flex; flex-direction: column; gap: var(--sp-space-2); }
.cc-report-category-row {
    display: grid;
    grid-template-columns: 100px 1fr 40px 40px;
    gap: var(--sp-space-2);
    align-items: center;
    font-size: var(--sp-text-xs);
}
.cc-report-category-label { font-weight: 500; color: var(--sp-text-primary); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.cc-report-category-bar-track { height: 14px; background: var(--sp-bg-tertiary); border-radius: var(--sp-radius-xs); overflow: hidden; }
.cc-report-category-bar { height: 100%; background: var(--sp-accent); border-radius: var(--sp-radius-xs); }
.cc-report-category-count { text-align: right; font-weight: 600; color: var(--sp-text-primary); font-variant-numeric: tabular-nums; }
.cc-report-category-pct { text-align: right; color: var(--sp-text-tertiary); font-variant-numeric: tabular-nums; }

.cc-report-entity-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(80px, 1fr));
    gap: var(--sp-space-3);
    text-align: center;
}
.cc-report-entity-card {
    padding: var(--sp-space-3);
    border-radius: var(--sp-radius-md);
    background: var(--sp-bg-surface-raised);
}
.cc-report-entity-value { display: block; font-size: var(--sp-text-lg); font-weight: 700; color: var(--sp-text-primary); font-variant-numeric: tabular-nums; }
.cc-report-entity-label { display: block; font-size: var(--sp-text-xs); color: var(--sp-text-tertiary); text-transform: uppercase; letter-spacing: 0.04em; }

.cc-report-sparkline { display: block; width: 100%; height: 30px; overflow: visible; }
.cc-report-history-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(60px, 1fr));
    gap: var(--sp-space-2);
    text-align: center;
}
.cc-report-history-item {
    padding: var(--sp-space-2);
    border-radius: var(--sp-radius-sm);
    background: var(--sp-bg-surface-raised);
    font-size: var(--sp-text-xs);
}
.cc-report-history-label { color: var(--sp-text-tertiary); display: block; }
.cc-report-insights-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
    gap: var(--sp-space-3);
}

}

@layer components {

.cc-detail-overlay {
    position: fixed;
    inset: 0;
    background: color-mix(in oklch, var(--sp-bg-canvas) 80%, transparent);
    z-index: var(--sp-z-modal-backdrop);
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0;
    pointer-events: none;
    transition: opacity var(--sp-duration-normal);
}
.cc-detail-overlay.open { opacity: 1; pointer-events: auto; }
.cc-detail-modal {
    background: var(--sp-bg-surface);
    border: 1px solid var(--sp-border-default);
    border-radius: var(--sp-radius-card-brand);
    box-shadow: var(--sp-shadow-float);
    max-width: 640px;
    width: 90%;
    max-height: 80vh;
    overflow-y: auto;
    z-index: var(--sp-z-modal);
}
.cc-detail-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: var(--sp-space-4) var(--sp-space-5);
    border-bottom: 1px solid var(--sp-border-subtle);
}
.cc-detail-title { font-size: var(--sp-text-base); font-weight: 700; color: var(--sp-text-primary); }
.cc-detail-close {
    background: none;
    border: none;
    color: var(--sp-text-tertiary);
    cursor: pointer;
    padding: var(--sp-space-1);
    border-radius: var(--sp-radius-sm);
    transition: color var(--sp-duration-fast), background var(--sp-duration-fast);
}
.cc-detail-close:hover { color: var(--sp-text-primary); background: var(--sp-bg-surface-raised); }
.cc-detail-content { padding: var(--sp-space-5); }
.cc-detail-meta {
    display: flex;
    gap: var(--sp-space-4);
    margin-bottom: var(--sp-space-4);
    font-size: var(--sp-text-xs);
    color: var(--sp-text-tertiary);
}
.cc-detail-section { margin-bottom: var(--sp-space-4); }
.cc-detail-section--tool-errors { border-top: 1px solid var(--sp-border-subtle); padding-top: var(--sp-space-4); }
.cc-detail-section-label {
    font-size: var(--sp-text-xs);
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    color: var(--sp-text-secondary);
    margin-bottom: var(--sp-space-2);
}
.cc-detail-text { font-size: var(--sp-text-sm); color: var(--sp-text-primary); line-height: 1.5; }
.cc-detail-text--muted { color: var(--sp-text-tertiary); }
.cc-detail-text--recommendation { color: var(--sp-accent); font-weight: 500; }
.cc-detail-data { font-family: var(--sp-font-mono); font-size: var(--sp-text-xs); }
.cc-detail-outcomes {
    display: flex;
    gap: var(--sp-space-2);
    flex-wrap: wrap;
}
.cc-detail-btn {
    padding: var(--sp-space-1) var(--sp-space-3);
    font-size: var(--sp-text-xs);
    font-weight: 600;
    border: 1px solid var(--sp-border-default);
    border-radius: var(--sp-radius-button);
    background: transparent;
    color: var(--sp-text-secondary);
    cursor: pointer;
}
.cc-detail-btn:hover { background: var(--sp-accent-dim); border-color: var(--sp-accent); color: var(--sp-accent); }

.cc-batch-bar {
    display: flex;
    align-items: center;
    gap: var(--sp-space-3);
    padding: var(--sp-space-2) var(--sp-space-4);
    background: var(--sp-bg-surface-raised);
    border-radius: var(--sp-radius-md);
    margin-bottom: var(--sp-space-3);
}
.cc-batch-bar[hidden] {
    display: none;
}
.cc-batch-count { font-size: var(--sp-text-sm); font-weight: 600; color: var(--sp-text-primary); }
.cc-batch-btn {
    padding: var(--sp-space-1) var(--sp-space-3);
    font-size: var(--sp-text-xs);
    font-weight: 600;
    border: 1px solid var(--sp-border-default);
    border-radius: var(--sp-radius-button);
    background: transparent;
    color: var(--sp-text-secondary);
    cursor: pointer;
}
.cc-batch-btn:hover { background: var(--sp-accent-dim); color: var(--sp-accent); }
.cc-batch-btn--danger { color: var(--sp-danger); border-color: color-mix(in oklch, var(--sp-danger) 30%, transparent); }
.cc-batch-btn--danger:hover { background: var(--sp-danger-dim); }

@media (prefers-reduced-motion: reduce) {
    .cc-detail-overlay,
    .cc-report-share-menu,
    .cc-report-toast {
        transition: none;
    }
}

}

@layer components {

.cc-report-th-metric { text-align: left; }
.cc-report-th-value,
.cc-report-th-global,
.cc-report-th-delta { text-align: right; }

.cc-report-section { contain: layout style; }

.cc-report-entity-grid { contain: layout style; }


.cc-efficiency-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: var(--sp-space-3);
}
.cc-eff-metric {
    text-align: center;
    padding: var(--sp-space-2);
    background: var(--sp-bg-surface-raised);
    border-radius: var(--sp-radius-sm);
}
.cc-eff-value {
    display: block;
    font-size: var(--sp-text-lg);
    font-weight: 700;
    color: var(--sp-text-primary);
    font-variant-numeric: tabular-nums;
}
.cc-eff-label {
    display: block;
    font-size: var(--sp-text-xs);
    color: var(--sp-text-tertiary);
    text-transform: uppercase;
    letter-spacing: 0.04em;
}


.cc-goal-outcome-map {
    display: flex;
    flex-direction: column;
    gap: var(--sp-space-2);
}
.cc-goal-outcome-row {
    display: flex;
    align-items: flex-start;
    gap: var(--sp-space-2);
    padding: var(--sp-space-2);
    border-radius: var(--sp-radius-sm);
}
.cc-goal-outcome-row--achieved { background: color-mix(in oklch, var(--sp-success) 5%, transparent); }
.cc-goal-outcome-row--missed { background: color-mix(in oklch, var(--sp-danger) 5%, transparent); }
.cc-goal-outcome-indicator {
    width: 8px;
    height: 8px;
    border-radius: var(--sp-radius-full);
    flex-shrink: 0;
    margin-top: 0.375rem;
}
.cc-goal-outcome-row--achieved .cc-goal-outcome-indicator { background: var(--sp-success); }
.cc-goal-outcome-row--missed .cc-goal-outcome-indicator { background: var(--sp-danger); }
.cc-goal-outcome-content { flex: 1; min-width: 0; }
.cc-goal-text { display: block; font-size: var(--sp-text-sm); font-weight: 600; color: var(--sp-text-primary); }
.cc-outcome-text { display: block; font-size: var(--sp-text-xs); color: var(--sp-text-secondary); margin-top: 0.125rem; }


.cc-best-practices-list { list-style: none; padding: 0; margin: 0; }
.cc-bp-item {
    display: flex;
    align-items: flex-start;
    gap: var(--sp-space-2);
    padding: var(--sp-space-2) 0;
    border-bottom: 1px solid var(--sp-border-subtle);
}
.cc-bp-item:last-child { border-bottom: none; }
.cc-bp-indicator {
    width: 8px;
    height: 8px;
    border-radius: var(--sp-radius-full);
    flex-shrink: 0;
    margin-top: 0.375rem;
}
.cc-bp-item--good .cc-bp-indicator { background: var(--sp-success); }
.cc-bp-item--fair .cc-bp-indicator { background: var(--sp-warning); }
.cc-bp-item--poor .cc-bp-indicator { background: var(--sp-danger); }
.cc-bp-practice { font-size: var(--sp-text-sm); color: var(--sp-text-primary); }
.cc-bp-note { font-size: var(--sp-text-xs); color: var(--sp-text-tertiary); display: block; margin-top: 0.125rem; }


.cc-detail-text--hint { color: var(--sp-accent); font-weight: 500; }
.cc-detail-section--hints { border-left: 3px solid var(--sp-accent); padding-left: var(--sp-space-3); }

@media (max-width: 768px) {
    .cc-efficiency-grid {
        grid-template-columns: repeat(2, 1fr);
    }
    .cc-report-insights-grid {
        grid-template-columns: 1fr;
    }
}

}

@layer components {

.cc-achievement-progress-list { display: flex; flex-direction: column; gap: var(--sp-space-2); }
.cc-achievement-progress-item {
    display: flex;
    align-items: center;
    gap: var(--sp-space-3);
    padding: var(--sp-space-2) 0;
}
.cc-achievement-progress-info { flex: 1; min-width: 0; }
.cc-achievement-progress-name { font-size: var(--sp-text-sm); font-weight: 600; color: var(--sp-text-primary); }
.cc-achievement-progress-count { font-size: var(--sp-text-xs); color: var(--sp-text-tertiary); font-variant-numeric: tabular-nums; }

.cc-adoption-summary { display: flex; align-items: center; gap: var(--sp-space-4); }
.cc-adoption-gauge { position: relative; width: 64px; height: 64px; flex-shrink: 0; }
.cc-adoption-ring { width: 100%; height: 100%; }
.cc-adoption-pct {
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: var(--sp-text-sm);
    font-weight: 700;
    color: var(--sp-text-primary);
}
.cc-adoption-label { font-size: var(--sp-text-xs); color: var(--sp-text-tertiary); }

.cc-category-badge {
    display: inline-flex;
    align-items: center;
    padding: 0.125rem var(--sp-space-2);
    border-radius: var(--sp-radius-xs);
    font-size: var(--sp-text-xs);
    font-weight: 500;
    background: color-mix(in oklch, var(--sp-accent) 10%, transparent);
    color: var(--sp-accent);
}
.cc-category-badge--other { background: var(--sp-bg-tertiary); color: var(--sp-text-secondary); }

.cc-chart-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: var(--sp-space-3); }
.cc-chart-title { font-size: var(--sp-text-sm); font-weight: 600; color: var(--sp-text-primary); }
.cc-chart-legend { display: flex; gap: var(--sp-space-3); font-size: var(--sp-text-xs); color: var(--sp-text-tertiary); }

.cc-hourly-chart-card { margin-bottom: var(--sp-space-4); contain: layout style; }
.cc-hourly-chart-container { position: relative; width: 100%; overflow-x: auto; }
.cc-hourly-x-labels { display: flex; justify-content: space-between; font-size: var(--sp-text-xs); color: var(--sp-text-tertiary); padding-top: var(--sp-space-1); }

.cc-entity-pill--unused { opacity: 0.5; }

.cc-goal-badge {
    display: inline-flex;
    align-items: center;
    padding: 0.125rem var(--sp-space-2);
    border-radius: var(--sp-radius-xs);
    font-size: var(--sp-text-xs);
    font-weight: 600;
}
.cc-goal-badge--yes { color: var(--sp-success); background: var(--sp-success-dim); }
.cc-goal-badge--no { color: var(--sp-danger); background: var(--sp-danger-dim); }
.cc-goal-badge--partial { color: var(--sp-warning); background: color-mix(in oklch, var(--sp-warning) 12%, transparent); }

.cc-insight-card--adoption {
    border-left: 3px solid var(--sp-accent);
    padding-left: var(--sp-space-4);
}

.cc-legend-item { display: inline-flex; align-items: center; gap: var(--sp-space-1); font-size: var(--sp-text-xs); color: var(--sp-text-tertiary); }
.cc-legend--actions { color: var(--sp-accent); }
.cc-legend--apm { color: var(--sp-success); }
.cc-legend--concurrency { color: var(--sp-warning); }
.cc-legend--throughput { color: var(--sp-info); }
.cc-legend--tools { color: var(--sp-text-secondary); }

.cc-quality-gauge {
    display: inline-flex;
    align-items: center;
    padding: 0.125rem var(--sp-space-2);
    border-radius: var(--sp-radius-xs);
    font-size: var(--sp-text-xs);
    font-weight: 600;
}
.cc-quality-gauge--high { color: var(--sp-success); background: var(--sp-success-dim); }
.cc-quality-gauge--medium { color: var(--sp-warning); background: color-mix(in oklch, var(--sp-warning) 12%, transparent); }
.cc-quality-gauge--low { color: var(--sp-danger); background: var(--sp-danger-dim); }

.cc-range-tabs { display: flex; gap: var(--sp-space-1); margin-bottom: var(--sp-space-4); }
.cc-range-tab {
    padding: var(--sp-space-1) var(--sp-space-3);
    font-size: var(--sp-text-xs);
    font-weight: 600;
    border: 1px solid var(--sp-border-default);
    border-radius: var(--sp-radius-button);
    background: transparent;
    color: var(--sp-text-secondary);
    cursor: pointer;
    transition: all var(--sp-duration-fast);
}
.cc-range-tab:hover { background: var(--sp-bg-surface-raised); }
.cc-range-tab--active { background: var(--sp-accent); color: var(--sp-text-on-accent); border-color: var(--sp-accent); }

.cc-select-all-label { font-size: var(--sp-text-xs); color: var(--sp-text-secondary); cursor: pointer; display: flex; align-items: center; gap: var(--sp-space-2); }

.cc-suggestions-section-title { font-size: var(--sp-text-sm); font-weight: 700; color: var(--sp-text-primary); margin-bottom: var(--sp-space-3); }
.cc-suggestion-row td { vertical-align: middle; }
.cc-suggestion-summary { font-size: var(--sp-text-sm); color: var(--sp-text-primary); flex: 1; }

.cc-tab-panel--report { padding-top: var(--sp-space-4); contain: layout style; }

.cc-tag-badges { display: flex; flex-wrap: wrap; gap: var(--sp-space-1); }
.cc-tag-badge {
    display: inline-flex;
    padding: 0.0625rem var(--sp-space-2);
    border-radius: var(--sp-radius-xs);
    font-size: var(--sp-text-xs);
    background: var(--sp-bg-tertiary);
    color: var(--sp-text-secondary);
}

.cc-unused-skills { margin-top: var(--sp-space-3); }
.cc-unused-label { font-size: var(--sp-text-xs); color: var(--sp-text-tertiary); font-weight: 500; }

}

@layer components {

.cc-report {
    background: var(--sp-bg-surface);
    border: 1px solid var(--sp-border-default);
    border-radius: var(--sp-radius-card-brand);
    box-shadow: var(--sp-shadow-card);
    padding: var(--sp-space-6);
    contain: layout style;
}

.cc-report--empty {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 200px;
    padding: var(--sp-space-8);
}

.cc-report-empty-text {
    font-size: var(--sp-text-sm);
    color: var(--sp-text-tertiary);
    text-align: center;
    line-height: 1.6;
}

.cc-report-empty-text code {
    font-family: ui-monospace, "Cascadia Code", "Fira Code", monospace;
    font-size: var(--sp-text-xs);
    background: var(--sp-bg-surface-overlay);
    border: 1px solid var(--sp-border-subtle);
    border-radius: var(--sp-radius-sm);
    padding: 0.15em 0.4em;
}

.cc-report-header {
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    padding-bottom: var(--sp-space-4);
    margin-bottom: var(--sp-space-5);
    border-bottom: 1px solid var(--sp-border-default);
}

.cc-report-title-group {
    display: flex;
    align-items: baseline;
    gap: var(--sp-space-3);
}

.cc-report-title {
    font-size: var(--sp-text-lg);
    font-weight: 700;
    color: var(--sp-text-primary);
    margin: 0;
    letter-spacing: -0.01em;
}

.cc-report-subtitle {
    font-size: var(--sp-text-xs);
    color: var(--sp-text-tertiary);
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.cc-report-date {
    font-size: var(--sp-text-sm);
    font-weight: 600;
    color: var(--sp-text-secondary);
    font-variant-numeric: tabular-nums;
}

.cc-report-header-right {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: var(--sp-space-1);
}

.cc-report-countdown {
    display: flex;
    align-items: baseline;
    gap: var(--sp-space-2);
    font-size: var(--sp-text-xs);
    color: var(--sp-text-tertiary);
}

.cc-report-countdown-value {
    font-family: ui-monospace, "Cascadia Code", "Fira Code", monospace;
    font-weight: 600;
    color: var(--sp-text-secondary);
    font-variant-numeric: tabular-nums;
}

.cc-report-actions {
    display: flex;
    align-items: center;
    gap: var(--sp-space-2);
}

.cc-report-action-btn {
    display: inline-flex;
    align-items: center;
    gap: var(--sp-space-2);
    padding: var(--sp-space-2) var(--sp-space-3);
    font-size: var(--sp-text-xs);
    font-weight: 600;
    font-family: inherit;
    color: var(--sp-accent);
    background: color-mix(in oklch, var(--sp-accent) 8%, transparent);
    border: 1px solid color-mix(in oklch, var(--sp-accent) 25%, transparent);
    border-radius: var(--sp-radius-full);
    cursor: pointer;
    transition: all var(--sp-duration-fast) var(--sp-ease-out);
    white-space: nowrap;
    letter-spacing: 0.01em;
}

.cc-report-action-btn:hover {
    color: var(--sp-accent);
    background: color-mix(in oklch, var(--sp-accent) 15%, transparent);
    border-color: color-mix(in oklch, var(--sp-accent) 40%, transparent);
    box-shadow: 0 2px 8px color-mix(in oklch, var(--sp-accent) 15%, transparent);
}

.cc-report-action-btn:active {
    transform: scale(0.97);
}

.cc-report-action-btn svg {
    flex-shrink: 0;
    width: 14px;
    height: 14px;
}

@media (prefers-reduced-motion: reduce) {
    .cc-report-action-btn {
        transition: none;
    }
    .cc-report-action-btn:active {
        transform: none;
    }
}

}

@layer components {



.cc-sessions-list {
    display: flex;
    flex-direction: column;
    gap: var(--sp-space-3);
    margin-bottom: var(--sp-space-4);
}

.cc-session-card {
    background: var(--sp-bg-surface);
    border: 1px solid var(--sp-border-subtle);
    border-radius: var(--sp-radius-card-brand);
    padding: var(--sp-space-3) var(--sp-space-4);
    box-shadow: var(--sp-shadow-card);
}

.cc-session-active {
    border-left: 3px solid var(--sp-success);
    background: color-mix(in oklch, var(--sp-success) 3%, var(--sp-bg-surface));
}

.cc-session-header {
    display: flex;
    align-items: center;
    gap: var(--sp-space-2);
    margin-bottom: var(--sp-space-2);
}

.cc-session-live-dot {
    width: 8px;
    height: 8px;
    border-radius: var(--sp-radius-full);
    background: var(--sp-success);
    flex-shrink: 0;
    animation: cc-pulse 2s ease-in-out infinite;
}

@keyframes cc-pulse {
    0%, 100% { box-shadow: 0 0 0 0 color-mix(in oklch, var(--sp-success) 40%, transparent); }
    50% { box-shadow: 0 0 0 4px color-mix(in oklch, var(--sp-success) 0%, transparent); }
}

.cc-session-model {
    font-size: var(--sp-text-sm);
    font-weight: 600;
    color: var(--sp-text-primary);
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.cc-session-time {
    font-size: var(--sp-text-xs);
    color: var(--sp-text-tertiary);
    margin-left: auto;
    flex-shrink: 0;
    white-space: nowrap;
}

.cc-session-stats {
    display: flex;
    gap: var(--sp-space-3);
    font-size: var(--sp-text-xs);
    color: var(--sp-text-secondary);
}

.cc-session-errors {
    color: var(--sp-danger);
    font-weight: 600;
}

.cc-session-tokens {
    font-size: var(--sp-text-xs);
    color: var(--sp-text-tertiary);
    margin-top: var(--sp-space-1);
    font-variant-numeric: tabular-nums;
}



.cc-token-card {
    background: var(--sp-bg-surface);
    border: 1px solid var(--sp-border-subtle);
    border-radius: var(--sp-radius-card-brand);
    padding: var(--sp-space-3) var(--sp-space-4);
    margin-bottom: var(--sp-space-4);
    box-shadow: var(--sp-shadow-card);
}

.cc-token-model-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: var(--sp-space-2) 0;
    font-size: var(--sp-text-xs);
}

.cc-token-model-row + .cc-token-model-row {
    border-top: 1px solid var(--sp-border-subtle);
}

.cc-token-model-name {
    color: var(--sp-text-secondary);
    font-weight: 500;
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    margin-right: var(--sp-space-2);
}

.cc-token-model-tokens {
    color: var(--sp-text-tertiary);
    font-variant-numeric: tabular-nums;
    flex-shrink: 0;
}




.cc-side-panel {
    min-width: 0;
}


.cc-sessions {
    display: flex;
    flex-direction: column;
    gap: var(--sp-space-2);
    margin-bottom: var(--sp-space-4);
}

.cc-session {
    background: var(--sp-bg-surface);
    border: 1px solid var(--sp-border-subtle);
    border-radius: var(--sp-radius-card-inner-brand);
    padding: var(--sp-space-3) var(--sp-space-4);
    box-shadow: var(--sp-shadow-card);
}

.cc-session--active {
    border-left: 3px solid var(--sp-success);
    background: color-mix(in oklch, var(--sp-success) 3%, var(--sp-bg-surface));
}

.cc-session-top {
    display: flex;
    align-items: center;
    gap: var(--sp-space-2);
    margin-bottom: var(--sp-space-1);
}

.cc-live-dot {
    width: 8px;
    height: 8px;
    border-radius: var(--sp-radius-full);
    background: var(--sp-success);
    flex-shrink: 0;
    animation: cc-pulse 2s ease-in-out infinite;
}

.cc-session-meta {
    display: flex;
    gap: var(--sp-space-3);
    font-size: var(--sp-text-xs);
    color: var(--sp-text-secondary);
}

.cc-session-err {
    color: var(--sp-danger);
    font-weight: 600;
}

@media (prefers-reduced-motion: reduce) {
    .cc-session-live-dot,
    .cc-live-dot {
        animation: none;
    }
}

}

@layer components {

.cc-stats-bar {
    display: flex;
    align-items: center;
    gap: var(--sp-space-3);
    padding: var(--sp-space-4) var(--sp-space-5);
    background: var(--sp-bg-hero-gradient);
    border: 1px solid var(--sp-border-default);
    border-top: 3px solid var(--sp-accent);
    border-radius: var(--sp-radius-card-brand);
    margin-bottom: var(--sp-space-5);
    box-shadow: var(--sp-shadow-hero), var(--sp-shadow-inner-glow);
    flex-wrap: wrap;
}

.cc-stat-item {
    display: flex;
    align-items: baseline;
    gap: var(--sp-space-1);
}

.cc-stat-value {
    font-size: var(--sp-text-lg);
    font-weight: 700;
    color: var(--sp-text-primary);
    font-variant-numeric: tabular-nums;
}

.cc-stat-label {
    font-size: var(--sp-text-xs);
    color: var(--sp-text-tertiary);
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.cc-stat-sep {
    color: var(--sp-text-disabled);
    font-size: var(--sp-text-sm);
    user-select: none;
    opacity: 0.5;
}

.cc-stat-primary .cc-stat-value { font-size: var(--sp-text-2xl); }
.cc-stat-success { color: var(--sp-success); }
.cc-stat-warning { color: var(--sp-warning); }
.cc-stat-danger { color: var(--sp-danger); }
.cc-health-excellent { color: var(--sp-success); }
.cc-health-good { color: var(--sp-success); opacity: 0.85; }
.cc-health-fair { color: var(--sp-warning); }
.cc-health-attention { color: var(--sp-danger); }

.cc-suggestion-banner {
    display: flex;
    align-items: flex-start;
    gap: var(--sp-space-3);
    padding: var(--sp-space-3) var(--sp-space-4);
    background: color-mix(in oklch, var(--sp-accent) 5%, var(--sp-bg-surface));
    border: 1px solid var(--sp-border-subtle);
    border-left: 3px solid var(--sp-accent);
    border-radius: var(--sp-radius-card-brand);
    margin-bottom: var(--sp-space-5);
}

.cc-suggestion-icon {
    font-size: var(--sp-text-lg);
    flex-shrink: 0;
}

.cc-suggestion-text {
    margin: 0;
    font-size: var(--sp-text-sm);
    color: var(--sp-text-secondary);
    line-height: 1.5;
}

.cc-stat-range {
    margin-left: auto;
    font-size: var(--sp-text-xs);
    color: var(--sp-text-disabled);
    text-transform: uppercase;
    letter-spacing: 0.06em;
    font-weight: 600;
}

.cc-apm-section {
    margin-bottom: var(--sp-space-5);
}

.cc-apm-section .cc-section-header h3 {
    font-size: var(--sp-text-sm);
    font-weight: 700;
    color: var(--sp-text-primary);
    text-transform: uppercase;
    letter-spacing: 0.06em;
    margin: 0 0 var(--sp-space-3) 0;
}

.cc-apm-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
    gap: var(--sp-space-3);
}

.cc-apm-card {
    background: var(--sp-bg-surface-gradient);
    border: 1px solid var(--sp-border-subtle);
    border-radius: var(--sp-radius-card-brand);
    padding: var(--sp-space-3) var(--sp-space-4);
    box-shadow: var(--sp-shadow-card), var(--sp-shadow-inner-glow);
    text-align: center;
    transition: border-color var(--sp-duration-fast), box-shadow var(--sp-duration-fast);
}

.cc-apm-card:hover {
    border-color: var(--sp-border-default);
    box-shadow: var(--sp-shadow-lift);
}

.cc-apm-label {
    font-size: var(--sp-text-xs);
    font-weight: 600;
    color: var(--sp-text-tertiary);
    text-transform: uppercase;
    letter-spacing: 0.05em;
    margin-bottom: var(--sp-space-1);
}

.cc-apm-value {
    font-size: var(--sp-text-xl);
    font-weight: 700;
    color: var(--sp-text-primary);
    font-variant-numeric: tabular-nums;
    line-height: 1.2;
}

.cc-apm-sub {
    font-size: var(--sp-text-xs);
    color: var(--sp-text-tertiary);
    margin-top: var(--sp-space-1);
}

.cc-help-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 14px;
    height: 14px;
    font-size: 0.6rem;
    font-weight: 700;
    color: var(--sp-text-disabled);
    border: 1px solid var(--sp-border-subtle);
    border-radius: var(--sp-radius-full);
    text-decoration: none;
    vertical-align: middle;
    margin-left: 0.125rem;
    transition: color var(--sp-duration-fast), border-color var(--sp-duration-fast);
}

.cc-help-icon:hover {
    color: var(--sp-accent);
    border-color: var(--sp-accent);
}

.cc-main-grid {
    display: grid;
    grid-template-columns: 2fr 1fr;
    gap: var(--sp-space-5);
    align-items: start;
}

.cc-feed-panel {
    min-width: 0;
}

.cc-panel-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: var(--sp-space-3);
}

.cc-panel-header h3 {
    margin: 0;
    font-size: var(--sp-text-base);
    font-weight: 700;
    color: var(--sp-text-primary);
}

.cc-panel-header--spaced {
    margin-top: var(--sp-space-6);
}

}

@layer components {


.cc-tools {
    background: var(--sp-bg-surface-gradient);
    border: 1px solid var(--sp-border-subtle);
    border-radius: var(--sp-radius-card-inner-brand);
    padding: var(--sp-space-4) var(--sp-space-5);
    box-shadow: var(--sp-shadow-card), var(--sp-shadow-inner-glow);
}

.cc-tool-row {
    display: flex;
    align-items: center;
    gap: var(--sp-space-3);
    padding: var(--sp-space-2) 0;
    border-radius: var(--sp-radius-sm);
    transition: background var(--sp-duration-fast);
}

.cc-tool-row:hover {
    background: color-mix(in oklch, var(--sp-accent) 4%, transparent);
}

.cc-tool-row + .cc-tool-row {
    border-top: 1px solid var(--sp-border-subtle);
    padding-top: var(--sp-space-2);
    margin-top: var(--sp-space-1);
}

.cc-tool-name {
    font-size: var(--sp-text-xs);
    color: var(--sp-text-secondary);
    font-weight: 500;
    min-width: 70px;
    flex-shrink: 0;
}

.cc-tool-bar {
    flex: 1;
    height: 8px;
    background: var(--sp-bg-base);
    border-radius: var(--sp-radius-full);
    overflow: hidden;
    box-shadow: var(--sp-shadow-inset-sm);
}

.cc-tool-fill {
    height: 100%;
    background: linear-gradient(90deg, var(--sp-accent), var(--sp-accent-hover));
    border-radius: var(--sp-radius-full);
    transition: width var(--sp-duration-slow) var(--sp-ease-out);
    box-shadow: 0 1px 3px color-mix(in oklch, var(--sp-accent) 30%, transparent);
}

.cc-tool-count {
    font-size: var(--sp-text-xs);
    font-weight: 600;
    color: var(--sp-text-primary);
    font-variant-numeric: tabular-nums;
    min-width: 32px;
    text-align: right;
}

@media (prefers-reduced-motion: reduce) {
    .cc-tool-fill {
        transition: none;
    }
}

}



.cc-insights-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(400px, 1fr));
    gap: var(--sp-space-4);
    contain: layout style;
}
.cc-insight-card {
    background: var(--sp-bg-surface-gradient);
    border: 1px solid var(--sp-border-subtle);
    border-radius: var(--sp-radius-card-brand);
    padding: var(--sp-space-4);
    box-shadow: var(--sp-shadow-card), var(--sp-shadow-inner-glow);
    display: flex;
    flex-direction: column;
    max-height: 400px;
    transition: border-color var(--sp-duration-fast), box-shadow var(--sp-duration-fast), transform var(--sp-duration-fast);
}
.cc-insight-card:hover {
    border-color: var(--sp-border-default);
    box-shadow: var(--sp-shadow-lift);
    transform: translateY(-1px);
}
.cc-insight-title {
    font-size: var(--sp-text-sm);
    font-weight: 600;
    color: var(--sp-text-primary);
    margin: 0 0 var(--sp-space-3) 0;
    padding-bottom: var(--sp-space-2);
    border-bottom: 1px solid var(--sp-border-subtle);
    flex-shrink: 0;
}
.cc-insight-card > :not(.cc-insight-title) {
    flex: 1;
    min-height: 0;
    overflow-y: auto;
}
.cc-insight-text {
    font-size: var(--sp-text-sm);
    color: var(--sp-text-tertiary);
    line-height: 1.5;
    margin: 0;
}

.cc-insight-bars {
    display: flex;
    flex-direction: column;
    gap: var(--sp-space-1);
}
.cc-bar-row {
    display: flex;
    align-items: center;
    gap: var(--sp-space-2);
}
.cc-bar-label {
    font-size: var(--sp-text-xs);
    color: var(--sp-text-tertiary);
    width: 80px;
    text-align: right;
    flex-shrink: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.cc-bar-track {
    flex: 1;
    height: 6px;
    background: var(--sp-bg-surface-overlay);
    border-radius: var(--sp-radius-xs);
    overflow: hidden;
}
.cc-bar-fill {
    height: 100%;
    width: var(--sp-fill);
    background: linear-gradient(90deg, var(--sp-accent), var(--sp-success));
    border-radius: var(--sp-radius-xs);
    transition: width var(--sp-duration-slow) var(--sp-ease-out);
}
.cc-bar-value {
    font-size: var(--sp-text-xs);
    color: var(--sp-text-primary);
    font-weight: 600;
    width: 40px;
    text-align: right;
    flex-shrink: 0;
}

.cc-insight-card .data-table {
    font-size: var(--sp-text-sm);
}
.cc-insight-card .data-table th {
    font-weight: 500;
    letter-spacing: 0.5px;
}
.cc-insight-card .data-table td {
    color: var(--sp-text-primary);
}
.cc-insight-card .data-table tr:hover td {
    background: var(--sp-bg-surface-raised);
}
.cc-insight-card .table-container {
    border: none;
    box-shadow: none;
}
.cc-insight-card .table-scroll {
    max-height: none;
}

.cc-empty-section {
    padding: var(--sp-space-10) var(--sp-space-5);
    text-align: center;
    color: var(--sp-text-tertiary);
    font-size: var(--sp-text-sm);
}
.cc-empty-hint {
    font-size: var(--sp-text-xs);
    color: var(--sp-text-tertiary);
    opacity: 0.7;
    margin-top: var(--sp-space-2);
}




.cc-skill-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    gap: var(--sp-space-3);
}
.cc-skill-card {
    background: var(--sp-bg-surface-gradient);
    border: 1px solid var(--sp-border-subtle);
    border-radius: var(--sp-radius-card-brand);
    padding: var(--sp-space-4);
    transition: border-color var(--sp-duration-fast), box-shadow var(--sp-duration-fast);
    box-shadow: var(--sp-shadow-card), var(--sp-shadow-inner-glow);
}
.cc-skill-card:hover {
    border-color: var(--sp-accent);
    box-shadow: var(--sp-shadow-card-hover);
}
.cc-skill-card-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    margin-bottom: var(--sp-space-3);
}
.cc-skill-card-name {
    font-size: var(--sp-text-sm);
    font-weight: 600;
    color: var(--sp-text-primary);
    word-break: break-word;
}
.cc-skill-card-stats {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: var(--sp-space-2);
    text-align: center;
}
.cc-skill-stat {
    display: flex;
    flex-direction: column;
}
.cc-skill-stat-value {
    font-size: var(--sp-text-lg);
    font-weight: 700;
    color: var(--sp-text-primary);
    line-height: 1.2;
}
.cc-skill-stat-label {
    font-size: var(--sp-text-xs);
    color: var(--sp-text-tertiary);
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.cc-components-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
    gap: var(--sp-space-4);
}
.cc-component-section {
    background: var(--sp-bg-surface-gradient);
    border: 1px solid var(--sp-border-subtle);
    border-radius: var(--sp-radius-card-brand);
    padding: var(--sp-space-4);
    box-shadow: var(--sp-shadow-card), var(--sp-shadow-inner-glow);
}
.cc-component-title {
    font-size: var(--sp-text-sm);
    font-weight: 600;
    color: var(--sp-text-primary);
    margin: 0 0 var(--sp-space-3) 0;
    padding-bottom: var(--sp-space-2);
    border-bottom: 1px solid var(--sp-border-subtle);
}
.cc-component-list {
    display: flex;
    flex-direction: column;
    gap: var(--sp-space-2);
}
.cc-component-item {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--sp-space-2);
    padding: var(--sp-space-1) 0;
}
.cc-component-count {
    font-size: var(--sp-text-xs);
    color: var(--sp-text-tertiary);
    white-space: nowrap;
}
.cc-component-empty {
    font-size: var(--sp-text-sm);
    color: var(--sp-text-tertiary);
    font-style: italic;
    margin: 0;
}

.cc-filter-bar {
    display: flex;
    gap: var(--sp-space-1);
    margin-bottom: var(--sp-space-3);
}

.cc-filter-btn {
    padding: var(--sp-space-1) var(--sp-space-3);
    font-size: var(--sp-text-xs);
    font-weight: 500;
    font-family: inherit;
    border: 1px solid var(--sp-border-subtle);
    border-radius: var(--sp-radius-full);
    background: transparent;
    color: var(--sp-text-tertiary);
    cursor: pointer;
    transition: background var(--sp-duration-fast),
                color var(--sp-duration-fast),
                border-color var(--sp-duration-fast);
}

.cc-filter-btn:hover {
    color: var(--sp-text-primary);
    border-color: var(--sp-border-default);
}

.cc-filter-btn:focus-visible {
    outline: 2px solid var(--sp-accent);
    outline-offset: 2px;
}

.cc-filter-btn--active {
    background: var(--sp-accent-dim);
    color: var(--sp-accent);
    border-color: var(--sp-accent);
}

.cc-tabs {
    display: flex;
    gap: 0.125rem;
    margin: 0;
    padding: 0 var(--sp-space-4);
    background: var(--sp-bg-card-header);
    border-bottom: 2px solid var(--sp-border-default);
    border-radius: var(--sp-radius-card) var(--sp-radius-brand-tr) 0 0;
}

.cc-tab {
    padding: var(--sp-space-3) var(--sp-space-5);
    background: transparent;
    color: var(--sp-text-tertiary);
    border: none;
    border-bottom: 2px solid transparent;
    cursor: pointer;
    font-size: var(--sp-text-sm);
    font-weight: 500;
    font-family: inherit;
    transition: color var(--sp-duration-fast), border-color var(--sp-duration-fast), box-shadow var(--sp-duration-fast);
    white-space: nowrap;
}

.cc-tab:hover {
    color: var(--sp-text-primary);
    background: color-mix(in oklch, var(--sp-text-primary) 3%, transparent);
}

.cc-tab:focus-visible {
    outline: 2px solid var(--sp-accent);
    outline-offset: -2px;
}

.cc-tab--active {
    color: var(--sp-accent);
    border-bottom-color: var(--sp-accent);
    box-shadow: 0 2px 8px color-mix(in oklch, var(--sp-accent) 25%, transparent);
    background: color-mix(in oklch, var(--sp-accent) 4%, transparent);
    font-weight: 600;
}

.cc-tab-panel {
    display: none;
    padding: var(--sp-space-4);
}

.cc-tab-panel--active {
    display: block;
}

.cc-rating {
    display: inline-flex;
    gap: 0.125rem;
    align-items: center;
}

.cc-rating--small {
    font-size: var(--sp-text-sm);
}

.cc-rating--readonly .cc-star {
    cursor: default;
    pointer-events: none;
}

.cc-rating--readonly .cc-star:hover {
    transform: none;
}

.cc-star {
    color: var(--sp-border-default);
    cursor: pointer;
    font-size: var(--sp-text-md);
    line-height: 1;
    transition: color var(--sp-duration-fast) var(--sp-ease-spring), transform var(--sp-duration-fast) var(--sp-ease-spring);
    user-select: none;
}

.cc-star:hover,
.cc-star--filled {
    color: var(--sp-warning);
}

.cc-star:hover {
    transform: scale(1.15);
}

.cc-rating:hover .cc-star {
    color: var(--sp-border-default);
}

.cc-rating:hover .cc-star:hover,
.cc-rating:hover .cc-star:hover ~ .cc-star {
    color: var(--sp-border-default);
}

.cc-rating:hover .cc-star {
    color: var(--sp-border-default);
}

.cc-rating .cc-star.cc-star--hover-fill {
    color: var(--sp-warning);
}

@media (prefers-reduced-motion: reduce) {
    .cc-star {
        transition: none;
    }
    .cc-star:hover {
        transform: none;
    }
}


.cc-usage-limits-card {
    background: var(--sp-bg-surface-gradient);
    border: 1px solid var(--sp-border-subtle);
    border-radius: var(--sp-radius-card-brand);
    padding: var(--sp-space-4);
    margin-bottom: var(--sp-space-4);
    box-shadow: var(--sp-shadow-card), var(--sp-shadow-inner-glow);
}

.cc-usage-limits-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: var(--sp-space-3);
    padding-bottom: var(--sp-space-2);
    border-bottom: 1px solid var(--sp-border-subtle);
}

.cc-usage-limits-header h3 {
    font-size: var(--sp-text-sm);
    font-weight: 600;
    color: var(--sp-text-primary);
    margin: 0;
}

.cc-plan-badge {
    font-size: var(--sp-text-xs);
    font-weight: 700;
    padding: 0.125rem var(--sp-space-2);
    border-radius: var(--sp-radius-full);
    background: color-mix(in oklch, var(--sp-accent) 15%, transparent);
    color: var(--sp-accent);
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.cc-limits-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
    gap: var(--sp-space-3);
}

.cc-limit-row {
    display: flex;
    flex-direction: column;
    gap: var(--sp-space-1);
}

.cc-limit-info {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
}

.cc-limit-label {
    font-size: var(--sp-text-xs);
    color: var(--sp-text-tertiary);
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.cc-limit-count {
    font-size: var(--sp-text-xs);
    color: var(--sp-text-secondary);
    font-variant-numeric: tabular-nums;
}

.cc-limit-bar-track {
    height: 6px;
    background: var(--sp-bg-surface-overlay);
    border-radius: var(--sp-radius-xs);
    overflow: hidden;
}

.cc-limit-bar-fill {
    height: 100%;
    width: var(--sp-fill);
    border-radius: var(--sp-radius-xs);
    transition: width var(--sp-duration-slow) var(--sp-ease-out);
}

.cc-limit-bar--green {
    background: var(--sp-success);
}

.cc-limit-bar--yellow {
    background: var(--sp-warning);
}

.cc-limit-bar--orange {
    background: color-mix(in oklch, var(--sp-warning) 60%, var(--sp-danger));
}

.cc-limit-bar--red {
    background: var(--sp-danger);
}

.cc-limit-warnings {
    margin-top: var(--sp-space-3);
    display: flex;
    flex-direction: column;
    gap: var(--sp-space-2);
}

.cc-limit-warning {
    font-size: var(--sp-text-xs);
    padding: var(--sp-space-2) var(--sp-space-3);
    border-radius: var(--sp-radius-sm);
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--sp-space-2);
    line-height: 1.4;
}

.cc-limit-warning--caution {
    background: color-mix(in oklch, var(--sp-warning) 10%, transparent);
    color: var(--sp-warning);
    border: 1px solid color-mix(in oklch, var(--sp-warning) 20%, transparent);
}

.cc-limit-warning--critical {
    background: color-mix(in oklch, var(--sp-danger) 10%, transparent);
    color: var(--sp-danger);
    border: 1px solid color-mix(in oklch, var(--sp-danger) 20%, transparent);
}

.cc-limit-upgrade-link {
    font-weight: 700;
    text-decoration: none;
    color: inherit;
    white-space: nowrap;
    padding: 0.125rem var(--sp-space-2);
    border-radius: var(--sp-radius-xs);
    background: color-mix(in oklch, currentColor 12%, transparent);
    transition: background var(--sp-duration-fast);
}

.cc-limit-upgrade-link:hover {
    background: color-mix(in oklch, currentColor 20%, transparent);
}



.cc-onboarding-code {
    display: flex;
    align-items: center;
    gap: var(--sp-space-2);
    background: var(--sp-bg-surface-overlay);
    border: 1px solid var(--sp-border-subtle);
    border-radius: var(--sp-radius-sm);
    padding: var(--sp-space-2) var(--sp-space-3);
    margin: var(--sp-space-2) 0;
}
.cc-onboarding-code code {
    flex: 1;
    font-family: var(--sp-font-mono);
    font-size: var(--sp-text-xs);
    color: var(--sp-text-primary);
    word-break: break-all;
}
.cc-onboarding-code .btn-copy {
    flex-shrink: 0;
    padding: var(--sp-space-1) var(--sp-space-2);
    font-size: var(--sp-text-xs);
    background: transparent;
    border: 1px solid var(--sp-border-default);
    border-radius: var(--sp-radius-sm);
    color: var(--sp-text-secondary);
    cursor: pointer;
    font-family: inherit;
    transition: color var(--sp-duration-fast),
                border-color var(--sp-duration-fast);
}
.cc-onboarding-code .btn-copy:hover {
    color: var(--sp-accent);
    border-color: var(--sp-accent);
}
.cc-onboarding-table {
    width: 100%;
    border-collapse: collapse;
    font-size: var(--sp-text-sm);
    margin: var(--sp-space-2) 0;
}
.cc-onboarding-table th,
.cc-onboarding-table td {
    text-align: left;
    padding: var(--sp-space-1) var(--sp-space-2);
    border-bottom: 1px solid var(--sp-border-subtle);
}
.cc-onboarding-table th {
    color: var(--sp-text-tertiary);
    font-weight: 500;
    font-size: var(--sp-text-xs);
}
.cc-onboarding-table td {
    color: var(--sp-text-primary);
    font-family: var(--sp-font-mono);
    font-size: var(--sp-text-xs);
}
.cc-onboarding--hiding {
    opacity: 0;
    transform: translateY(-8px);
    transition: opacity var(--sp-duration-slow) var(--sp-ease-out), transform var(--sp-duration-slow) var(--sp-ease-out);
}

@media (max-width: 768px) {
    .cc-tabs {
        overflow-x: auto;
    }
    .cc-skill-grid,
    .cc-components-grid,
    .cc-insights-grid {
        grid-template-columns: 1fr;
    }
    .cc-skill-card-stats {
        grid-template-columns: repeat(2, 1fr);
    }
    .cc-perf-summary-grid {
        grid-template-columns: repeat(2, 1fr);
    }
    .cc-session-meta {
        flex-wrap: wrap;
    }
    .cc-onboarding-tabs {
        overflow-x: auto;
    }
    .cc-onboarding-step {
        flex-direction: column;
    }
    .cc-step-content h3 {
        line-height: 1.4;
    }
}

@media (prefers-reduced-motion: reduce) {
    .cc-onboarding--hiding {
        transition: none;
    }
}




.cc-onboarding {
    max-width: 720px;
    margin: 0 auto;
    padding: var(--sp-space-6) var(--sp-space-4);
}
.cc-onboarding-header {
    text-align: center;
    margin-bottom: var(--sp-space-6);
}
.cc-onboarding-header h2 {
    font-size: var(--sp-text-xl);
    font-weight: 700;
    color: var(--sp-text-primary);
    margin: 0 0 var(--sp-space-2) 0;
}
.cc-onboarding-header p {
    font-size: var(--sp-text-sm);
    color: var(--sp-text-tertiary);
    margin: 0;
    line-height: 1.6;
}
.cc-onboarding-tabs {
    display: flex;
    gap: 0.125rem;
    margin: 0 0 0.0625rem 0;
    padding: 0;
    border-bottom: 1px solid var(--sp-border-subtle);
}
.cc-onboarding-tab {
    padding: var(--sp-space-3) var(--sp-space-5);
    background: transparent;
    color: var(--sp-text-tertiary);
    border: none;
    border-bottom: 2px solid transparent;
    cursor: pointer;
    font-size: var(--sp-text-sm);
    font-weight: 500;
    font-family: inherit;
    transition: color var(--sp-duration-fast), border-color var(--sp-duration-fast), box-shadow var(--sp-duration-fast);
    white-space: nowrap;
}
.cc-onboarding-tab:hover {
    color: var(--sp-text-primary);
}
.cc-onboarding-tab--active {
    color: var(--sp-accent);
    border-bottom-color: var(--sp-accent);
    box-shadow: 0 2px 6px color-mix(in oklch, var(--sp-accent) 20%, transparent);
}
.cc-onboarding-panel {
    display: none;
    padding: var(--sp-space-4) 0;
}
.cc-onboarding-panel--active {
    display: block;
}
.cc-onboarding-steps {
    display: flex;
    flex-direction: column;
    gap: var(--sp-space-4);
}
.cc-onboarding-step {
    display: flex;
    gap: var(--sp-space-4);
    background: var(--sp-bg-surface-gradient);
    border: 1px solid var(--sp-border-subtle);
    border-radius: var(--sp-radius-card-brand);
    padding: var(--sp-space-4);
    box-shadow: var(--sp-shadow-card), var(--sp-shadow-inner-glow);
}
.cc-step-number {
    width: 32px;
    height: 32px;
    min-width: 32px;
    border-radius: var(--sp-radius-full);
    background: var(--sp-accent-dim);
    color: var(--sp-accent);
    font-weight: 700;
    font-size: var(--sp-text-sm);
    display: flex;
    align-items: center;
    justify-content: center;
    line-height: 1;
}
.cc-step-content {
    flex: 1;
    min-width: 0;
}
.cc-step-content h3 {
    font-size: var(--sp-text-sm);
    font-weight: 600;
    color: var(--sp-text-primary);
    margin: 0 0 var(--sp-space-2) 0;
    line-height: 32px;
}
.cc-step-content p {
    font-size: var(--sp-text-sm);
    color: var(--sp-text-secondary);
    margin: 0 0 var(--sp-space-2) 0;
    line-height: 1.5;
}
.cc-step-content p:last-child {
    margin-bottom: 0;
}

.sp-onboarding-banner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--sp-space-3);
    padding: var(--sp-space-2) var(--sp-space-4);
    background: color-mix(in oklch, var(--sp-accent) 8%, var(--sp-bg-surface));
    border: 1px solid color-mix(in oklch, var(--sp-accent) 20%, transparent);
    border-radius: var(--sp-radius-sm);
    margin: var(--sp-space-3) var(--sp-space-4) 0;
    font-size: var(--sp-text-sm);
    color: var(--sp-text-secondary);
}

.sp-onboarding-banner[hidden] {
    display: none;
}

.sp-onboarding-banner__content {
    display: flex;
    align-items: center;
    gap: var(--sp-space-2);
    flex: 1;
    min-width: 0;
}

.sp-onboarding-banner__icon {
    flex-shrink: 0;
    color: var(--sp-accent);
}

.sp-onboarding-banner__link {
    font-weight: 600;
    color: var(--sp-accent);
    text-decoration: none;
    white-space: nowrap;
}

.sp-onboarding-banner__link:hover {
    text-decoration: underline;
}

.sp-onboarding-banner__dismiss {
    flex-shrink: 0;
    background: transparent;
    border: none;
    color: var(--sp-text-tertiary);
    cursor: pointer;
    font-size: var(--sp-text-lg);
    padding: var(--sp-space-1);
    line-height: 1;
    font-family: inherit;
}

.sp-onboarding-banner__dismiss:hover {
    color: var(--sp-text-primary);
}

@media (max-width: 48rem) {
    .sp-onboarding-banner__content {
        flex-wrap: wrap;
    }
}

.cc-entity-pill {
    display: inline-block;
    padding: 0.125rem var(--sp-space-2);
    border-radius: var(--sp-radius-badge);
    font-size: var(--sp-text-xs);
    font-weight: 500;
    line-height: 1.4;
    white-space: nowrap;
    max-width: 160px;
    overflow: hidden;
    text-overflow: ellipsis;
    vertical-align: middle;
}

.cc-entity-pill--skill {
    background: color-mix(in oklch, var(--sp-section-plugins) 15%, transparent);
    color: var(--sp-section-plugins);
    border: 1px solid color-mix(in oklch, var(--sp-section-plugins) 30%, transparent);
}

.cc-entity-pill--agent {
    background: color-mix(in oklch, var(--sp-section-users) 15%, transparent);
    color: var(--sp-section-users);
    border: 1px solid color-mix(in oklch, var(--sp-section-users) 30%, transparent);
}

.cc-entity-pill--mcp_tool {
    background: color-mix(in oklch, var(--sp-success) 15%, transparent);
    color: var(--sp-success);
    border: 1px solid color-mix(in oklch, var(--sp-success) 30%, transparent);
}

.sf-session-entities {
    display: inline-flex;
    gap: var(--sp-space-1);
    flex-wrap: wrap;
    margin: 0 var(--sp-space-1);
}

.cc-session-meta {
    display: flex;
    align-items: center;
    gap: var(--sp-space-4);
    padding: var(--sp-space-2) var(--sp-space-4);
    border-bottom: 1px solid var(--sp-border-subtle);
    background: var(--sp-bg-surface-raised);
}

@layer components {

.data-table th.col-checkbox,
.data-table td.col-checkbox {
    width: 40px;
    min-width: 40px;
    max-width: 40px;
    padding: var(--sp-space-2) var(--sp-space-2) var(--sp-space-2) var(--sp-space-3);
    text-align: center;
    vertical-align: middle;
}

.entity-batch-checkbox {
    cursor: pointer;
    accent-color: var(--sp-accent);
    width: 16px;
    height: 16px;
    margin: 0;
}

.entity-batch-checkbox:disabled {
    opacity: 0.3;
    cursor: not-allowed;
}

.entity-batch-bar {
    display: flex;
    align-items: center;
    gap: var(--sp-space-3);
    padding: var(--sp-space-2) var(--sp-space-4);
    margin-bottom: var(--sp-space-3);
    background: color-mix(in oklch, var(--sp-accent) 8%, var(--sp-bg-surface));
    border: 1px solid color-mix(in oklch, var(--sp-accent) 25%, var(--sp-border-subtle));
    border-radius: var(--sp-radius-card-brand);
    position: sticky;
    top: 0;
    z-index: var(--sp-z-sticky-header);
    transition: opacity var(--sp-duration-fast) var(--sp-ease-in-out);
}

.entity-batch-bar[hidden] {
    display: none;
}

.entity-batch-count {
    font-size: var(--sp-text-sm);
    font-weight: 600;
    color: var(--sp-text-primary);
    white-space: nowrap;
    font-variant-numeric: tabular-nums;
}

.entity-batch-btn {
    padding: var(--sp-space-1) var(--sp-space-3);
    font-size: var(--sp-text-xs);
    font-weight: 500;
    font-family: inherit;
    border: 1px solid var(--sp-border-subtle);
    border-radius: var(--sp-radius-full);
    background: var(--sp-bg-surface);
    color: var(--sp-text-secondary);
    cursor: pointer;
    white-space: nowrap;
    transition: background var(--sp-duration-fast),
                border-color var(--sp-duration-fast),
                color var(--sp-duration-fast);
}

.entity-batch-btn:hover {
    background: var(--sp-bg-surface-raised);
    border-color: var(--sp-accent);
    color: var(--sp-text-primary);
}

.entity-batch-btn--danger {
    color: var(--sp-danger);
    border-color: color-mix(in oklch, var(--sp-danger) 30%, var(--sp-border-subtle));
}

.entity-batch-btn--danger:hover {
    background: color-mix(in oklch, var(--sp-danger) 8%, var(--sp-bg-surface));
    border-color: var(--sp-danger);
    color: var(--sp-danger);
}

.data-table tr.entity-row--selected td {
    background: color-mix(in oklch, var(--sp-accent) 6%, var(--sp-bg-surface));
}

.data-table tr.entity-row--selected td:first-child {
    box-shadow: inset 3px 0 0 var(--sp-accent);
}

.data-table tr.entity-row--leaving td {
    opacity: 0;
    transform: translateY(-4px);
    transition: opacity 300ms var(--sp-ease-out), transform 300ms var(--sp-ease-out);
    pointer-events: none;
}

@media (max-width: 768px) {
    .entity-batch-bar {
        padding: var(--sp-space-2) var(--sp-space-3);
        gap: var(--sp-space-2);
    }

    .data-table th.col-checkbox,
    .data-table td.col-checkbox {
        width: 36px;
        min-width: 36px;
        max-width: 36px;
        padding: var(--sp-space-1) var(--sp-space-2);
    }

    .entity-batch-checkbox {
        width: 18px;
        height: 18px;
    }
}

@media (max-width: 480px) {
    .entity-batch-bar {
        position: fixed;
        bottom: 0;
        left: 0;
        right: 0;
        top: auto;
        margin: 0;
        border-radius: 0;
        border-left: none;
        border-right: none;
        border-bottom: none;
        z-index: var(--sp-z-sticky-header);
        box-shadow: var(--sp-shadow-md);
        padding: var(--sp-space-3) var(--sp-space-4);
        padding-bottom: calc(var(--sp-space-3) + env(safe-area-inset-bottom, 0px));
    }
}

@media (prefers-reduced-motion: reduce) {
    .data-table tr.entity-row--leaving td {
        transition: none;
    }
}

}

.profile-entity-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(80px, 1fr));
    gap: 0.75rem;
    text-align: center;
}
.profile-entity-card {
    padding: 0.75rem;
    border-radius: var(--sp-radius-card-brand, var(--sp-radius-md));
    background: var(--sp-surface-2);
}
.profile-entity-value {
    display: block;
    font-size: 1.5rem;
    font-weight: 700;
    font-variant-numeric: tabular-nums;
}
.profile-entity-label {
    display: block;
    font-size: 0.7rem;
    color: var(--sp-text-secondary);
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.profile-ai-section .card-body { display: flex; flex-direction: column; gap: 1rem; }
.profile-ai-block {
    padding: 1rem;
    border-radius: var(--sp-radius-md);
    background: var(--sp-surface-1);
}
.profile-ai-block--highlight {
    background: var(--sp-accent-surface);
    border-left: 3px solid var(--sp-accent);
}
.profile-ai-label {
    font-size: 0.75rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--sp-text-secondary);
    margin: 0 0 0.5rem;
}
.profile-ai-text {
    font-size: 0.9rem;
    line-height: 1.6;
    margin: 0;
    white-space: pre-line;
}
.profile-ai-empty {
    color: var(--sp-text-secondary);
    font-size: 0.9rem;
    text-align: center;
    padding: 2rem 1rem;
}
.profile-empty-text {
    color: var(--sp-text-secondary);
    font-size: 0.95rem;
    text-align: center;
    padding: 3rem 1rem;
}

.profile-sw-item--strength .profile-sw-delta { color: var(--sp-success); }
.profile-sw-item--weakness .profile-sw-delta { color: var(--sp-danger); }

@media (prefers-reduced-motion: reduce) {
    .profile-sparkline * {
        animation: none !important;
        transition: none !important;
    }
}

@media (max-width: 768px) {
    .profile-comparison-row { grid-template-columns: 90px 1fr 100px 50px; }
    .profile-sw-grid { grid-template-columns: 1fr; }
    .profile-category-row { grid-template-columns: 80px 1fr 35px 40px; }
    .profile-entity-grid { grid-template-columns: repeat(auto-fit, minmax(70px, 1fr)); }
}

@media (max-width: 480px) {
    .profile-comparison-row {
        grid-template-columns: 1fr;
        gap: 0.25rem;
    }
    .profile-comparison-bars { order: 3; }
    .profile-comparison-values { order: 2; }
    .profile-comparison-delta { order: 4; text-align: left; }
    .profile-category-row {
        grid-template-columns: 1fr auto auto;
    }
    .profile-category-label {
        grid-column: 1 / -1;
    }
}

.profile-comparison-legend {
    display: flex;
    gap: 1rem;
    margin-bottom: 0.75rem;
    font-size: 0.75rem;
}
.profile-comparison-legend-item {
    display: flex;
    align-items: center;
    gap: 0.375rem;
    color: var(--sp-text-secondary);
}
.profile-comparison-legend-swatch {
    display: inline-block;
    width: 12px;
    height: 12px;
    border-radius: 2px;
}
.profile-comparison-legend-swatch--user {
    background: var(--sp-accent);
}
.profile-comparison-legend-swatch--global {
    background: repeating-linear-gradient(
        -45deg,
        var(--sp-text-tertiary),
        var(--sp-text-tertiary) 2px,
        transparent 2px,
        transparent 5px
    );
    opacity: 0.6;
}
.profile-comparison-grid { display: flex; flex-direction: column; gap: 0.75rem; }
.profile-comparison-row {
    display: grid;
    grid-template-columns: 110px 1fr 120px 60px;
    gap: 0.75rem;
    align-items: center;
}
.profile-comparison-label {
    font-size: 0.8rem;
    font-weight: 500;
    white-space: nowrap;
}
.profile-comparison-bars { position: relative; }
.profile-bar-track {
    position: relative;
    height: 20px;
    background: var(--sp-surface-2);
    border-radius: var(--sp-radius-xs);
    overflow: hidden;
}
.profile-bar {
    position: absolute;
    top: 0;
    left: 0;
    height: 100%;
    border-radius: var(--sp-radius-xs);
}
.profile-bar--user {
    background: var(--sp-accent);
    opacity: 0.85;
    z-index: 2;
}
.profile-bar--global {
    background: repeating-linear-gradient(
        -45deg,
        var(--sp-text-tertiary),
        var(--sp-text-tertiary) 2px,
        transparent 2px,
        transparent 5px
    );
    opacity: 0.4;
    z-index: 1;
}
.profile-comparison-values {
    display: flex;
    gap: 0.25rem;
    align-items: center;
    font-size: 0.8rem;
}
.profile-val-user { font-weight: 600; font-variant-numeric: tabular-nums; }
.profile-val-sep { color: var(--sp-text-tertiary); }
.profile-val-global { color: var(--sp-text-secondary); font-variant-numeric: tabular-nums; }
.profile-comparison-delta {
    font-size: 0.75rem;
    font-weight: 600;
    text-align: right;
}
.profile-comparison-delta--positive { color: var(--sp-success); }
.profile-comparison-delta--negative { color: var(--sp-danger); }
.profile-comparison-delta--neutral { color: var(--sp-text-secondary); }

.profile-sw-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
    gap: 1.5rem;
    margin-bottom: 1.5rem;
}
.profile-sw-item {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.5rem 0;
    border-bottom: 1px solid var(--sp-border-color);
}
.profile-sw-item:last-child { border-bottom: none; }
.profile-sw-label { flex: 1; font-size: 0.85rem; font-weight: 500; }
.profile-sw-values { font-size: 0.75rem; color: var(--sp-text-secondary); }
.profile-sw-delta {
    font-size: 0.8rem;
    font-weight: 700;
    min-width: 50px;
    text-align: right;
}
.profile-sw-delta--positive { color: var(--sp-success); }
.profile-sw-delta--negative { color: var(--sp-danger); }

.profile-trends-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
    gap: 1rem;
}
.profile-trend-item { text-align: center; }
.profile-trend-label {
    display: block;
    font-size: 0.75rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--sp-text-secondary);
    margin-bottom: 0.25rem;
}
.profile-sparkline {
    width: 100%;
    height: 30px;
}

.profile-category-list { display: flex; flex-direction: column; gap: 0.5rem; }
.profile-category-row {
    display: grid;
    grid-template-columns: 100px 1fr 40px 40px;
    gap: 0.5rem;
    align-items: center;
    font-size: 0.85rem;
}
.profile-category-label { font-weight: 500; }
.profile-category-bar-track {
    height: 14px;
    background: var(--sp-surface-2);
    border-radius: var(--sp-radius-xs);
    overflow: hidden;
}
.profile-category-bar {
    height: 100%;
    background: var(--sp-accent);
    border-radius: var(--sp-radius-xs);
}
.profile-category-count { text-align: right; font-weight: 600; }
.profile-category-pct { text-align: right; color: var(--sp-text-secondary); }

.profile-hero {
    display: flex;
    gap: 2rem;
    align-items: flex-start;
    margin-bottom: 2rem;
    flex-wrap: wrap;
}
.profile-hero-left { flex: 1 1 400px; }
.profile-hero-right { flex: 0 0 auto; min-width: 200px; }

.profile-archetype-badge {
    display: flex;
    gap: 1rem;
    align-items: flex-start;
    padding: 1.5rem;
    border-radius: var(--sp-radius-lg);
    background: var(--sp-surface-1);
    border: 1px solid var(--sp-border-color);
}
.profile-archetype-icon {
    font-size: 2.5rem;
    line-height: 1;
    flex-shrink: 0;
}
.profile-archetype-info { flex: 1; }
.profile-archetype-name {
    font-size: 1.5rem;
    font-weight: 700;
    margin: 0 0 0.25rem;
    line-height: 1.2;
}
.profile-archetype-desc {
    font-size: 0.875rem;
    color: var(--sp-text-secondary);
    margin: 0 0 0.75rem;
    line-height: 1.5;
}
.profile-archetype-confidence { display: flex; align-items: center; gap: 0.5rem; }
.profile-confidence-bar {
    flex: 1;
    height: 6px;
    background: var(--sp-surface-2);
    border-radius: var(--sp-radius-xs);
    overflow: hidden;
}
.profile-confidence-fill {
    height: 100%;
    background: var(--sp-accent);
    border-radius: var(--sp-radius-xs);
    transition: width 0.3s ease;
}
.profile-confidence-label {
    font-size: 0.75rem;
    color: var(--sp-text-secondary);
    white-space: nowrap;
}

.profile-rank-card {
    padding: 1rem 1.25rem;
    border-radius: var(--sp-radius-md);
    background: var(--sp-surface-1);
    border: 1px solid var(--sp-border-color);
    text-align: center;
}
.profile-rank-level {
    display: block;
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--sp-text-secondary);
}
.profile-rank-name {
    display: block;
    font-size: 1.25rem;
    font-weight: 700;
    margin-bottom: 0.5rem;
}
.profile-xp-bar {
    height: 6px;
    background: var(--sp-surface-2);
    border-radius: var(--sp-radius-xs);
    overflow: hidden;
    margin-bottom: 0.25rem;
}
.profile-xp-fill {
    height: 100%;
    background: var(--sp-success);
    border-radius: var(--sp-radius-xs);
}
.profile-xp-label {
    font-size: 0.75rem;
    color: var(--sp-text-secondary);
}
.profile-streak-row {
    display: flex;
    gap: 1rem;
    justify-content: center;
    margin-top: 0.75rem;
    font-size: 0.8rem;
}
.profile-streak { color: var(--sp-warning); font-weight: 600; }
.profile-streak-best, .profile-rank-pos { color: var(--sp-text-secondary); }

.profile-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(380px, 1fr));
    gap: 1.5rem;
    margin-bottom: 1.5rem;
}
.profile-section { margin-bottom: 1.5rem; }
.profile-period-label {
    font-size: 0.75rem;
    color: var(--sp-text-secondary);
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

@media (max-width: 768px) {
    .profile-hero { flex-direction: column; gap: 1rem; }
    .profile-hero-left { flex: 1 1 100%; }
    .profile-hero-right { width: 100%; min-width: 0; }
    .profile-rank-card { text-align: center; }
    .profile-xp-bar { width: 100%; }
    .profile-streak-row { flex-wrap: wrap; justify-content: center; }
    .profile-grid { grid-template-columns: 1fr; }
    .profile-archetype-badge { flex-direction: column; align-items: center; text-align: center; }
}

@media (max-width: 375px) {
    .profile-archetype-name { font-size: 1.25rem; }
    .profile-rank-name { font-size: 1rem; }
    .profile-streak-row { font-size: 0.75rem; gap: 0.5rem; }
}

@layer components {

html .sf-session-actions {
    display: block;
    position: absolute;
    top: var(--sp-space-4);
    right: var(--sp-space-4);
    flex-shrink: 0;
    z-index: var(--sp-z-sticky);
}

.sf-action-btn {
    background: none;
    border: none;
    cursor: pointer;
    font-size: var(--sp-text-lg);
    color: var(--sp-text-tertiary);
    padding: 0 var(--sp-space-1);
    line-height: 1;
    border-radius: var(--sp-radius-sm);
    transition: background var(--sp-duration-fast), color var(--sp-duration-fast);
}

.sf-action-btn:hover {
    background: color-mix(in oklch, var(--sp-bg-surface) 80%, var(--sp-accent));
    color: var(--sp-text-primary);
}

.sf-action-menu {
    display: none;
    position: absolute;
    right: 0;
    top: 100%;
    z-index: var(--sp-z-dropdown);
    min-width: 160px;
    background: var(--sp-bg-surface);
    border: 1px solid var(--sp-border-default);
    border-radius: var(--sp-radius-md);
    box-shadow: var(--sp-shadow-lg);
    padding: var(--sp-space-1) 0;
}

.sf-action-menu--open {
    display: block;
}

.sf-action-menu--portal {
    display: block;
    position: fixed;
    left: auto;
    z-index: var(--sp-z-dropdown);
}

.sf-action-item {
    display: block;
    width: 100%;
    text-align: left;
    background: none;
    border: none;
    padding: var(--sp-space-2) var(--sp-space-3);
    font-size: var(--sp-text-sm);
    color: var(--sp-text-secondary);
    cursor: pointer;
    transition: background var(--sp-duration-fast);
}

.sf-action-item:hover {
    background: color-mix(in oklch, var(--sp-accent) 8%, transparent);
    color: var(--sp-text-primary);
}

.sf-action-item--danger:hover {
    background: color-mix(in oklch, var(--sp-danger) 8%, transparent);
    color: var(--sp-danger);
}

.sf-session[data-status="completed"] {
    border-left: 3px solid var(--sp-success);
}

.sf-session[data-status="archived"] {
    opacity: 0.6;
}

.sf-session-status-label {
    font-size: var(--sp-text-xs);
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    padding: 0.0625rem var(--sp-space-2);
    border-radius: var(--sp-radius-full);
    white-space: nowrap;
}

.sf-session-status-label--completed {
    color: var(--sp-success);
    background: color-mix(in oklch, var(--sp-success) 10%, transparent);
}

.sf-session-status-label--archived {
    color: var(--sp-text-tertiary);
    background: color-mix(in oklch, var(--sp-text-tertiary) 10%, transparent);
}

.sf-session-status-label--analysed {
    color: var(--sp-accent);
    background: color-mix(in oklch, var(--sp-accent) 10%, transparent);
}

.sf-session-status-label--analysing {
    color: var(--sp-text-tertiary);
    background: color-mix(in oklch, var(--sp-text-tertiary) 10%, transparent);
    animation: pulse 1.5s ease-in-out infinite;
}

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

.sf-action-item--accent {
    color: var(--sp-accent);
    font-weight: 600;
}

.sf-quality-badge {
    font-size: var(--sp-text-xs);
    font-weight: 700;
    padding: 0.0625rem var(--sp-space-2);
    border-radius: var(--sp-radius-full);
    white-space: nowrap;
    letter-spacing: 0.02em;
}
.sf-quality-badge--high {
    color: var(--sp-success);
    background: color-mix(in oklch, var(--sp-success) 12%, transparent);
}
.sf-quality-badge--medium {
    color: var(--sp-warning);
    background: color-mix(in oklch, var(--sp-warning) 12%, transparent);
}
.sf-quality-badge--low {
    color: var(--sp-error);
    background: color-mix(in oklch, var(--sp-error) 12%, transparent);
}

.sf-goal-badge {
    font-size: var(--sp-text-xs);
    font-weight: 600;
    padding: 0.0625rem var(--sp-space-1);
    border-radius: var(--sp-radius-full);
    white-space: nowrap;
}
.sf-goal-badge--yes { color: var(--sp-success); }
.sf-goal-badge--partial { color: var(--sp-warning); }
.sf-goal-badge--no { color: var(--sp-error); }
.sf-goal-badge--unknown { color: var(--sp-text-tertiary); }

.cc-analysis-preview {
    padding: var(--sp-space-3) var(--sp-space-4);
    font-size: var(--sp-text-sm);
    line-height: 1.6;
    border-top: 1px solid var(--sp-border-subtle);
    border-bottom: 1px solid var(--sp-border-subtle);
    background: color-mix(in oklch, var(--sp-accent) 3%, transparent);
    display: flex;
    flex-direction: column;
    gap: var(--sp-space-1);
}
.cc-analysis-desc {
    color: var(--sp-text-secondary);
}
.cc-analysis-rec {
    color: var(--sp-accent);
    font-style: italic;
    font-size: var(--sp-text-xs);
}
.cc-analysis-rec::before {
    content: '\2192 ';
}

}

@layer components {

.sf-badge {
    font-size: var(--sp-text-xs);
    padding: 0.125rem var(--sp-space-2);
    border-radius: var(--sp-radius-badge);
    background: var(--sp-badge-accent-bg);
    color: var(--sp-badge-accent-fg);
    font-weight: 600;
    white-space: nowrap;
    border: 1px solid color-mix(in oklch, var(--sp-accent) 12%, transparent);
}

.sf-badge--tools {
    background: var(--sp-badge-warning-bg);
    color: var(--sp-badge-warning-fg);
    border-color: color-mix(in oklch, var(--sp-warning) 12%, transparent);
}

.sf-badge--error {
    background: var(--sp-badge-danger-bg);
    color: var(--sp-badge-danger-fg);
    border-color: color-mix(in oklch, var(--sp-danger) 12%, transparent);
}

.sf-session-time {
    font-size: var(--sp-text-xs);
    color: var(--sp-text-tertiary);
    white-space: nowrap;
}

.sf-session-active-label {
    font-size: var(--sp-text-xs);
    font-weight: 600;
    color: var(--sp-success);
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.sf-session-right {
    display: flex;
    align-items: center;
    gap: var(--sp-space-3);
    margin-left: auto;
    flex-shrink: 0;
}

.sf-outcome-chip {
    font-size: var(--sp-text-xs);
    font-weight: 500;
    padding: 0.0625rem var(--sp-space-2);
    border-radius: var(--sp-radius-full);
    text-transform: capitalize;
    letter-spacing: 0.02em;
    flex-shrink: 0;
}

.sf-outcome-chip--success {
    background: color-mix(in oklch, var(--sp-success) 15%, transparent);
    color: var(--sp-success);
}

.sf-outcome-chip--partial {
    background: color-mix(in oklch, var(--sp-warning) 15%, transparent);
    color: var(--sp-warning);
}

.sf-outcome-chip--failed {
    background: color-mix(in oklch, var(--sp-danger) 15%, transparent);
    color: var(--sp-danger);
}

.sf-outcome-chip--learning {
    background: color-mix(in oklch, var(--sp-accent) 15%, transparent);
    color: var(--sp-accent);
}

.sf-session-duration {
    font-size: var(--sp-text-xs);
    color: var(--sp-text-tertiary);
    font-variant-numeric: tabular-nums;
}

.sf-tools-bar {
    display: flex;
    gap: var(--sp-space-2);
    flex-wrap: wrap;
    padding: var(--sp-space-2) var(--sp-space-4);
    margin-bottom: var(--sp-space-3);
    background: var(--sp-bg-surface-gradient);
    border: 1px solid var(--sp-border-subtle);
    border-radius: var(--sp-radius-card-brand);
    box-shadow: var(--sp-shadow-xs);
}

.sf-tool-pill {
    font-size: var(--sp-text-xs);
    padding: 0.125rem var(--sp-space-2);
    border-radius: var(--sp-radius-full);
    background: color-mix(in oklch, var(--sp-text-tertiary) 8%, transparent);
    color: var(--sp-text-secondary);
}

.sf-tool-pill strong {
    color: var(--sp-text-primary);
    font-variant-numeric: tabular-nums;
}

@media (max-width: 768px) {
    .sf-session-right {
        flex-shrink: 1;
        flex-wrap: wrap;
        gap: var(--sp-space-1);
    }
}

}

@layer components {

.cc-card-section {
    border-top: 1px solid var(--sp-border-subtle);
}

.cc-card-section-title {
    list-style: none;
    padding: var(--sp-space-2) var(--sp-space-4);
    font-size: var(--sp-text-xs);
    font-weight: 600;
    color: var(--sp-text-secondary);
    cursor: pointer;
    user-select: none;
    transition: background var(--sp-duration-fast);
}

.cc-card-section-title::-webkit-details-marker {
    display: none;
}

.cc-card-section-title::before {
    content: '\25B8';
    display: inline-block;
    margin-right: var(--sp-space-2);
    font-size: 0.625rem;
    transition: transform var(--sp-duration-fast);
}

.cc-card-section[open] > .cc-card-section-title::before {
    transform: rotate(90deg);
}

.cc-card-section-title:hover {
    background: color-mix(in oklch, var(--sp-text-tertiary) 5%, transparent);
}

.cc-card-section-title--error {
    color: var(--sp-danger);
}

.cc-card-section-body {
    padding: var(--sp-space-2) var(--sp-space-4) var(--sp-space-3);
    display: flex;
    flex-direction: column;
    gap: var(--sp-space-2);
}

.cc-turns-expand > summary {
    list-style: none;
    font-size: var(--sp-text-xs);
    color: var(--sp-accent);
    cursor: pointer;
    padding: var(--sp-space-1) 0;
}

.cc-turns-expand > summary::-webkit-details-marker {
    display: none;
}

.cc-card-entities-inline {
    display: flex;
    flex-wrap: wrap;
    gap: var(--sp-space-1);
    padding: var(--sp-space-2) var(--sp-space-4);
    border-top: 1px solid var(--sp-border-subtle);
}

.cc-entity-pill {
    font-size: var(--sp-text-xs);
    padding: 0.0625rem var(--sp-space-2);
    border-radius: var(--sp-radius-full);
    background: color-mix(in oklch, var(--sp-accent) 8%, transparent);
    color: var(--sp-accent);
    white-space: nowrap;
}

.cc-entity-pill--agent {
    background: color-mix(in oklch, var(--sp-success) 8%, transparent);
    color: var(--sp-success);
}

.cc-ai-summary {
    padding: var(--sp-space-2) var(--sp-space-4);
    font-size: var(--sp-text-sm);
    color: var(--sp-text-secondary);
    border-top: 1px solid var(--sp-border-subtle);
    line-height: 1.5;
}

@media (max-width: 768px) {
    .sf-session-header-row1 {
        flex-wrap: wrap;
    }
    .sf-session-header-row2 {
        flex-wrap: wrap;
    }
    .sf-session-title {
        white-space: normal;
        display: -webkit-box;
        -webkit-line-clamp: 2;
        -webkit-box-orient: vertical;
        overflow: hidden;
        flex-basis: 100%;
        min-width: 0;
    }
    .sf-session-right {
        margin-left: 0;
    }
    .cc-select-check {
        top: var(--sp-space-2);
        left: var(--sp-space-2);
    }
    .sf-session-header {
        padding-left: calc(var(--sp-space-2) + 44px + var(--sp-space-2));
        padding-right: calc(var(--sp-space-2) + 44px + var(--sp-space-2));
    }
    .sf-session-project {
        flex-shrink: 1;
        min-width: 0;
        overflow: hidden;
        text-overflow: ellipsis;
        max-width: 40%;
    }
    .sf-action-btn {
        font-size: var(--sp-text-xl);
        padding: var(--sp-space-2);
        min-width: 44px;
        min-height: 44px;
        display: flex;
        align-items: center;
        justify-content: center;
    }
    .sf-action-menu {
        min-width: 200px;
    }
    .sf-action-item {
        padding: var(--sp-space-3) var(--sp-space-4);
        font-size: var(--sp-text-base);
    }
    .cc-session-checkbox {
        -webkit-appearance: none;
        appearance: none;
        width: 20px;
        height: 20px;
        border: 2px solid var(--sp-border-strong);
        border-radius: var(--sp-radius-xs);
        background: var(--sp-bg-surface);
        cursor: pointer;
        position: relative;
        flex-shrink: 0;
        margin: 0;
    }
    .cc-session-checkbox:checked {
        background: var(--sp-accent);
        border-color: var(--sp-accent);
    }
    .cc-session-checkbox:checked::after {
        content: '';
        position: absolute;
        left: 5px;
        top: 1px;
        width: 6px;
        height: 11px;
        border: solid var(--sp-text-on-accent);
        border-width: 0 2.5px 2.5px 0;
        transform: rotate(45deg);
    }
}

}

@layer components {

.sf-feed {
    display: flex;
    flex-direction: column;
    gap: var(--sp-space-3);
}

.sf-session {
    position: relative;
    background: var(--sp-bg-surface-gradient);
    border: 1px solid var(--sp-border-subtle);
    border-radius: var(--sp-radius-card-brand);
    box-shadow: var(--sp-shadow-card), var(--sp-shadow-inner-glow);
    overflow: hidden;
}

.sf-session[data-is-active="true"] {
    border-left: 3px solid var(--sp-success);
}

.sf-feed > .sf-session:nth-child(even) {
    background: var(--sp-bg-surface-alt);
}

.sf-session[open] {
    border-color: color-mix(in oklch, var(--sp-accent) 40%, var(--sp-border-default));
    box-shadow: var(--sp-shadow-elevated), var(--sp-shadow-inner-glow);
    background: var(--sp-bg-surface-raised);
}

.sf-session:not([open]):hover {
    box-shadow: var(--sp-shadow-lift);
    border-color: var(--sp-border-default);
    transform: translateY(-1px);
}

.sf-session-header {
    display: flex;
    flex-direction: column;
    gap: var(--sp-space-2);
    padding: var(--sp-space-3) var(--sp-space-10) var(--sp-space-3) calc(var(--sp-space-4) + 16px + var(--sp-space-2));
    cursor: pointer;
    user-select: none;
    list-style: none;
    transition: background var(--sp-duration-fast);
}

.sf-session-header:hover {
    background: color-mix(in oklch, var(--sp-bg-surface) 85%, var(--sp-accent));
}

.sf-session-header-row1 {
    display: flex;
    align-items: center;
    gap: var(--sp-space-2);
}

.sf-session-header-row2 {
    display: flex;
    align-items: center;
    gap: var(--sp-space-3);
}

.sf-session-title {
    font-weight: 600;
    font-size: var(--sp-text-sm);
    color: var(--sp-text-primary);
    flex: 1;
    min-width: 120px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.sf-session-project {
    font-size: var(--sp-text-xs);
    color: var(--sp-text-tertiary);
    white-space: nowrap;
    margin-left: auto;
    flex-shrink: 0;
}

.sf-metric-chips {
    display: flex;
    gap: var(--sp-space-1);
    font-size: var(--sp-text-xs);
    color: var(--sp-text-tertiary);
    align-items: center;
    flex-wrap: wrap;
}

.sf-metric-chip { white-space: nowrap; }
.sf-metric-sep { opacity: 0.4; }

.sf-chip--source {
    padding: 0 var(--sp-space-1);
    border-radius: var(--sp-radius-sm);
    font-weight: 600;
    font-size: 0.65rem;
    text-transform: uppercase;
    letter-spacing: 0.03em;
}
.sf-chip--source-cli { background: oklch(0.45 0.12 145 / 0.15); color: oklch(0.65 0.14 145); }
.sf-chip--source-vscode { background: oklch(0.45 0.12 250 / 0.15); color: oklch(0.65 0.14 250); }
.sf-chip--source-jetbrains { background: oklch(0.45 0.12 55 / 0.15); color: oklch(0.65 0.14 55); }
.sf-chip--source-desktop { background: oklch(0.45 0.12 300 / 0.15); color: oklch(0.65 0.14 300); }
.sf-chip--source-other { background: oklch(0.45 0.05 0 / 0.15); color: var(--sp-text-secondary); }

.sf-chip--mode {
    padding: 0 var(--sp-space-1);
    border-radius: var(--sp-radius-sm);
    font-weight: 600;
    font-size: 0.65rem;
    text-transform: uppercase;
    letter-spacing: 0.03em;
    background: oklch(0.5 0.12 80 / 0.15);
    color: oklch(0.7 0.14 80);
}

.sf-chip--model {
    font-size: 0.65rem;
    opacity: 0.7;
}

.sf-session-badges {
    display: flex;
    gap: var(--sp-space-2);
    flex-wrap: wrap;
    flex-shrink: 0;
    margin-left: auto;
}

.cc-select-check {
    position: absolute;
    top: var(--sp-space-3);
    left: var(--sp-space-4);
    z-index: 2;
    display: flex;
    align-items: center;
    line-height: 1;
}

.cc-session-checkbox {
    cursor: pointer;
    accent-color: var(--sp-accent);
    width: 16px;
    height: 16px;
    margin: 0;
}

.cc-session--selected {
    background: color-mix(in oklch, var(--sp-accent) 6%, var(--sp-bg-surface));
    border: 1.5px dashed color-mix(in oklch, var(--sp-accent) 50%, var(--sp-border-default));
}

.sf-session--leaving {
    opacity: 0;
    transform: translateY(-4px);
    transition: opacity 300ms var(--sp-ease-out), transform 300ms var(--sp-ease-out);
    pointer-events: none;
}

}

@layer components {


.sf-turns {
    border-top: 2px solid var(--sp-border-default);
    padding: var(--sp-space-3) var(--sp-space-5);
    display: flex;
    flex-direction: column;
    gap: var(--sp-space-3);
    background: var(--sp-bg-surface-raised);
}

.sf-turn {
    display: flex;
    flex-direction: column;
    gap: var(--sp-space-1);
}

.sf-turn + .sf-turn {
    padding-top: var(--sp-space-2);
    border-top: 1px solid color-mix(in oklch, var(--sp-border-subtle) 50%, transparent);
}


.sf-speaker {
    display: inline-block;
    font-size: var(--sp-text-xs);
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    padding: 0.0625rem var(--sp-space-2);
    border-radius: var(--sp-radius-sm);
    flex-shrink: 0;
    margin-right: var(--sp-space-2);
}

.sf-speaker--you {
    background: color-mix(in oklch, var(--sp-accent) 15%, transparent);
    color: var(--sp-accent);
}

.sf-speaker--ai {
    background: color-mix(in oklch, var(--sp-success) 15%, transparent);
    color: var(--sp-success);
}


.sf-prompt {
    display: flex;
    align-items: flex-start;
    padding: var(--sp-space-2);
    background: color-mix(in oklch, var(--sp-accent) 5%, var(--sp-bg-surface));
    border: 1px solid color-mix(in oklch, var(--sp-accent) 15%, transparent);
    border-radius: var(--sp-radius-md);
}

.sf-prompt-text {
    font-size: var(--sp-text-sm);
    color: var(--sp-text-primary);
    line-height: 1.5;
    word-break: break-word;
}


.sf-response {
    display: flex;
    align-items: flex-start;
    padding: var(--sp-space-2);
    background: color-mix(in oklch, var(--sp-success) 4%, var(--sp-bg-surface));
    border: 1px solid color-mix(in oklch, var(--sp-success) 12%, transparent);
    border-radius: var(--sp-radius-md);
}

.sf-response-text {
    font-size: var(--sp-text-sm);
    color: var(--sp-text-secondary);
    line-height: 1.5;
    word-break: break-word;
    overflow: hidden;
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
}


.sf-tools-summary {
    font-size: var(--sp-text-xs);
    color: var(--sp-text-tertiary);
}

.sf-tools-toggle {
    cursor: pointer;
    user-select: none;
    list-style: none;
    display: flex;
    align-items: center;
    gap: var(--sp-space-1);
    padding: var(--sp-space-1) var(--sp-space-2);
    border-radius: var(--sp-radius-sm);
    transition: background var(--sp-duration-fast);
}


.sf-tools-toggle:hover {
    background: color-mix(in oklch, var(--sp-text-tertiary) 8%, transparent);
}

.sf-tools-arrow {
    display: inline-block;
    transition: transform var(--sp-duration-fast);
    font-size: 0.625rem;
}

.sf-tools-summary[open] .sf-tools-arrow {
    transform: rotate(90deg);
}

.sf-tool-chip {
    display: inline-block;
    padding: 0 var(--sp-space-1);
    margin-left: var(--sp-space-1);
    background: color-mix(in oklch, var(--sp-warning) 10%, transparent);
    color: var(--sp-warning);
    border-radius: var(--sp-radius-sm);
    font-weight: 500;
    font-size: var(--sp-text-xs);
}


.sf-error {
    display: flex;
    align-items: flex-start;
    gap: var(--sp-space-2);
    padding: var(--sp-space-2) var(--sp-space-3);
    background: color-mix(in oklch, var(--sp-danger) 6%, var(--sp-bg-surface));
    border: 1px solid color-mix(in oklch, var(--sp-danger) 20%, transparent);
    border-radius: var(--sp-radius-sm);
    font-size: var(--sp-text-xs);
}

.sf-error-icon {
    color: var(--sp-danger);
    font-weight: 700;
    flex-shrink: 0;
}

.sf-error-tool {
    color: var(--sp-danger);
    font-weight: 600;
    white-space: nowrap;
}

.sf-error-desc {
    color: var(--sp-text-secondary);
    word-break: break-word;
}


.sf-turn {
    transition: opacity var(--sp-duration-normal) var(--sp-ease-out), transform var(--sp-duration-normal) var(--sp-ease-out);
}

.sf-turn--entering {
    opacity: 0;
    transform: translateY(-8px);
}

@media (prefers-reduced-motion: reduce) {
    .sf-turn {
        transition: none;
    }
    .sf-turn--entering {
        transform: none;
    }
}

}

@layer components {

.status-badge {
    display: inline-flex;
    align-items: center;
    padding: 0.125rem var(--sp-space-2);
    border-radius: var(--sp-radius-badge);
    font-size: var(--sp-text-xs);
    font-weight: 500;
    border: 1px solid color-mix(in oklch, currentColor 15%, transparent);
}

.status-active {
    background: var(--sp-success-dim);
    color: var(--sp-success);
}

.status-inactive {
    background: var(--sp-bg-surface-raised);
    color: var(--sp-text-tertiary);
}

.tier-badge {
    font-size: var(--sp-text-xs);
    line-height: 1;
    font-weight: 500;
    color: var(--sp-text-tertiary);
}

.tier-badge.tier-premium {
    color: var(--sp-success);
    font-weight: 600;
}


.badge {
    display: inline-flex;
    align-items: center;
    padding: 0.125rem var(--sp-space-2);
    border-radius: var(--sp-radius-badge);
    font-size: var(--sp-text-xs);
    font-weight: 500;
    border: 1px solid color-mix(in oklch, currentColor 15%, transparent);
    line-height: 1.4;
    white-space: nowrap;
}

.badge-subtle {
    background: var(--sp-bg-surface-raised);
    padding: 0.125rem var(--sp-space-2);
    border-radius: var(--sp-radius-xs);
    font-size: var(--sp-text-xs);
    color: var(--sp-text-secondary);
}

.badge-green,
.badge-success { color: var(--sp-success); background: var(--sp-success-dim); border-color: color-mix(in oklch, var(--sp-success) 15%, transparent); }
.badge-red,
.badge-danger { color: var(--sp-danger); background: var(--sp-danger-dim); border-color: color-mix(in oklch, var(--sp-danger) 15%, transparent); }
.badge-warning { color: var(--sp-warning); background: color-mix(in oklch, var(--sp-warning) 12%, transparent); border-color: color-mix(in oklch, var(--sp-warning) 15%, transparent); }
.badge-info { color: var(--sp-info); background: color-mix(in oklch, var(--sp-accent) 12%, transparent); border-color: color-mix(in oklch, var(--sp-accent) 15%, transparent); }
.badge-gray,
.badge-secondary { color: var(--sp-text-secondary); background: var(--sp-bg-tertiary); border-color: var(--sp-border-subtle); }
.badge-sm { font-size: var(--sp-text-xs); padding: 0.0625rem var(--sp-space-1); }

}

@layer components {

.btn {
    display: inline-flex;
    align-items: center;
    gap: var(--sp-space-2);
    padding: var(--sp-space-2) var(--sp-space-4);
    border: 1px solid transparent;
    border-radius: var(--sp-radius-button);
    font-size: var(--sp-text-sm);
    font-weight: 600;
    font-family: inherit;
    cursor: pointer;
    transition: background var(--sp-duration-fast) var(--sp-ease-in-out),
                color var(--sp-duration-fast) var(--sp-ease-in-out),
                border-color var(--sp-duration-fast) var(--sp-ease-in-out),
                box-shadow var(--sp-duration-fast) var(--sp-ease-in-out),
                transform var(--sp-duration-fast) var(--sp-ease-in-out);
    text-decoration: none;
    white-space: nowrap;
    line-height: 20px;
}

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

.btn:focus-visible {
    outline: none;
    box-shadow: 0 0 0 2px var(--sp-bg-canvas), 0 0 0 4px var(--sp-accent);
}

.btn-primary {
    background: linear-gradient(180deg, var(--sp-accent) 0%, var(--sp-accent-hover) 100%);
    color: var(--sp-text-on-accent);
    border-color: var(--sp-accent);
    box-shadow: var(--sp-shadow-accent-sm);
}

.btn-primary:hover {
    background: linear-gradient(180deg, color-mix(in oklch, var(--sp-accent) 85%, white) 0%, var(--sp-accent) 100%);
    border-color: var(--sp-accent-hover);
    box-shadow: var(--sp-shadow-accent-md);
}

.btn-primary:active {
    box-shadow: var(--sp-shadow-xs);
}

.btn-secondary {
    background: transparent;
    color: var(--sp-text-secondary);
    border-color: var(--sp-border-default);
    box-shadow: var(--sp-shadow-xs);
}

.btn-secondary:hover {
    background: color-mix(in oklch, var(--sp-warm-900) 4%, transparent);
    border-color: var(--sp-border-strong);
    color: var(--sp-text-primary);
}

.btn-danger {
    background: transparent;
    color: var(--sp-danger);
    border-color: color-mix(in oklch, var(--sp-danger) 30%, transparent);
    box-shadow: var(--sp-shadow-xs);
}

.btn-danger:hover {
    background: var(--sp-danger-dim);
    border-color: color-mix(in oklch, var(--sp-danger) 50%, transparent);
}

.btn-view {
    background: transparent;
    color: var(--sp-accent);
    border-color: color-mix(in oklch, var(--sp-accent) 30%, transparent);
    box-shadow: var(--sp-shadow-xs);
}

.btn-view:hover {
    background: var(--sp-accent-dim);
    border-color: var(--sp-accent);
}

.btn-sm {
    padding: var(--sp-space-1) var(--sp-space-3);
    font-size: var(--sp-text-xs);
}

.btn-icon {
    padding: var(--sp-space-2);
    min-width: 36px;
    justify-content: center;
}

.btn-sm.btn-icon {
    padding: var(--sp-space-1);
    min-width: 28px;
    font-size: var(--sp-text-sm);
}

.btn-outline-primary {
    background: transparent;
    color: var(--sp-accent);
    border-color: color-mix(in oklch, var(--sp-accent) 40%, transparent);
}
.btn-outline-primary:hover {
    background: var(--sp-accent-dim);
    border-color: var(--sp-accent);
}

.btn-outline-danger {
    background: transparent;
    color: var(--sp-danger);
    border-color: color-mix(in oklch, var(--sp-danger) 40%, transparent);
}
.btn-outline-danger:hover {
    background: var(--sp-danger-dim);
    border-color: var(--sp-danger);
}

@media (prefers-reduced-motion: reduce) {
    .btn {
        transition: none;
    }
    .btn:active {
        transform: none;
    }
}

}

@layer components {

.table-container {
    border-radius: var(--sp-radius-card-brand);
    overflow-x: auto;
    overflow-y: auto;
    max-height: calc(100vh - 230px);
    box-shadow: var(--sp-shadow-card), var(--sp-shadow-inner-glow);
    background: var(--sp-bg-surface);
    border: 1px solid var(--sp-border-subtle);
}

.table-scroll {
    overflow-x: auto;
}

.card {
    background: var(--sp-bg-surface-gradient);
    border: 1px solid var(--sp-border-subtle);
    border-radius: var(--sp-radius-card-brand);
    padding: var(--sp-space-6);
    box-shadow: var(--sp-shadow-card), var(--sp-shadow-inner-glow);
    transition: box-shadow var(--sp-duration-normal) var(--sp-ease-out),
                border-color var(--sp-duration-normal);
}

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

.card-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: var(--sp-space-2);
    background: var(--sp-bg-card-header);
    margin: calc(-1 * var(--sp-space-6)) calc(-1 * var(--sp-space-6)) var(--sp-space-4);
    padding: var(--sp-space-4) var(--sp-space-6);
    border-radius: 0 var(--sp-radius-brand-tr) 0 0;
    border-bottom: 1px solid var(--sp-border-subtle);
}

.card-header .card-title {
    margin-bottom: 0;
}

.card-body--flush {
    margin: 0 calc(-1 * var(--sp-space-6)) calc(-1 * var(--sp-space-6));
}

.card-body--flush .table-container {
    border: none;
    border-radius: 0;
    box-shadow: none;
    border-top: 1px solid var(--sp-border-subtle);
}

.card > h3:first-child {
    font-size: var(--sp-text-base);
    font-weight: 600;
    color: var(--sp-text-primary);
    margin: 0 0 var(--sp-space-4);
    padding-bottom: var(--sp-space-3);
    border-bottom: 1px solid var(--sp-border-subtle);
}

}

@layer components {

.confirm-overlay {
    position: fixed;
    inset: 0;
    background: var(--sp-overlay-medium);
    backdrop-filter: blur(4px);
    z-index: var(--sp-z-modal);
    display: flex;
    align-items: center;
    justify-content: center;
    animation: fadeIn var(--sp-duration-normal) var(--sp-ease-out);
}

.confirm-dialog {
    background: var(--sp-bg-surface-overlay);
    border: 1px solid var(--sp-border-default);
    border-radius: var(--sp-radius-card-brand);
    padding: var(--sp-space-7);
    max-width: 400px;
    width: 90%;
    box-shadow: var(--sp-shadow-float);
    animation: dialogIn var(--sp-duration-normal) var(--sp-ease-out);
    color: var(--sp-text-primary);
}

@keyframes fadeIn {
    from { opacity: 0; }
    to { opacity: 1; }
}

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

.btn-actions-trigger,
.actions-trigger {
    background: var(--sp-bg-surface);
    border: 1px solid var(--sp-border-default);
    color: var(--sp-text-secondary);
    border-radius: var(--sp-radius-sm);
    cursor: pointer;
    padding: 0;
    width: 32px;
    height: 32px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: var(--sp-text-md);
    line-height: 1;
    letter-spacing: 2px;
    transition: background var(--sp-duration-fast) var(--sp-ease-in-out),
                border-color var(--sp-duration-fast) var(--sp-ease-in-out),
                color var(--sp-duration-fast) var(--sp-ease-in-out);
}

.btn-actions-trigger:hover,
.btn-actions-trigger.active,
.actions-trigger:hover,
.actions-menu.open .actions-trigger {
    background: var(--sp-bg-surface-raised);
    border-color: var(--sp-border-strong);
    color: var(--sp-text-primary);
}

.btn-actions-trigger:focus-visible,
.actions-trigger:focus-visible {
    outline: none;
    box-shadow: 0 0 0 2px var(--sp-bg-canvas), 0 0 0 4px var(--sp-accent);
}

.actions-menu {
    position: relative;
    display: inline-block;
}

.actions-dropdown {
    position: absolute;
    top: 100%;
    right: 0;
    margin-top: var(--sp-space-1);
    background: var(--sp-bg-surface-overlay);
    border: 1px solid var(--sp-border-default);
    border-radius: var(--sp-radius-card-inner-brand);
    box-shadow: var(--sp-shadow-float);
    z-index: var(--sp-z-dropdown);
    min-width: 140px;
    padding: var(--sp-space-1) 0;
    opacity: 0;
    visibility: hidden;
    transform: translateY(-4px);
    transition: opacity var(--sp-duration-fast) var(--sp-ease-in-out),
                visibility var(--sp-duration-fast),
                transform var(--sp-duration-fast) var(--sp-ease-in-out);
}

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

.actions-item {
    display: block;
    width: 100%;
    padding: var(--sp-space-2) var(--sp-space-4);
    background: transparent;
    border: none;
    color: var(--sp-text-secondary);
    font-size: var(--sp-text-sm);
    font-family: inherit;
    font-weight: 500;
    cursor: pointer;
    text-align: left;
    text-decoration: none;
    white-space: nowrap;
    transition: background var(--sp-duration-fast), color var(--sp-duration-fast);
}

.actions-item:hover,
.actions-item:focus-visible {
    background: var(--sp-bg-surface-raised);
    color: var(--sp-text-primary);
    outline: none;
}

.actions-item-danger {
    color: var(--sp-danger);
}

.actions-item-danger:hover {
    background: var(--sp-danger-dim);
    color: var(--sp-danger);
}

.sp-env-dialog {
    width: 560px;
    max-width: 90vw;
}

.sp-env-title {
    margin: 0 0 var(--sp-space-4);
}

.sp-env-scroll {
    max-height: 60vh;
    overflow-y: auto;
}

.sp-env-actions {
    display: flex;
    gap: var(--sp-space-3);
    justify-content: flex-end;
    margin-top: var(--sp-space-4);
}

.sp-env-loading {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: var(--sp-space-6);
    color: var(--sp-text-tertiary);
}

.sp-env-save-success {
    background: var(--sp-success);
    border-color: var(--sp-success);
}

@media (prefers-reduced-motion: reduce) {
    .confirm-overlay,
    .confirm-dialog {
        animation: none;
    }
    .actions-dropdown {
        transition: none;
    }
}

}

@layer components {

.sp-dropdown-portal {
    position: fixed;
    top: 0;
    left: 0;
    width: 0;
    height: 0;
    z-index: var(--sp-z-dropdown);
    pointer-events: none;
}

.sp-dropdown-menu {
    position: fixed;
    left: auto;
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
    pointer-events: auto;
    background: var(--sp-bg-surface-overlay);
    border: 1px solid var(--sp-border-default);
    border-radius: var(--sp-radius-md);
    box-shadow: var(--sp-shadow-lg);
    min-width: 140px;
    padding: var(--sp-space-1) 0;
    z-index: var(--sp-z-dropdown);
}

}

@layer components {

.form-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--sp-space-4);
}

.form-group-wide {
    grid-column: 1 / -1;
}

.checkbox-group {
    display: flex;
    flex-wrap: wrap;
    gap: var(--sp-space-2) var(--sp-space-4);
}

.checkbox-label {
    display: inline-flex;
    align-items: center;
    gap: var(--sp-space-1);
    font-size: var(--sp-text-sm);
    cursor: pointer;
}

.toolbar {
    display: flex;
    gap: var(--sp-space-3);
    align-items: flex-end;
    margin-bottom: var(--sp-space-4);
    flex-wrap: wrap;
}

.search-input {
    width: 100%;
    background: var(--sp-bg-surface);
    border: 1px solid var(--sp-border-default);
    border-radius: var(--sp-radius-button);
    padding: var(--sp-space-2) var(--sp-space-4);
    color: var(--sp-text-primary);
    font-size: var(--sp-text-base);
    font-family: inherit;
    outline: none;
    transition: border-color var(--sp-duration-fast), box-shadow var(--sp-duration-fast);
}

.search-input:focus-visible {
    border-color: var(--sp-accent);
    outline: 2px solid var(--sp-accent-dim);
    outline-offset: -1px;
}

.search-input::placeholder {
    color: var(--sp-text-disabled);
}

.search-group {
    flex: 1;
    min-width: 200px;
    display: flex;
    flex-direction: column;
    gap: 0.125rem;
}

.filter-select {
    background: var(--sp-bg-surface);
    border: 1px solid var(--sp-border-default);
    border-radius: var(--sp-radius-button);
    padding: var(--sp-space-2) var(--sp-space-4);
    color: var(--sp-text-primary);
    font-size: var(--sp-text-sm);
    font-family: inherit;
    outline: none;
    cursor: pointer;
    transition: border-color var(--sp-duration-fast);
}

.filter-select:focus-visible {
    border-color: var(--sp-accent);
    outline: 2px solid var(--sp-accent-dim);
    outline-offset: -1px;
}

.filter-select option {
    background: var(--sp-bg-surface-overlay);
    color: var(--sp-text-primary);
}

.filter-group {
    display: flex;
    flex-direction: column;
    gap: 0.125rem;
}

.filter-label {
    font-size: var(--sp-text-xs);
    font-weight: 600;
    color: var(--sp-text-tertiary);
    text-transform: uppercase;
    letter-spacing: 0.04em;
    line-height: 1;
}

}

@layer components {


.sp-getting-started-checklist .checklist-item {
    display: flex;
    align-items: flex-start;
    gap: var(--sp-space-3);
    padding: var(--sp-space-4) var(--sp-space-6);
    border-bottom: 1px solid var(--sp-border-subtle);
    transition: opacity var(--sp-duration-fast);
}

.sp-getting-started-checklist .checklist-item:last-child {
    border-bottom: none;
    padding-bottom: var(--sp-space-6);
}

.sp-getting-started-checklist .checklist-item input[type="checkbox"] {
    appearance: none;
    margin-top: 0.1875rem;
    width: 20px;
    height: 20px;
    min-width: 20px;
    flex-shrink: 0;
    cursor: pointer;
    border: 2px solid var(--sp-border-strong);
    border-radius: var(--sp-radius-xs);
    background: var(--sp-bg-surface);
    transition: background var(--sp-duration-fast),
                border-color var(--sp-duration-fast);
    position: relative;
}

.sp-getting-started-checklist .checklist-item input[type="checkbox"]:checked {
    background: var(--sp-accent);
    border-color: var(--sp-accent);
}

.sp-getting-started-checklist .checklist-item input[type="checkbox"]:checked::after {
    content: '';
    position: absolute;
    left: 5px;
    top: 1px;
    width: 6px;
    height: 11px;
    border: solid white;
    border-width: 0 2px 2px 0;
    transform: rotate(45deg);
}

.sp-getting-started-checklist .checklist-item label {
    font-weight: 600;
    cursor: pointer;
    display: block;
    margin-bottom: var(--sp-space-1);
    font-size: var(--sp-text-base);
}

.sp-getting-started-checklist .checklist-item .checklist-hint {
    display: block;
    color: var(--sp-text-secondary);
    font-size: var(--sp-text-sm);
}

.gs-banner {
    background: linear-gradient(135deg,
        color-mix(in oklch, var(--sp-accent) 8%, var(--sp-bg-surface)) 0%,
        var(--sp-bg-surface) 100%);
    border: 1px solid color-mix(in oklch, var(--sp-accent) 20%, var(--sp-border-subtle));
    border-radius: var(--sp-radius-card-brand);
    padding: var(--sp-space-10) var(--sp-space-8);
    text-align: center;
    margin-bottom: var(--sp-space-6);
}

.gs-banner-title {
    font-size: var(--sp-text-2xl);
    font-weight: 700;
    color: var(--sp-text-primary);
    margin: 0 0 var(--sp-space-3);
    font-family: var(--sp-font-heading);
    letter-spacing: -0.02em;
}

.gs-banner-subtitle {
    font-size: var(--sp-text-base);
    color: var(--sp-text-secondary);
    margin: 0 auto var(--sp-space-8);
    max-width: 520px;
    line-height: 1.6;
}

.gs-steps {
    display: flex;
    gap: var(--sp-space-8);
    justify-content: center;
    flex-wrap: wrap;
    margin-bottom: var(--sp-space-8);
}

.gs-step {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: var(--sp-space-2);
    max-width: 160px;
}

.gs-step-number {
    width: 36px;
    height: 36px;
    border-radius: var(--sp-radius-full);
    background: var(--sp-accent);
    color: var(--sp-text-on-accent);
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 700;
    font-size: var(--sp-text-sm);
    flex-shrink: 0;
}

.gs-step-text {
    font-size: var(--sp-text-sm);
    color: var(--sp-text-secondary);
    text-align: center;
    line-height: 1.4;
}

.gs-copybox {
    display: flex;
    align-items: center;
    gap: var(--sp-space-3);
    background: var(--sp-bg-surface-raised);
    border: 1px solid var(--sp-border-default);
    border-radius: var(--sp-radius-md);
    padding: var(--sp-space-3) var(--sp-space-4);
    max-width: 560px;
    margin: 0 auto;
}

.gs-copybox code {
    flex: 1;
    font-family: var(--sp-font-mono);
    font-size: var(--sp-text-sm);
    color: var(--sp-text-primary);
    word-break: break-all;
}

.checklist-hint a {
    color: var(--sp-accent);
}

.checklist-hint a:hover {
    color: var(--sp-accent-hover);
}

.gs-stat-ribbon {
    display: flex;
    gap: var(--sp-space-4);
    margin-bottom: var(--sp-space-6);
}

.gs-stat-ribbon .card {
    flex: 1;
    padding: var(--sp-space-4);
}

.install-steps {
    display: flex;
    flex-direction: column;
    gap: var(--sp-space-6);
    counter-reset: install-step;
}
.install-step-number {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 28px;
    height: 28px;
    border-radius: var(--sp-radius-full);
    background: var(--sp-accent);
    color: var(--sp-text-on-accent);
    font-weight: 700;
    font-size: var(--sp-text-sm);
    flex-shrink: 0;
}
.install-step-content {
    flex: 1;
    min-width: 0;
}
.install-tab-content { padding: var(--sp-space-3) 0; }
.install-dropdown-body { padding: var(--sp-space-2); }

}

@layer components {

.clickable-row {
    cursor: pointer;
}

.clickable-row:hover {
    background: var(--sp-accent-dim);
}

.detail-header {
    margin-bottom: var(--sp-space-7);
    display: flex;
    align-items: center;
    gap: var(--sp-space-4);
}

.spinner {
    width: 40px;
    height: 40px;
    border: 3px solid var(--sp-border-default);
    border-top-color: var(--sp-accent);
    border-radius: var(--sp-radius-full);
    animation: spin var(--sp-duration-slow) linear infinite;
}

.loading-spinner {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: var(--sp-space-3);
    padding: var(--sp-space-12);
    color: var(--sp-text-tertiary);
}

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

.actions-popup {
    position: fixed;
    background: var(--sp-bg-surface-overlay);
    border: 1px solid var(--sp-border-default);
    border-radius: var(--sp-radius-card-inner-brand);
    box-shadow: var(--sp-shadow-float);
    z-index: var(--sp-z-dropdown);
    min-width: 180px;
    padding: var(--sp-space-1) 0;
    opacity: 0;
    visibility: hidden;
    transform: translateY(-4px);
    transition: opacity var(--sp-duration-fast) var(--sp-ease-in-out),
                visibility var(--sp-duration-fast),
                transform var(--sp-duration-fast) var(--sp-ease-in-out);
}

.actions-popup.open {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
}

.actions-popup-item {
    display: flex;
    align-items: center;
    gap: var(--sp-space-3);
    width: 100%;
    padding: var(--sp-space-2) var(--sp-space-4);
    background: transparent;
    border: none;
    color: var(--sp-text-secondary);
    font-size: var(--sp-text-sm);
    font-family: inherit;
    font-weight: 500;
    cursor: pointer;
    text-align: left;
    white-space: nowrap;
    min-height: 44px;
    transition: background var(--sp-duration-fast), color var(--sp-duration-fast);
    appearance: none;
}

.actions-popup-item:hover,
.actions-popup-item:focus-visible {
    background: var(--sp-bg-surface-raised);
    color: var(--sp-text-primary);
    outline: none;
}

.actions-popup-item .popup-icon {
    width: 16px;
    text-align: center;
    flex-shrink: 0;
}

.actions-popup-item--danger {
    color: var(--sp-danger);
}

.actions-popup-item--danger:hover {
    background: var(--sp-danger-dim);
    color: var(--sp-danger);
}

.actions-popup-separator {
    height: 1px;
    background: var(--sp-border-subtle);
    margin: var(--sp-space-1) 0;
}

@media (prefers-reduced-motion: reduce) {
    .spinner {
        animation: none;
    }
}

}

@layer components {

.skill-file-category {
    font-size: var(--sp-text-xs);
    font-weight: 700;
    color: var(--sp-text-secondary);
    text-transform: uppercase;
    letter-spacing: 0.05em;
    padding: var(--sp-space-2) var(--sp-space-3);
    margin-top: var(--sp-space-2);
}

.skill-file-item {
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    padding: var(--sp-space-2) var(--sp-space-3);
    cursor: pointer;
    border-radius: var(--sp-radius-sm);
    color: var(--sp-text-primary);
    transition: background var(--sp-duration-fast) var(--sp-ease-in-out);
}

.skill-file-item:hover {
    background: var(--sp-bg-surface-raised);
}

.skill-file-item.selected {
    background: var(--sp-accent);
    color: var(--sp-text-on-accent);
}

.skill-file-name {
    font-family: var(--sp-font-mono);
    font-size: var(--sp-text-sm);
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.skill-file-lang {
    flex-shrink: 0;
    font-size: var(--sp-text-xs);
    color: var(--sp-text-tertiary);
    padding-left: var(--sp-space-3);
}

.skill-file-item.selected .skill-file-lang {
    color: inherit;
    opacity: 0.7;
}

.code-inline {
    background: var(--sp-bg-surface-raised);
    padding: 0.125rem var(--sp-space-2);
    border-radius: var(--sp-radius-xs);
    font-size: var(--sp-text-xs);
}

.section-footer {
    text-align: center;
    margin-top: var(--sp-space-3);
}

.section-footer a {
    color: var(--sp-accent-blue);
}

.dept-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
    gap: var(--sp-space-4);
}

.dept-card-title {
    font-size: var(--sp-text-lg);
    font-weight: 600;
    margin-bottom: var(--sp-space-4);
}

.stats-grid-3col {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--sp-space-3);
}

.dept-top-user {
    margin-top: var(--sp-space-3);
    font-size: var(--sp-text-sm);
    color: var(--sp-text-secondary);
}

.metadata-grid {
    display: grid;
    grid-template-columns: auto 1fr;
    gap: var(--sp-space-2) var(--sp-space-4);
    font-size: var(--sp-text-sm);
    margin-bottom: var(--sp-space-3);
}

.detail-content {
    padding: var(--sp-space-3) var(--sp-space-4);
    background: var(--sp-bg-surface-raised);
    border-top: 1px solid var(--sp-border-primary);
}

.detail-summary {
    cursor: pointer;
    font-size: var(--sp-text-sm);
    font-weight: 600;
    margin-bottom: var(--sp-space-2);
}

.detail-pre {
    font-size: var(--sp-text-xs);
    background: var(--sp-bg-primary);
    padding: var(--sp-space-3);
    border-radius: var(--sp-radius-sm);
    overflow-x: auto;
    max-height: 300px;
}

.clickable {
    cursor: pointer;
}

.expand-chevron {
    transition: transform var(--sp-duration-normal);
    display: inline-block;
    font-size: var(--sp-text-xs);
    color: var(--sp-text-tertiary);
}

.search-narrow {
    width: 260px;
}

.self-center {
    align-self: center;
}

.cell-no-pad {
    padding: 0;
}

.col-chevron {
    width: 32px;
}

.form-hint {
    font-weight: 400;
    color: var(--sp-text-tertiary);
}

.toggle-label {
    display: inline-flex;
    align-items: center;
    gap: var(--sp-space-3);
    width: auto;
    height: auto;
}

.toggle-label-text {
    margin: 0;
    white-space: nowrap;
}

}

.setup-phase-link {
    display: inline-flex;
    align-items: center;
    gap: 0.25rem;
    font-size: var(--sp-text-sm);
    font-weight: 500;
    color: var(--sp-accent);
    text-decoration: none;
    transition: gap 0.15s ease;
}
.setup-phase-link:hover {
    gap: 0.5rem;
    text-decoration: underline;
}
.setup-phase-action {
    display: inline-flex;
    align-items: center;
    gap: 0.25rem;
    font-size: var(--sp-text-sm);
    font-weight: 600;
    color: var(--sp-text-primary);
    text-decoration: none;
    padding: var(--sp-space-1) var(--sp-space-3);
    border: 1px solid var(--sp-border-default);
    border-radius: var(--sp-radius-sm);
    background: var(--sp-bg-surface);
    transition: border-color 0.15s ease, gap 0.15s ease;
}
.setup-phase-action:hover {
    border-color: var(--sp-accent);
    gap: 0.5rem;
}
.setup-phase-expand {
    margin-top: var(--sp-space-4);
}
@media (max-width: 640px) {
    .setup-page {
        padding: var(--sp-space-4) var(--sp-space-2);
    }
    .setup-phase-indicator {
        width: 2rem;
    }
    .setup-phase-number {
        width: 2rem;
        height: 2rem;
        font-size: 0.75rem;
    }
    .setup-phase-actions {
        flex-direction: column;
        align-items: flex-start;
    }
}

.setup-page {
    max-width: 48rem;
    margin: 0 auto;
    padding: var(--sp-space-6) var(--sp-space-4);
}
.setup-hero {
    margin-bottom: var(--sp-space-8);
}
.setup-hero h2 {
    font-size: var(--sp-text-xl);
    font-weight: 700;
    margin: 0 0 var(--sp-space-2);
    color: var(--sp-text-primary);
}
.setup-hero p {
    color: var(--sp-text-secondary);
    line-height: 1.6;
    margin: 0;
}
.setup-stepper {
    display: flex;
    flex-direction: column;
    gap: 0;
}
.setup-phase {
    display: flex;
    gap: var(--sp-space-4);
    position: relative;
}
.setup-phase-indicator {
    display: flex;
    flex-direction: column;
    align-items: center;
    flex-shrink: 0;
    width: 2.5rem;
}
.setup-phase-number {
    width: 2.5rem;
    height: 2.5rem;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 700;
    font-size: var(--sp-text-sm);
    flex-shrink: 0;
    border: 2px solid var(--sp-border-default);
    background: var(--sp-bg-surface);
    color: var(--sp-text-secondary);
    transition: all 0.2s ease;
}
.setup-phase--complete .setup-phase-number {
    background: var(--sp-success);
    border-color: var(--sp-success);
    color: var(--sp-text-on-accent);
}
.setup-phase--current .setup-phase-number {
    background: var(--sp-accent);
    border-color: var(--sp-accent);
    color: var(--sp-text-on-accent);
}
.setup-phase-connector {
    width: 2px;
    flex: 1;
    min-height: 1.5rem;
    background: var(--sp-border-default);
    transition: background 0.2s ease;
}
.setup-phase--complete .setup-phase-connector {
    background: var(--sp-success);
}
.setup-phase-content {
    padding-bottom: var(--sp-space-6);
    flex: 1;
    min-width: 0;
}
.setup-phase-header {
    display: flex;
    align-items: center;
    gap: var(--sp-space-2);
    margin-bottom: var(--sp-space-1);
}
.setup-phase-content h3 {
    font-size: var(--sp-text-base);
    font-weight: 600;
    margin: 0;
    color: var(--sp-text-primary);
}
.setup-phase--upcoming .setup-phase-content h3 {
    color: var(--sp-text-secondary);
}
.setup-phase-content p {
    color: var(--sp-text-secondary);
    line-height: 1.5;
    margin: 0 0 var(--sp-space-2);
    font-size: var(--sp-text-sm);
}
.setup-badge {
    font-size: 0.6875rem;
    font-weight: 600;
    padding: 0.125rem 0.5rem;
    border-radius: var(--sp-radius-full);
    white-space: nowrap;
    text-transform: uppercase;
    letter-spacing: 0.025em;
}
.setup-badge--complete {
    background: color-mix(in oklch, var(--sp-success) 15%, transparent);
    color: var(--sp-success);
}
.setup-badge--current {
    background: color-mix(in oklch, var(--sp-accent) 15%, transparent);
    color: var(--sp-accent);
}
.setup-phase-actions {
    display: flex;
    align-items: center;
    gap: var(--sp-space-4);
    margin-bottom: var(--sp-space-2);
}

@layer components {


.rank-bg-1  { background: var(--sp-rank-1-bg); }
.rank-bg-2  { background: var(--sp-rank-2-bg); }
.rank-bg-3  { background: var(--sp-rank-3-bg); }
.rank-bg-4  { background: var(--sp-rank-4-bg); }
.rank-bg-5  { background: var(--sp-rank-5-bg); }
.rank-bg-6  { background: var(--sp-rank-6-bg); }
.rank-bg-7  { background: var(--sp-rank-7-bg); }
.rank-bg-8  { background: var(--sp-rank-8-bg); }
.rank-bg-9  { background: var(--sp-rank-9-bg); }
.rank-bg-10 { background: var(--sp-rank-10-bg); }


.user-widget__level.rank-bg-tier-10 { font-size: 0.5rem; }


.user-widget--tier-1,
.user-widget--tier-2,
.user-widget--tier-3,
.user-widget--tier-4,
.user-widget--tier-5 {  }


.user-widget--tier-6 { filter: drop-shadow(0 0 3px color-mix(in oklch, var(--sp-rank-tier-6-color) 25%, transparent)); }
.user-widget--tier-7 { filter: drop-shadow(0 0 3px color-mix(in oklch, var(--sp-rank-tier-7-color) 25%, transparent)); }
.user-widget--tier-8 { filter: drop-shadow(0 0 4px color-mix(in oklch, var(--sp-rank-tier-8-color) 30%, transparent)); }
.user-widget--tier-9 { filter: drop-shadow(0 0 4px color-mix(in oklch, var(--sp-rank-tier-9-color) 30%, transparent)); }
.user-widget--tier-10 { filter: drop-shadow(0 0 6px color-mix(in oklch, var(--sp-rank-tier-10-color) 40%, transparent)); }

.user-widget__level.is-premium {
    border-color: var(--sp-rank-tier-10-color);
    box-shadow: 0 0 0 2px color-mix(in oklch, var(--sp-rank-tier-10-color) 40%, transparent),
                0 0 6px color-mix(in oklch, var(--sp-rank-tier-10-color) 30%, transparent);
}

.user-avatar {
    width: 36px;
    height: 36px;
    border-radius: var(--sp-radius-full);
    background: linear-gradient(135deg, var(--sp-accent), color-mix(in oklch, var(--sp-accent) 70%, var(--sp-success)));
    color: var(--sp-text-on-accent);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: var(--sp-text-xs);
    font-weight: 700;
    flex-shrink: 0;
    letter-spacing: 0.02em;
    box-shadow: var(--sp-shadow-sm);
    position: relative;
}

.user-name {
    font-size: var(--sp-text-sm);
    color: var(--sp-text-primary);
    font-weight: 600;
    line-height: 1.3;
}

.user-meta {
    font-size: var(--sp-text-xs);
    color: var(--sp-text-secondary);
    line-height: 1.3;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.user-email {
    font-size: var(--sp-text-xs);
    color: var(--sp-text-tertiary);
    line-height: 1.3;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.btn-logout {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 36px;
    height: 36px;
    padding: 0;
    border: 1px solid var(--sp-border-default);
    border-radius: var(--sp-radius-md);
    background: var(--sp-bg-surface);
    color: var(--sp-text-secondary);
    cursor: pointer;
    transition: color var(--sp-duration-fast),
                background var(--sp-duration-fast),
                border-color var(--sp-duration-fast);
    flex-shrink: 0;
}

.btn-logout:hover {
    color: var(--sp-text-primary);
    background: var(--sp-bg-surface-raised);
    border-color: var(--sp-border-strong);
}

.btn-logout svg {
    display: block;
}

.avatar {
    width: 36px;
    height: 36px;
    border-radius: var(--sp-radius-full);
    background: linear-gradient(135deg, var(--sp-accent), color-mix(in oklch, var(--sp-accent) 70%, var(--sp-success)));
    color: var(--sp-text-on-accent);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: var(--sp-text-xs);
    font-weight: 700;
    flex-shrink: 0;
    overflow: hidden;
}
.avatar img { width: 100%; height: 100%; object-fit: cover; }
.avatar-sm { width: 28px; height: 28px; font-size: 0.625rem; }

.user-info {
    display: flex;
    align-items: center;
    gap: var(--sp-space-3);
    min-width: 0;
}

.user-level-number {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 22px;
    height: 22px;
    border-radius: var(--sp-radius-full);
    background: var(--sp-accent);
    color: var(--sp-text-on-accent);
    font-size: 0.625rem;
    font-weight: 700;
    flex-shrink: 0;
}

.star-rating {
    display: inline-flex;
    align-items: center;
    gap: 0.125rem;
}
.star {
    font-size: var(--sp-text-base);
    line-height: 1;
    cursor: pointer;
    color: var(--sp-text-tertiary);
    transition: color var(--sp-duration-fast);
}
.star-filled { color: var(--sp-warning); }
.star-empty { color: var(--sp-text-tertiary); }
.star-text {
    font-size: var(--sp-text-xs);
    color: var(--sp-text-secondary);
    margin-left: var(--sp-space-1);
}

}

@layer components {

.user-cell {
    display: flex;
    align-items: center;
    gap: var(--sp-space-2);
}

.user-widget {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 44px;
    height: 44px;
    flex-shrink: 0;
    text-decoration: none;
    transition: transform var(--sp-duration-fast);
}

.user-widget:hover {
    transform: scale(1.08);
}

.user-widget__avatar {
    width: 36px;
    height: 36px;
    border-radius: var(--sp-radius-full);
    background: linear-gradient(135deg, var(--sp-accent), color-mix(in oklch, var(--sp-accent) 70%, var(--sp-success)));
    color: var(--sp-text-on-accent);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: var(--sp-text-xs);
    font-weight: 700;
    letter-spacing: 0.02em;
    position: relative;
    z-index: var(--sp-z-sticky);
}

.user-widget__xp-ring {
    position: absolute;
    inset: 0;
    width: 44px;
    height: 44px;
    transform: rotate(-90deg);
    z-index: var(--sp-z-sticky-header);
    pointer-events: none;
}

.user-widget__xp-track {
    fill: none;
    stroke: color-mix(in oklch, var(--sp-text-tertiary) 12%, transparent);
    stroke-width: 2.5;
}

.user-widget__xp-fill {
    fill: none;
    stroke-width: 2.5;
    stroke-linecap: round;
    transition: stroke-dashoffset 0.8s ease-out;
}


.rank-ring-tier-1  { stroke: var(--sp-rank-tier-1-color); }
.rank-ring-tier-2  { stroke: var(--sp-rank-tier-2-color); }
.rank-ring-tier-3  { stroke: var(--sp-rank-tier-3-color); }
.rank-ring-tier-4  { stroke: var(--sp-rank-tier-4-color); }
.rank-ring-tier-5  { stroke: var(--sp-rank-tier-5-color); }
.rank-ring-tier-6  { stroke: var(--sp-rank-tier-6-color); }
.rank-ring-tier-7  { stroke: var(--sp-rank-tier-7-color); }
.rank-ring-tier-8  { stroke: var(--sp-rank-tier-8-color); }
.rank-ring-tier-9  { stroke: var(--sp-rank-tier-9-color); }
.rank-ring-tier-10 { stroke: var(--sp-rank-tier-10-color); }


.rank-ring-1  { stroke: var(--sp-rank-1-color); }
.rank-ring-2  { stroke: var(--sp-rank-2-color); }
.rank-ring-3  { stroke: var(--sp-rank-3-color); }
.rank-ring-4  { stroke: var(--sp-rank-4-color); }
.rank-ring-5  { stroke: var(--sp-rank-5-color); }
.rank-ring-6  { stroke: var(--sp-rank-6-color); }
.rank-ring-7  { stroke: var(--sp-rank-7-color); }
.rank-ring-8  { stroke: var(--sp-rank-8-color); }
.rank-ring-9  { stroke: var(--sp-rank-9-color); }
.rank-ring-10 { stroke: var(--sp-rank-10-color); }

.user-widget__level {
    position: absolute;
    bottom: -1px;
    right: -1px;
    width: 22px;
    height: 22px;
    border-radius: var(--sp-radius-full);
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 700;
    font-size: 0.6rem;
    line-height: 1;
    color: var(--sp-text-on-accent);
    text-shadow: 0 1px 2px oklch(0 0 0 / 0.4);
    border: 2px solid var(--sp-bg-surface);
    z-index: var(--sp-z-sticky-header);
}


.rank-bg-tier-1  { background: var(--sp-rank-tier-1-bg); }
.rank-bg-tier-2  { background: var(--sp-rank-tier-2-bg); }
.rank-bg-tier-3  { background: var(--sp-rank-tier-3-bg); }
.rank-bg-tier-4  { background: linear-gradient(135deg, var(--sp-rank-tier-4-bg), var(--sp-rank-tier-4-color)); }
.rank-bg-tier-5  { background: linear-gradient(135deg, var(--sp-rank-tier-5-bg), var(--sp-rank-tier-5-color)); }
.rank-bg-tier-6  { background: linear-gradient(135deg, var(--sp-rank-tier-6-bg), var(--sp-rank-tier-6-color)); box-shadow: 0 0 4px color-mix(in oklch, var(--sp-rank-tier-6-color) 30%, transparent); }
.rank-bg-tier-7  { background: linear-gradient(135deg, var(--sp-rank-tier-7-bg), var(--sp-rank-tier-7-color)); box-shadow: 0 0 4px color-mix(in oklch, var(--sp-rank-tier-7-color) 30%, transparent); }
.rank-bg-tier-8  { background: linear-gradient(135deg, var(--sp-rank-tier-8-bg), var(--sp-rank-tier-8-color)); box-shadow: 0 0 6px color-mix(in oklch, var(--sp-rank-tier-8-color) 40%, transparent); }
.rank-bg-tier-9  { background: linear-gradient(135deg, var(--sp-rank-tier-9-bg), var(--sp-rank-tier-9-color)); box-shadow: 0 0 6px color-mix(in oklch, var(--sp-rank-tier-9-color) 40%, transparent); }
.rank-bg-tier-10 { background: linear-gradient(135deg, var(--sp-rank-tier-10-bg), var(--sp-rank-tier-10-color)); box-shadow: 0 0 8px color-mix(in oklch, var(--sp-rank-tier-10-color) 50%, transparent); }

}

@layer components {


.install-menu {
    position: relative;
    display: inline-flex;
    align-items: center;
    margin-left: auto;
    margin-right: var(--sp-space-3);
}
.install-trigger {
    position: relative;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 36px;
    height: 36px;
    background: var(--sp-bg-surface);
    border: 1px solid var(--sp-border-default);
    border-radius: var(--sp-radius-md);
    color: var(--sp-text-secondary);
    cursor: pointer;
    transition: background var(--sp-duration-fast) var(--sp-ease-out),
                border-color var(--sp-duration-fast) var(--sp-ease-out),
                color var(--sp-duration-fast) var(--sp-ease-out);
}
.plugin-counter {
    position: absolute;
    top: -6px;
    right: -6px;
    min-width: 18px;
    height: 18px;
    padding: 0 0.3125rem;
    font-size: var(--sp-text-xs);
    font-weight: 600;
    line-height: 18px;
    text-align: center;
    color: var(--sp-text-on-accent);
    background: var(--sp-accent);
    border-radius: var(--sp-radius-full);
    pointer-events: none;
}
.install-trigger:hover,
.install-menu.open .install-trigger {
    background: var(--sp-bg-surface-raised);
    border-color: var(--sp-border-strong);
    color: var(--sp-text-primary);
}
.install-trigger:focus-visible {
    outline: none;
    box-shadow: 0 0 0 2px var(--sp-bg-canvas), 0 0 0 4px var(--sp-accent);
}
.install-dropdown {
    position: absolute;
    top: 100%;
    right: 0;
    margin-top: var(--sp-space-2);
    width: 380px;
    background: var(--sp-bg-surface-overlay);
    border: 1px solid var(--sp-border-default);
    border-radius: var(--sp-radius-card-inner-brand);
    box-shadow: var(--sp-shadow-float);
    z-index: var(--sp-z-dropdown);
    padding: var(--sp-space-4);
    opacity: 0;
    visibility: hidden;
    transform: translateY(-4px);
    transition: opacity var(--sp-duration-fast) var(--sp-ease-out), visibility var(--sp-duration-fast), transform var(--sp-duration-fast) var(--sp-ease-out);
}
.install-menu.open .install-dropdown {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
}
.install-dropdown-header {
    margin-bottom: var(--sp-space-3);
}
.install-dropdown-title {
    font-size: var(--sp-text-sm);
    font-weight: 600;
    color: var(--sp-text-primary);
    margin-bottom: var(--sp-space-2);
}
.install-dropdown .install-widget-stats {
    display: flex;
    gap: var(--sp-space-3);
    font-size: var(--sp-text-xs);
    color: var(--sp-text-secondary);
    flex-wrap: wrap;
}
.install-dropdown .install-stat strong {
    color: var(--sp-text-primary);
}
.install-dropdown-tabs {
    display: flex;
    gap: var(--sp-space-1);
    margin-bottom: var(--sp-space-3);
    border-bottom: 1px solid var(--sp-border-subtle);
    padding-bottom: var(--sp-space-2);
}
.install-dropdown-tabs .tab-btn {
    display: inline-flex;
    align-items: center;
    padding: var(--sp-space-1) var(--sp-space-3);
    font-size: var(--sp-text-xs);
    font-weight: 500;
    color: var(--sp-text-secondary);
    background: transparent;
    border: 1px solid var(--sp-border-default);
    border-radius: var(--sp-radius-sm);
    cursor: pointer;
    transition: background var(--sp-duration-fast) var(--sp-ease-out),
                border-color var(--sp-duration-fast) var(--sp-ease-out),
                color var(--sp-duration-fast) var(--sp-ease-out);
}
.install-dropdown-tabs .tab-btn:hover {
    background: var(--sp-bg-surface-raised);
    border-color: var(--sp-border-strong);
    color: var(--sp-text-primary);
}
.install-dropdown-tabs .tab-btn.active {
    background: var(--sp-accent);
    color: var(--sp-text-on-accent);
    border-color: var(--sp-accent);
}
.install-dropdown-tabs a.tab-btn {
    text-decoration: none;
}
.install-copybox {
    display: flex;
    align-items: center;
    gap: var(--sp-space-3);
    background: var(--sp-bg-surface);
    border: 1px solid var(--sp-border-default);
    border-radius: var(--sp-radius-sm);
    padding: var(--sp-space-2) var(--sp-space-3);
}
.install-code {
    flex: 1;
    font-size: var(--sp-text-xs);
    user-select: all;
    word-break: break-all;
    font-family: var(--sp-font-mono);
    color: var(--sp-text-primary);
    overflow: hidden;
    text-overflow: ellipsis;
}
.install-copybox .btn {
    white-space: nowrap;
    padding: var(--sp-space-1) var(--sp-space-3);
    font-size: var(--sp-text-xs);
}

}

@layer components {

.sp-expand-icon-open {
    transform: rotate(180deg);
}

.sp-mkt-empty-users {
    margin-top: var(--sp-space-2);
    font-size: var(--sp-text-xs);
    color: var(--sp-text-tertiary);
}

.sp-mkt-users-list {
    margin-top: var(--sp-space-2);
    display: flex;
    flex-direction: column;
    gap: var(--sp-space-1);
}

.sp-mkt-user-row {
    display: flex;
    align-items: center;
    gap: var(--sp-space-2);
    font-size: var(--sp-text-xs);
    padding: var(--sp-space-1) 0;
    border-bottom: 1px solid var(--sp-border-primary);
}

.sp-mkt-user-name {
    font-weight: 600;
    color: var(--sp-text-primary);
}

.sp-mkt-user-date {
    color: var(--sp-text-tertiary);
}

.sp-mkt-no-plugins {
    color: var(--sp-text-tertiary);
    font-size: var(--sp-text-sm);
}

.sp-mkt-checkbox-row {
    display: flex;
    align-items: center;
    gap: var(--sp-space-2);
    padding: var(--sp-space-1) 0;
    cursor: pointer;
}

.sp-mkt-roles-wrap {
    display: flex;
    flex-wrap: wrap;
    gap: var(--sp-space-1);
    padding: var(--sp-space-2) 0;
}

.sp-mkt-role-label {
    display: inline-flex;
    align-items: center;
    gap: var(--sp-space-2);
    margin-right: var(--sp-space-3);
    font-size: var(--sp-text-sm);
    cursor: pointer;
}

.sp-mkt-plugin-filter {
    margin-bottom: var(--sp-space-2);
}

.sp-mkt-checklist-scroll {
    max-height: 200px;
    overflow-y: auto;
    border: 1px solid var(--sp-border-subtle);
    border-radius: var(--sp-radius-md);
    padding: var(--sp-space-2);
}

.sp-mkt-delete-btn {
    margin-right: auto;
}

.sp-visibility-overlay {
    position: fixed;
    inset: 0;
    background: var(--sp-overlay-medium);
    backdrop-filter: blur(4px);
    z-index: var(--sp-z-modal);
    display: flex;
    align-items: center;
    justify-content: center;
    animation: fadeIn var(--sp-duration-normal) var(--sp-ease-out);
}

.sp-visibility-dialog {
    background: var(--sp-bg-surface-overlay);
    border: 1px solid var(--sp-border-default);
    border-radius: var(--sp-radius-card-brand);
    padding: var(--sp-space-7);
    max-width: 520px;
    width: 90%;
    box-shadow: var(--sp-shadow-float);
    animation: dialogIn var(--sp-duration-normal) var(--sp-ease-out);
    color: var(--sp-text-primary);
}

.sp-visibility-header {
    margin: 0 0 var(--sp-space-4);
    font-size: var(--sp-text-lg);
    font-weight: 600;
    color: var(--sp-text-primary);
}

.sp-visibility-rules {
    max-height: 300px;
    overflow-y: auto;
    margin-bottom: var(--sp-space-4);
}

.sp-visibility-rule {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--sp-space-2);
    padding: var(--sp-space-2) var(--sp-space-3);
    border: 1px solid var(--sp-border-subtle);
    border-radius: var(--sp-radius-sm);
    margin-bottom: var(--sp-space-2);
    font-size: var(--sp-text-sm);
    color: var(--sp-text-primary);
}

.sp-visibility-empty {
    padding: var(--sp-space-4);
    text-align: center;
    font-size: var(--sp-text-sm);
    color: var(--sp-text-tertiary);
}

.sp-visibility-actions {
    display: flex;
    gap: var(--sp-space-3);
    justify-content: flex-end;
}

@media (prefers-reduced-motion: reduce) {
    .sp-visibility-overlay,
    .sp-visibility-dialog {
        animation: none;
    }
}

}

@layer components {


.marketplace-card-expandable {
    border: none;
}
.marketplace-card-expandable summary {
    list-style: none;
    cursor: pointer;
    display: flex;
    align-items: center;
    gap: var(--sp-space-2);
}

.marketplace-expand-hint {
    font-size: var(--sp-text-xs);
    color: var(--sp-accent);
    font-weight: 500;
}
.marketplace-card-expandable[open] .marketplace-expand-hint {
    display: none;
}


.marketplace-card-footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding-top: var(--sp-space-3);
    border-top: 1px solid var(--sp-border-subtle);
    margin-top: auto;
}
.marketplace-card-link {
    font-size: var(--sp-text-sm);
    font-weight: 600;
    color: var(--sp-accent);
    text-decoration: none;
    transition: color var(--sp-duration-fast);
}
.marketplace-card-link:hover {
    color: var(--sp-accent-hover);
}
.marketplace-card-action {
    font-size: var(--sp-text-xs);
    font-weight: 500;
    color: var(--sp-text-tertiary);
    text-decoration: none;
    padding: var(--sp-space-1) var(--sp-space-3);
    border-radius: var(--sp-radius-sm);
    transition: color var(--sp-duration-fast),
                background var(--sp-duration-fast);
}
.marketplace-card-action:hover {
    color: var(--sp-text-primary);
    background: var(--sp-bg-surface-raised);
}


.marketplace-share-section {
    margin-bottom: var(--sp-space-4);
    border: 1px solid var(--sp-border-default);
    border-radius: var(--sp-radius-md);
    background: var(--sp-bg-surface);
}
.marketplace-share-toggle {
    display: flex;
    align-items: center;
    gap: var(--sp-space-2);
    padding: var(--sp-space-3) var(--sp-space-4);
    cursor: pointer;
    list-style: none;
}

.marketplace-share-body {
    padding: 0 var(--sp-space-4) var(--sp-space-4);
    display: flex;
    flex-direction: column;
    gap: var(--sp-space-3);
}
.marketplace-share-option {
    display: flex;
    flex-direction: column;
    gap: var(--sp-space-1);
}


.marketplace-empty-state {
    text-align: center;
    padding: var(--sp-space-12) var(--sp-space-6);
    border: 2px dashed var(--sp-border-default);
    border-radius: var(--sp-radius-card-brand);
    background: var(--sp-bg-surface);
}


.platform-info-bar {
    display: flex;
    align-items: center;
    gap: var(--sp-space-3);
    padding: var(--sp-space-3) var(--sp-space-4);
    background: var(--sp-bg-surface-raised);
    border: 1px solid var(--sp-border-subtle);
    border-radius: var(--sp-radius-md);
    margin-bottom: var(--sp-space-4);
    font-size: var(--sp-text-sm);
    color: var(--sp-text-secondary);
}
.platform-info-bar strong {
    color: var(--sp-text-primary);
}

}

@layer components {


.marketplace-card {
    display: flex;
    flex-direction: column;
    padding: 0;
    border: 1px solid var(--sp-border-default);
    border-radius: var(--sp-radius-card-brand);
    background: var(--sp-bg-surface);
    box-shadow: var(--sp-shadow-card);
    overflow: hidden;
    transition: transform var(--sp-duration-normal) var(--sp-ease-out),
                border-color var(--sp-duration-normal) var(--sp-ease-out),
                box-shadow var(--sp-duration-normal) var(--sp-ease-out);
}
.marketplace-card:hover {
    transform: translateY(-2px);
    border-color: var(--sp-border-strong);
    box-shadow: var(--sp-shadow-card-hover);
}
.marketplace-card.plugin-disabled {
    opacity: 0.5;
    pointer-events: none;
}


.marketplace-card-accent {
    height: 3px;
    background: var(--sp-accent);
    flex-shrink: 0;
}
.marketplace-card--custom .marketplace-card-accent {
    background: var(--sp-success);
}

.marketplace-card-body {
    display: flex;
    flex-direction: column;
    flex: 1;
    padding: var(--sp-space-5);
}

.marketplace-card-header {
    display: flex;
    flex-direction: column;
    gap: var(--sp-space-1);
    margin-bottom: var(--sp-space-3);
}
.marketplace-card-title-row {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: var(--sp-space-3);
}
.marketplace-card-name {
    font-size: var(--sp-text-lg);
    font-weight: 700;
    line-height: 1.3;
    color: var(--sp-text-primary);
    letter-spacing: -0.01em;
}
.marketplace-card-source {
    display: inline-flex;
    align-items: center;
    gap: var(--sp-space-2);
    font-size: var(--sp-text-xs);
    font-weight: 600;
    padding: var(--sp-space-1) var(--sp-space-3);
    border-radius: var(--sp-radius-full);
    white-space: nowrap;
    flex-shrink: 0;
    margin-top: var(--sp-radius-xs);
}
.marketplace-card-source--official {
    background: color-mix(in oklch, var(--sp-accent) 12%, transparent);
    color: var(--sp-accent);
}
.marketplace-card-source--custom {
    background: color-mix(in oklch, var(--sp-success) 12%, transparent);
    color: var(--sp-success);
}
.marketplace-card-source-dot {
    width: var(--sp-space-2);
    height: var(--sp-space-2);
    border-radius: var(--sp-radius-full);
    background: currentColor;
}
.marketplace-card-category {
    display: inline-block;
    font-size: var(--sp-text-xs);
    color: var(--sp-text-tertiary);
    font-weight: 500;
}
.marketplace-card-desc {
    margin: 0 0 var(--sp-space-4);
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    line-height: 1.5;
    color: var(--sp-text-secondary);
}


.marketplace-card-summary {
    display: flex;
    gap: var(--sp-space-2);
    flex-wrap: wrap;
    margin-bottom: var(--sp-space-3);
}
.marketplace-summary-pill {
    display: inline-flex;
    align-items: center;
    gap: var(--sp-space-1);
    font-size: var(--sp-text-xs);
    font-weight: 600;
    padding: var(--sp-space-1) var(--sp-space-3);
    border-radius: var(--sp-radius-full);
    background: var(--sp-bg-surface-raised);
    color: var(--sp-text-secondary);
}
.marketplace-summary-pill .pill-dot {
    width: var(--sp-space-2);
    height: var(--sp-space-2);
    border-radius: var(--sp-radius-full);
}
.pill-dot--skill { background: var(--sp-success); }
.pill-dot--agent { background: var(--sp-section-plugins); }
.pill-dot--mcp { background: var(--sp-accent); }
.pill-dot--hook { background: var(--sp-section-audit); }

.marketplace-card-contents {
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: var(--sp-space-3);
    margin-bottom: var(--sp-space-4);
}
.marketplace-card-section {
    display: flex;
    flex-direction: column;
    gap: var(--sp-space-2);
}
.marketplace-card-section-label {
    font-size: var(--sp-text-xs);
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--sp-text-tertiary);
}
.marketplace-card-tags {
    display: flex;
    flex-wrap: wrap;
    gap: var(--sp-space-2);
}
.marketplace-tag {
    display: inline-block;
    padding: var(--sp-space-1) var(--sp-space-3);
    border-radius: var(--sp-radius-full);
    font-size: var(--sp-text-xs);
    font-weight: 500;
    line-height: 1.4;
}
.marketplace-tag--skill {
    background: color-mix(in oklch, var(--sp-success) 10%, transparent);
    color: color-mix(in oklch, var(--sp-success) 80%, var(--sp-text-primary));
}
.marketplace-tag--agent {
    background: color-mix(in oklch, var(--sp-section-plugins) 10%, transparent);
    color: color-mix(in oklch, var(--sp-section-plugins) 80%, var(--sp-text-primary));
}
.marketplace-tag--mcp {
    background: color-mix(in oklch, var(--sp-accent) 10%, transparent);
    color: color-mix(in oklch, var(--sp-accent) 80%, var(--sp-text-primary));
}

.marketplace-tag--more {
    background: var(--sp-bg-surface-raised);
    color: var(--sp-text-tertiary);
    font-weight: 600;
}

@media (prefers-reduced-motion: reduce) {
    .marketplace-card {
        transition: none;
    }
    .marketplace-card:hover {
        transform: none;
    }
}

}

@layer components {


.marketplace-stats-ribbon {
    display: flex;
    gap: var(--sp-space-3);
    margin-bottom: var(--sp-space-5);
}
.marketplace-stat-card {
    flex: 1;
    display: flex;
    align-items: center;
    gap: var(--sp-space-3);
    padding: var(--sp-space-3) var(--sp-space-4);
    background: var(--sp-bg-surface-gradient);
    border: 1px solid var(--sp-border-subtle);
    border-radius: var(--sp-radius-card-brand);
    box-shadow: var(--sp-shadow-card), var(--sp-shadow-inner-glow);
}
.marketplace-stat-icon {
    width: 36px;
    height: 36px;
    border-radius: var(--sp-radius-md);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: var(--sp-text-lg);
    font-weight: 700;
    flex-shrink: 0;
}
.marketplace-stat-icon--plugins {
    background: color-mix(in oklch, var(--sp-section-plugins) 12%, transparent);
    color: var(--sp-section-plugins);
}
.marketplace-stat-icon--skills {
    background: color-mix(in oklch, var(--sp-success) 12%, transparent);
    color: var(--sp-success);
}
.marketplace-stat-icon--agents {
    background: color-mix(in oklch, var(--sp-section-users) 12%, transparent);
    color: var(--sp-section-users);
}
.marketplace-stat-icon--mcp {
    background: color-mix(in oklch, var(--sp-accent) 12%, transparent);
    color: var(--sp-accent);
}
.marketplace-stat-icon--hooks {
    background: color-mix(in oklch, var(--sp-section-audit) 12%, transparent);
    color: var(--sp-section-audit);
}
.marketplace-stat-info {
    display: flex;
    flex-direction: column;
}
.marketplace-stat-value {
    font-size: var(--sp-text-lg);
    font-weight: 700;
    color: var(--sp-text-primary);
    line-height: 1.2;
    font-variant-numeric: tabular-nums;
}
.marketplace-stat-label {
    font-size: var(--sp-text-xs);
    color: var(--sp-text-tertiary);
    font-weight: 500;
}
.marketplace-stat-delta {
    font-size: var(--sp-text-xs);
    font-weight: 600;
    font-variant-numeric: tabular-nums;
    color: var(--sp-text-tertiary);
    line-height: 1.2;
}
.marketplace-stat-delta--up {
    color: var(--sp-success);
}
.marketplace-stat-delta--down {
    color: var(--sp-danger);
}
.marketplace-stat-period {
    font-size: 0.625rem;
    color: var(--sp-text-tertiary);
    font-weight: 400;
}

@media (max-width: 768px) {
    .marketplace-stats-ribbon {
        flex-wrap: wrap;
    }
    .marketplace-stat-card {
        min-width: calc(50% - var(--sp-space-2));
    }
}
@media (max-width: 480px) {
    .marketplace-stat-card {
        min-width: 100%;
    }
}


.section-header {
    display: flex;
    align-items: center;
    gap: var(--sp-space-3);
    margin: var(--sp-space-6) 0 var(--sp-space-4);
}
.section-header h3 {
    margin: 0;
    font-size: var(--sp-text-lg);
    font-weight: 600;
    color: var(--sp-text-primary);
}


.selection-save-bar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: var(--sp-space-3) var(--sp-space-4);
    background: color-mix(in oklch, var(--sp-accent) 8%, var(--sp-bg-surface));
    border: 1px solid var(--sp-accent);
    border-radius: var(--sp-radius-md);
    margin-bottom: var(--sp-space-4);
    font-size: var(--sp-text-sm);
}


.plugin-card-actions {
    display: flex;
    gap: var(--sp-space-2);
    margin-top: var(--sp-space-2);
}
.btn-fork {
    font-size: var(--sp-text-xs);
    padding: 0.125rem var(--sp-space-2);
    color: var(--sp-text-tertiary);
    border: 1px solid var(--sp-border-subtle);
    border-radius: var(--sp-radius-sm);
    background: transparent;
    cursor: pointer;
    transition: color var(--sp-duration-fast),
                border-color var(--sp-duration-fast),
                background var(--sp-duration-fast);
}
.btn-fork:hover {
    color: var(--sp-accent);
    border-color: var(--sp-accent);
    background: color-mix(in oklch, var(--sp-accent) 8%, transparent);
}

}

@layer components {


.plugin-selection-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
    gap: var(--sp-space-5);
}

@media (max-width: 768px) {
    .plugin-selection-grid {
        grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
    }
}
@media (max-width: 480px) {
    .plugin-selection-grid {
        grid-template-columns: 1fr;
    }
}

.plugin-selection-card {
    display: flex;
    gap: var(--sp-space-3);
    padding: var(--sp-space-4);
    border: 1px solid var(--sp-border-default);
    border-radius: var(--sp-radius-card-brand);
    box-shadow: var(--sp-shadow-card);
    cursor: pointer;
    transition: border-color var(--sp-duration-fast), background var(--sp-duration-fast), box-shadow var(--sp-duration-fast);
}

.plugin-selection-card:hover {
    border-color: var(--sp-accent);
    background: color-mix(in oklch, var(--sp-accent) 4%, var(--sp-bg-surface));
    box-shadow: var(--sp-shadow-card-hover);
}

.plugin-selection-card:has(input:checked) {
    border-color: var(--sp-accent);
    background: color-mix(in oklch, var(--sp-accent) 8%, var(--sp-bg-surface));
}

.plugin-selection-card input[type="checkbox"] {
    flex-shrink: 0;
    margin-top: 0.125rem;
}

.plugin-selection-card-body {
    flex: 1;
    min-width: 0;
}

.plugin-selection-card-header {
    display: flex;
    align-items: center;
    gap: var(--sp-space-2);
    margin-bottom: var(--sp-space-1);
}

.plugin-selection-name {
    font-size: var(--sp-text-sm);
    font-weight: 600;
}

.plugin-selection-desc {
    margin: 0 0 var(--sp-space-2);
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.plugin-selection-meta {
    display: flex;
    gap: var(--sp-space-3);
}


.plugin-selection-card.plugin-disabled {
    opacity: 0.5;
}


.toggle-switch {
    position: relative;
    display: inline-block;
    width: 32px;
    height: 18px;
    cursor: pointer;
    flex-shrink: 0;
}
.toggle-switch input {
    opacity: 0;
    width: 0;
    height: 0;
}
.toggle-slider {
    position: absolute;
    inset: 0;
    background: var(--sp-border);
    border-radius: var(--sp-radius-full);
    transition: background var(--sp-duration-normal);
}
.toggle-slider::before {
    content: "";
    position: absolute;
    width: 14px;
    height: 14px;
    left: 2px;
    bottom: 2px;
    background: var(--sp-toggle-knob);
    border-radius: var(--sp-radius-full);
    transition: transform var(--sp-duration-normal);
}
.toggle-switch input:checked + .toggle-slider {
    background: var(--sp-accent);
}
.toggle-switch input:checked + .toggle-slider::before {
    transform: translateX(14px);
}

}

@layer components {

.panel-overlay {
    position: fixed;
    inset: 0;
    background: oklch(0 0 0 / 0);
    z-index: calc(var(--sp-z-panel) - 1);
    opacity: 0;
    visibility: hidden;
    transition: opacity var(--sp-duration-slow) var(--sp-ease-in-out),
                visibility var(--sp-duration-slow) var(--sp-ease-in-out),
                background var(--sp-duration-slow) var(--sp-ease-in-out),
                backdrop-filter var(--sp-duration-slow) var(--sp-ease-in-out);
    backdrop-filter: blur(0px);
}

.panel-overlay.open {
    opacity: 1;
    visibility: visible;
    background: var(--sp-overlay-light);
    backdrop-filter: blur(4px);
}

.side-panel {
    position: fixed;
    top: 0;
    right: 0;
    width: 640px;
    max-width: 94vw;
    height: 100vh;
    background: var(--sp-bg-surface-gradient);
    border-left: 1px solid var(--sp-border-subtle);
    box-shadow: var(--sp-shadow-float);
    z-index: var(--sp-z-panel);
    transform: translateX(100%);
    transition: transform var(--sp-duration-slow) var(--sp-ease-out);
    display: flex;
    flex-direction: column;
    border-radius: var(--sp-radius-card) 0 0 var(--sp-radius-card-brand);
}

.side-panel.open { transform: translateX(0); }

.panel-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: var(--sp-space-6) var(--sp-space-8);
    border-bottom: 1px solid var(--sp-border-default);
    background: var(--sp-bg-card-header);
    flex-shrink: 0;
}

.panel-header h2 {
    font-size: var(--sp-text-lg);
    font-weight: 600;
    margin: 0;
    color: var(--sp-text-primary);
    letter-spacing: -0.01em;
}

.panel-close {
    background: color-mix(in oklch, var(--sp-warm-900) 6%, transparent);
    border: none;
    color: var(--sp-text-secondary);
    font-size: var(--sp-text-lg);
    cursor: pointer;
    padding: var(--sp-space-1) var(--sp-space-2);
    border-radius: var(--sp-radius-sm);
    line-height: 1;
    transition: color var(--sp-duration-fast),
                background var(--sp-duration-fast);
}

.panel-close:hover {
    color: var(--sp-text-primary);
    background: color-mix(in oklch, var(--sp-warm-900) 8%, transparent);
}

.panel-body {
    flex: 1;
    overflow-y: auto;
    padding: var(--sp-space-8);
}

.panel-footer {
    padding: var(--sp-space-4) var(--sp-space-8);
    border-top: 1px solid var(--sp-border-subtle);
    display: flex;
    gap: var(--sp-space-3);
    justify-content: flex-end;
    flex-shrink: 0;
}

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

.side-panel.open .panel-body .form-group,
.side-panel.open .panel-body .detail-section {
    animation: panelContentIn var(--sp-duration-slow) var(--sp-ease-in-out) both;
}

.side-panel.open .panel-body .form-group:nth-child(1),
.side-panel.open .panel-body .detail-section:nth-child(1) { animation-delay: 50ms; }
.side-panel.open .panel-body .form-group:nth-child(2),
.side-panel.open .panel-body .detail-section:nth-child(2) { animation-delay: 100ms; }
.side-panel.open .panel-body .form-group:nth-child(3),
.side-panel.open .panel-body .detail-section:nth-child(3) { animation-delay: 150ms; }
.side-panel.open .panel-body .form-group:nth-child(4),
.side-panel.open .panel-body .detail-section:nth-child(4) { animation-delay: 200ms; }
.side-panel.open .panel-body .form-group:nth-child(n+5),
.side-panel.open .panel-body .detail-section:nth-child(n+5) { animation-delay: 250ms; }

@media (prefers-reduced-motion: reduce) {
    .panel-overlay {
        transition: none;
    }
    .side-panel {
        transition: none;
    }
    .side-panel.open .panel-body .form-group,
    .side-panel.open .panel-body .detail-section {
        animation: none;
    }
}

}

@layer components {

.panel-loading {
    text-align: center;
    padding: var(--sp-space-12);
    color: var(--sp-text-tertiary);
}

.sp-panel-empty-text {
    color: var(--sp-text-tertiary);
    font-size: var(--sp-text-sm);
}

.sp-skill-detail-field {
    margin-bottom: var(--sp-space-2);
}

.sp-skill-detail-label {
    font-weight: 600;
    font-size: var(--sp-text-xs);
    color: var(--sp-text-secondary);
    margin-right: var(--sp-space-2);
}

.sp-skill-detail-value {
    font-size: var(--sp-text-sm);
}

.sp-skill-prompt-section {
    margin-top: var(--sp-space-3);
}

.sp-skill-prompt-label {
    font-weight: 600;
    font-size: var(--sp-text-xs);
    color: var(--sp-text-secondary);
    margin-bottom: var(--sp-space-1);
}

.sp-skill-prompt-pre {
    font-size: var(--sp-text-xs);
    max-height: 200px;
    overflow: auto;
    white-space: pre-wrap;
    word-break: break-word;
    background: var(--sp-bg-surface-raised);
    padding: var(--sp-space-3);
    border-radius: var(--sp-radius-sm);
}

.form-actions {
    display: flex;
    align-items: center;
    gap: var(--sp-space-3);
    margin-top: var(--sp-space-6);
    padding-top: var(--sp-space-5);
    border-top: 1px solid var(--sp-border-subtle);
}

.btn[aria-busy="true"] {
    position: relative;
    color: transparent;
    pointer-events: none;
}

.btn[aria-busy="true"]::after {
    content: '';
    position: absolute;
    inset: 0;
    margin: auto;
    width: 1.125em;
    height: 1.125em;
    border: 2px solid currentColor;
    border-right-color: transparent;
    border-radius: 50%;
    animation: spin 0.6s linear infinite;
    color: var(--sp-text-on-accent);
}

.btn:disabled {
    opacity: 0.5;
    cursor: not-allowed;
}

.checklist-item {
    display: flex;
    align-items: center;
    gap: var(--sp-space-2);
    min-height: 2.75rem;
}

.checklist-item label {
    flex: 1;
    cursor: pointer;
    padding: var(--sp-space-2) 0;
}

.checklist-item input[type="checkbox"] {
    width: 1.125rem;
    height: 1.125rem;
    flex-shrink: 0;
}

.form-hint {
    font-weight: 400;
    color: var(--sp-text-tertiary);
    font-size: var(--sp-text-xs);
}

.error-msg:empty {
    display: none;
}

@media (max-width: 768px) {
    .side-panel {
        width: 100vw;
        max-width: 100vw;
    }

    .edit-panel,
    .assign-panel {
        width: 100vw;
    }

    .panel-header {
        padding: var(--sp-space-3) var(--sp-space-4);
    }

    .panel-body {
        padding: var(--sp-space-3) var(--sp-space-4);
    }

    .panel-footer {
        padding: var(--sp-space-3) var(--sp-space-4);
    }

    .form-row,
    .detail-grid {
        grid-template-columns: 1fr;
    }

    .form-actions {
        flex-wrap: wrap;
    }

    .form-actions .btn {
        flex: 1 1 auto;
        min-width: 0;
        text-align: center;
    }

    .checklist-item {
        min-height: 2.75rem;
        padding: var(--sp-space-1) 0;
    }

    .checklist-item input[type="checkbox"] {
        width: 1.375rem;
        height: 1.375rem;
    }
}

}

@layer components {

.form-group {
    margin-bottom: var(--sp-space-5);
    border-radius: var(--sp-radius-card-inner);
}

.form-group label {
    display: block;
    font-size: var(--sp-text-sm);
    font-weight: 500;
    color: var(--sp-text-secondary);
    margin-bottom: var(--sp-space-1);
}

.form-group input,
.form-group select,
.form-group textarea {
    width: 100%;
    background: var(--sp-bg-base);
    border: 1px solid var(--sp-border-default);
    border-radius: var(--sp-radius-card-inner);
    padding: var(--sp-space-2) var(--sp-space-3);
    color: var(--sp-text-primary);
    font-size: var(--sp-text-base);
    font-family: inherit;
    outline: none;
    transition: border-color var(--sp-duration-fast), box-shadow var(--sp-duration-fast);
    box-sizing: border-box;
}

.form-group input:focus-visible,
.form-group select:focus-visible,
.form-group textarea:focus-visible {
    border-color: var(--sp-accent);
    outline: 2px solid var(--sp-accent-dim);
    outline-offset: -1px;
}

.form-group input::placeholder,
.form-group textarea::placeholder {
    color: var(--sp-text-disabled);
}

.form-group textarea {
    min-height: 80px;
    resize: vertical;
}

.form-group .error-msg {
    font-size: var(--sp-text-sm);
    color: var(--sp-danger);
    margin-top: var(--sp-space-1);
}

.form-row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--sp-space-4);
}

.checklist-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--sp-space-5);
}

.form-section {
    margin-top: var(--sp-space-6);
    padding-top: var(--sp-space-5);
    border-top: 1px solid var(--sp-border-subtle);
}

.form-section-heading {
    font-size: var(--sp-text-sm);
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    color: var(--sp-text-tertiary);
    margin: 0 0 var(--sp-space-4);
}

@media (min-width: 769px) {
    .checklist-grid {
        grid-template-columns: 1fr 1fr;
    }
    .checklist-grid > :only-child,
    .checklist-grid > :last-child:nth-child(odd) {
        grid-column: 1 / -1;
    }
}

.detail-section {
    margin-bottom: var(--sp-space-6);
    padding-bottom: var(--sp-space-5);
    border-bottom: 1px solid var(--sp-border-subtle);
}

.detail-section:last-child {
    border-bottom: none;
    margin-bottom: 0;
}

.detail-section h3 {
    font-size: var(--sp-text-lg);
    font-weight: 600;
    margin: 0 0 var(--sp-space-4);
    color: var(--sp-text-primary);
    letter-spacing: -0.01em;
}

.detail-section h4 {
    font-size: var(--sp-text-xs);
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--sp-text-tertiary);
    margin: 0 0 var(--sp-space-3);
}

.detail-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--sp-space-4);
}

.detail-field {
    display: flex;
    flex-direction: column;
    gap: var(--sp-space-1);
}

.detail-label {
    font-size: var(--sp-text-xs);
    font-weight: 500;
    color: var(--sp-text-tertiary);
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.detail-value {
    font-size: var(--sp-text-base);
    color: var(--sp-text-primary);
}

}

.checklist-container {
  max-height: 200px;
  overflow-y: auto;
  border: 1px solid var(--sp-border-subtle);
  border-radius: var(--sp-radius-md);
  padding: var(--sp-space-2);
}
.checklist-filter { margin-bottom: var(--sp-space-2); }
.checklist-empty { padding: var(--sp-space-4); }
.role-checklist {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-space-1);
  padding: var(--sp-space-2) 0;
}
.role-checklist__label {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-space-2);
  margin-right: var(--sp-space-3);
  font-size: var(--sp-text-sm);
  cursor: pointer;
}
.user-group-header-row {
  display: flex;
  align-items: center;
  gap: var(--sp-space-3);
}
.user-avatar--circle {
  width: 32px;
  height: 32px;
  border-radius: var(--sp-radius-full);
  background: var(--sp-accent);
  color: var(--sp-text-on-accent);
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 600;
  font-size: var(--sp-text-sm);
}
.user-group-name { font-weight: 600; font-size: var(--sp-text-sm); }
.user-group-meta { font-size: var(--sp-text-xs); color: var(--sp-text-tertiary); }
.sp-add-items-overlay {
  position: fixed;
  inset: 0;
  background: var(--sp-overlay-medium);
  backdrop-filter: blur(4px);
  z-index: var(--sp-z-modal);
  display: flex;
  align-items: center;
  justify-content: center;
  animation: fadeIn var(--sp-duration-normal) var(--sp-ease-out);
}
.sp-add-items-dialog {
  background: var(--sp-bg-surface-overlay);
  border: 1px solid var(--sp-border-default);
  border-radius: var(--sp-radius-card-brand);
  padding: var(--sp-space-7);
  max-width: 480px;
  width: 90%;
  box-shadow: var(--sp-shadow-float);
  animation: dialogIn var(--sp-duration-normal) var(--sp-ease-out);
  color: var(--sp-text-primary);
}
.sp-add-items-header {
  margin: 0 0 var(--sp-space-4);
  font-size: var(--sp-text-lg);
  font-weight: 600;
  color: var(--sp-text-primary);
}
.sp-add-items-list {
  max-height: 300px;
  overflow-y: auto;
  border: 1px solid var(--sp-border-subtle);
  border-radius: var(--sp-radius-md);
  padding: var(--sp-space-2);
  margin-bottom: var(--sp-space-4);
}
.sp-add-items-row {
  display: flex;
  align-items: center;
  gap: var(--sp-space-2);
  padding: var(--sp-space-2);
  border-radius: var(--sp-radius-sm);
  cursor: pointer;
  font-size: var(--sp-text-sm);
  color: var(--sp-text-primary);
  transition: background var(--sp-duration-fast) var(--sp-ease-in-out);
}
.sp-add-items-row:hover {
  background: var(--sp-bg-surface-raised);
}
.sp-add-items-actions {
  display: flex;
  gap: var(--sp-space-3);
  justify-content: flex-end;
}
@media (prefers-reduced-motion: reduce) {
  .sp-add-items-overlay,
  .sp-add-items-dialog {
    animation: none;
  }
}

.plugin-card--accent { border-left: 3px solid var(--sp-accent); }
.plugin-card--warning { border-left: 3px solid var(--sp-warning); }
.plugin-card__body { flex: 1; min-width: 0; }
.plugin-card__title-row {
  display: flex;
  align-items: center;
  gap: var(--sp-space-2);
  flex-wrap: wrap;
}
.plugin-card__title {
  margin: 0;
  font-size: var(--sp-text-base);
  font-weight: 600;
  color: var(--sp-text-primary);
}
.plugin-card__description {
  margin: var(--sp-space-1) 0 0;
  font-size: var(--sp-text-sm);
  color: var(--sp-text-secondary);
}
.plugin-card__date {
  font-size: var(--sp-text-xs);
  color: var(--sp-text-tertiary);
  margin-top: var(--sp-space-1);
}
.plugin-card__tags {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-space-1);
  margin-top: var(--sp-space-2);
}
.plugin-card__tags .badge { font-size: 0.625rem; }
.plugin-meta {
  display: flex;
  gap: var(--sp-space-2);
  margin-top: var(--sp-space-2);
  flex-wrap: wrap;
}
.plugin-depends {
  margin-top: var(--sp-space-2);
  font-size: var(--sp-text-xs);
  color: var(--sp-warning);
}
.plugin-depends .text-muted-inline { color: var(--sp-text-tertiary); }
.expand-icon {
  font-size: var(--sp-text-sm);
  color: var(--sp-text-tertiary);
  transition: transform var(--sp-duration-fast) var(--sp-ease-out);
  display: inline-block;
}
.btn--xs { font-size: var(--sp-text-xs); }
.btn--files {
  margin-left: auto;
  font-size: var(--sp-text-xs);
  padding: 0.125rem var(--sp-space-2);
}
.plugin-tabs-container {
  border-top: 1px solid var(--sp-border-subtle);
  padding: var(--sp-space-4);
}
.plugin-tabs {
  display: flex;
  gap: var(--sp-space-2);
  margin-bottom: var(--sp-space-4);
}
.plugin-tab-placeholder {
  padding: var(--sp-space-4);
  color: var(--sp-text-tertiary);
  font-size: var(--sp-text-sm);
}
.detail-item-command {
  font-size: var(--sp-text-xs);
  color: var(--sp-text-tertiary);
}
.install-guide { margin-bottom: var(--sp-space-6); }
.install-guide__title { font-size: var(--sp-text-base); font-weight: 600; }
.install-step {
    display: flex;
    gap: var(--sp-space-3);
    align-items: flex-start;
}
.install-steps {
    list-style: none;
    padding: 0;
    margin: 0;
}
.install-step__hint { margin: var(--sp-space-1) 0 0; }
.install-copybox--spaced { margin-top: var(--sp-space-2); }
@media (max-width: 480px) {
    .install-step {
        flex-direction: column;
    }
}
.install-guide__alt {
  margin-top: var(--sp-space-4);
  padding-top: var(--sp-space-3);
  border-top: 1px solid var(--sp-border-subtle);
}
.install-guide__alt > summary {
  cursor: pointer;
  font-size: var(--sp-text-sm);
  font-weight: 500;
  color: var(--sp-text-secondary);
}
.install-guide__alt-body { margin-top: var(--sp-space-3); }
.install-guide__alt-body > p:first-child { margin: 0 0 var(--sp-space-2); }
.install-tab-hint {
  margin: 0 0 var(--sp-space-2);
  font-size: var(--sp-text-sm);
  color: var(--sp-text-secondary);
}

@layer components {

    .config-stats {
        display: flex;
        gap: var(--sp-space-3);
        padding: var(--sp-space-3) 0;
        flex-wrap: wrap;
    }

    .config-stat {
        display: flex;
        align-items: center;
        gap: var(--sp-space-2);
        font-size: var(--sp-text-sm);
        color: var(--sp-text-secondary);
    }

    .config-stat-value {
        font-weight: 600;
        color: var(--sp-text-primary);
    }

    .config-stat-dot {
        width: var(--sp-space-2);
        height: var(--sp-space-2);
        border-radius: var(--sp-radius-full);
        display: inline-block;
    }

    .config-stat-dot.green { background: var(--sp-success); }
    .config-stat-dot.red { background: var(--sp-danger); }
    .config-stat-dot.blue { background: var(--sp-accent); }

    
    .config-panel-section {
        padding: var(--sp-space-4) 0;
        border-bottom: 1px solid var(--sp-border-subtle);
    }

    .config-panel-section:last-child {
        border-bottom: none;
    }

    .config-panel-section h4 {
        margin: 0 0 var(--sp-space-3);
        font-size: var(--sp-text-sm);
        font-weight: 600;
        color: var(--sp-text-secondary);
        text-transform: uppercase;
        letter-spacing: 0.05em;
    }

    
    .config-resource-table {
        width: 100%;
        border-collapse: collapse;
    }

    .config-resource-table td {
        padding: var(--sp-space-2) var(--sp-space-2);
        font-size: var(--sp-text-sm);
        border-bottom: 1px solid var(--sp-border-subtle);
        vertical-align: middle;
    }

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

    .config-resource-table .toggle-switch {
        transform: scale(0.85);
    }

    
    .config-overview-grid {
        display: grid;
        grid-template-columns: auto 1fr;
        gap: var(--sp-space-2) var(--sp-space-4);
        font-size: var(--sp-text-sm);
    }

    .config-overview-label {
        color: var(--sp-text-tertiary);
        white-space: nowrap;
    }

    .config-overview-value {
        color: var(--sp-text-primary);
        word-break: break-word;
    }

    
    .tab-btn .tab-count {
        display: inline-block;
        min-width: var(--sp-space-5);
        padding: 0.0625rem 0.375rem;
        margin-left: var(--sp-space-1);
        font-size: var(--sp-text-xs);
        font-weight: 600;
        text-align: center;
        border-radius: var(--sp-radius-full);
        background: var(--sp-border-default);
    }

    .tab-btn.active .tab-count {
        background: var(--sp-border-strong);
    }

    
    .cell-primary {
        font-weight: 600;
        color: var(--sp-text-primary);
    }

    .cell-secondary {
        font-size: var(--sp-text-xs);
        color: var(--sp-text-secondary);
        margin-top: 0.125rem;
    }

    .cell-badges {
        display: flex;
        gap: var(--sp-space-1);
        flex-wrap: wrap;
    }

    
    .badge-clickable {
        cursor: pointer;
        transition: opacity var(--sp-duration-fast) var(--sp-ease-out), transform var(--sp-duration-fast) var(--sp-ease-out);
    }

    .badge-clickable:hover {
        opacity: 0.85;
        transform: scale(1.05);
    }

    .wizard-steps {
        display: flex;
        gap: var(--sp-space-1);
        margin-bottom: var(--sp-space-6);
        flex-wrap: wrap;
    }

    .wizard-step-badge {
        display: flex;
        align-items: center;
        gap: var(--sp-space-2);
        padding: var(--sp-space-2) var(--sp-space-3);
        border-radius: var(--sp-radius-md);
        font-size: var(--sp-text-sm);
        font-weight: 400;
        background: var(--sp-bg-tertiary);
        color: var(--sp-text-tertiary);
    }

    .wizard-step-badge.is-active {
        background: var(--sp-accent);
        color: #fff;
        font-weight: 600;
    }

    .wizard-step-badge.is-done {
        background: var(--sp-success);
        color: #fff;
    }

    .wizard-step-num {
        width: 20px;
        height: 20px;
        border-radius: 50%;
        background: rgba(255, 255, 255, 0.2);
        display: inline-flex;
        align-items: center;
        justify-content: center;
        font-size: var(--sp-text-xs);
    }

    .wizard-nav {
        display: flex;
        gap: var(--sp-space-3);
        margin-top: var(--sp-space-6);
    }

    .wizard-review-empty {
        color: var(--sp-text-tertiary);
    }

    .wizard-review-badge {
        margin: var(--sp-space-1);
    }

    .wizard-review-badges {
        display: flex;
        flex-wrap: wrap;
    }

}

@layer components {

    .fork-indicator {
        display: inline-flex;
        align-items: center;
        gap: var(--sp-space-1);
        font-size: var(--sp-text-xs);
        font-weight: 600;
        padding: 0.125rem var(--sp-space-2);
        border-radius: var(--sp-radius-full);
        line-height: 1.4;
    }

    .fork-indicator.forked {
        background: color-mix(in oklch, var(--sp-accent) 12%, transparent);
        color: var(--sp-accent);
    }

    .fork-indicator.custom {
        background: color-mix(in oklch, var(--sp-success) 12%, transparent);
        color: var(--sp-success);
    }

    .fork-indicator.inherited {
        background: color-mix(in oklch, var(--sp-text-secondary) 12%, transparent);
        color: var(--sp-text-secondary);
    }

    .fork-indicator .fork-icon {
        width: 12px;
        height: 12px;
    }

    .env-loading {
        padding: var(--sp-space-4);
        color: var(--sp-text-tertiary);
        font-size: var(--sp-text-sm);
    }

    .env-btn-wrap {
        padding: var(--sp-space-3) 0;
    }

    .env-code-label {
        background: var(--sp-bg-surface-raised);
        padding: 1px var(--sp-space-2);
        border-radius: var(--sp-radius-xs);
        font-size: var(--sp-text-sm);
    }

    .env-item-desc {
        font-size: var(--sp-text-sm);
        color: var(--sp-text-secondary);
        margin-top: var(--sp-space-1);
    }

    .env-val-mono {
        font-family: monospace;
        color: var(--sp-text-tertiary);
    }

    .env-empty-state {
        padding: var(--sp-space-6);
    }

    .env-field-desc {
        margin: 0 0 var(--sp-space-1);
        font-size: var(--sp-text-xs);
        color: var(--sp-text-tertiary);
    }

    .dialog-title {
        margin: 0 0 var(--sp-space-3);
    }

    .dialog-actions {
        display: flex;
        gap: var(--sp-space-3);
        justify-content: flex-end;
        margin-top: var(--sp-space-3);
    }

    .version-timeline {
        display: flex;
        flex-direction: column;
        gap: var(--sp-space-4);
        padding-left: var(--sp-space-4);
        border-left: 2px solid var(--sp-border-subtle);
    }
    .version-card {
        padding: var(--sp-space-3) var(--sp-space-4);
        background: var(--sp-bg-surface-raised);
        border-radius: var(--sp-radius-md);
        border: 1px solid var(--sp-border-subtle);
        font-variant-numeric: tabular-nums;
    }
    .version-user-header {
        display: flex;
        align-items: center;
        gap: var(--sp-space-2);
        margin-bottom: var(--sp-space-2);
        font-weight: 600;
        font-size: var(--sp-text-sm);
    }
    .version-user-group { margin-bottom: var(--sp-space-3); }

}

@layer components {


    .plugin-detail-row > td {
        padding: 0;
        background: var(--sp-bg-surface-raised);
        border-bottom: 1px solid var(--sp-border-subtle);
    }

    .plugin-detail-content {
        display: grid;
        grid-template-columns: 1fr 1fr;
        gap: var(--sp-space-4);
        padding: var(--sp-space-4) var(--sp-space-5);
    }

    .plugin-detail-section h5 {
        margin: 0 0 var(--sp-space-2);
        font-size: var(--sp-text-xs);
        font-weight: 600;
        color: var(--sp-text-secondary);
        text-transform: uppercase;
        letter-spacing: 0.05em;
    }

    .plugin-detail-section .config-resource-table td {
        padding: var(--sp-space-1) var(--sp-space-2);
        font-size: var(--sp-text-xs);
    }

    .plugin-detail-section .toggle-switch {
        transform: scale(0.75);
    }

    .plugin-detail-section .empty-inline {
        font-size: var(--sp-text-xs);
        color: var(--sp-text-tertiary);
        margin: 0;
    }

    .plugin-detail-section.active {
        background: var(--sp-bg-surface);
        border-radius: var(--sp-radius-sm);
        padding: var(--sp-space-2);
    }

    .btn-icon-remove {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        width: 24px;
        height: 24px;
        border: none;
        background: none;
        color: var(--sp-text-tertiary);
        font-size: var(--sp-text-sm);
        cursor: pointer;
        border-radius: var(--sp-radius-xs);
        transition: color var(--sp-duration-fast), background var(--sp-duration-fast);
        vertical-align: middle;
        margin-left: var(--sp-space-1);
    }
    .btn-icon-remove:hover {
        color: var(--sp-danger);
        background: var(--sp-danger-dim);
    }

    .add-row td {
        border-top: 1px dashed var(--sp-border-subtle);
        padding-top: var(--sp-space-2);
    }

    .add-checklist {
        max-height: 300px;
        overflow-y: auto;
        margin: var(--sp-space-3) 0;
    }
    .add-checklist label {
        display: flex;
        align-items: center;
        gap: var(--sp-space-2);
        padding: var(--sp-space-1) var(--sp-space-2);
        font-size: var(--sp-text-sm);
        cursor: pointer;
        border-radius: var(--sp-radius-xs);
    }
    .add-checklist label:hover {
        background: var(--sp-bg-surface-raised);
    }
    .add-checklist-empty {
        color: var(--sp-text-tertiary);
        font-size: var(--sp-text-sm);
        padding: var(--sp-space-3);
        text-align: center;
    }

    .assign-panel-empty {
        color: var(--sp-text-tertiary);
        font-size: var(--sp-text-sm);
    }

    .marketplace-card-expand-trigger {
        cursor: pointer;
        color: var(--sp-accent);
        font-size: var(--sp-text-xs);
        font-weight: 500;
    }
    .marketplace-card-expand-trigger:hover { text-decoration: underline; }

    .plugin-tab-content { padding: var(--sp-space-4) 0; }
    .plugin-users-container { margin-top: var(--sp-space-4); }

    .plugins-list {
        display: flex;
        flex-direction: column;
        gap: var(--sp-space-3);
    }

    @media (max-width: 768px) {
        .plugin-detail-content {
            grid-template-columns: 1fr;
        }
    }

}

@layer components {

.achievement-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
    gap: var(--sp-space-4);
}

.achievement-card {
    display: flex;
    flex-direction: column;
    padding: var(--sp-space-4);
    background: var(--sp-bg-surface-raised);
    border: 1px solid var(--sp-border-subtle);
    border-radius: var(--sp-radius-md);
    transition: border-color var(--sp-duration-normal), box-shadow var(--sp-duration-normal);
}

.achievement-card.unlocked {
    border-color: color-mix(in oklch, var(--sp-accent) 30%, var(--sp-border-subtle));
}

.achievement-card.locked {
    opacity: 0.55;
    filter: grayscale(0.3);
}

.achievement-card:hover {
    border-color: var(--sp-border-hover);
    box-shadow: var(--sp-shadow-card);
}

.achievement-card__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--sp-space-2);
    margin-bottom: var(--sp-space-1);
}

.achievement-card__name {
    font-weight: 600;
    font-size: var(--sp-text-sm);
    color: var(--sp-text-primary);
}

.achievement-card__desc {
    font-size: var(--sp-text-xs);
    color: var(--sp-text-tertiary);
    margin-top: var(--sp-space-1);
}

.achievement-card__date {
    font-size: var(--sp-text-xs);
    color: var(--sp-text-tertiary);
    margin-top: auto;
    padding-top: var(--sp-space-2);
}

.achievement-card__status {
    font-size: var(--sp-text-xs);
    color: var(--sp-text-tertiary);
    font-style: italic;
    margin-top: auto;
    padding-top: var(--sp-space-2);
}

.achievement-rarity {
    font-size: var(--sp-text-xs);
    font-weight: 600;
    padding: 0.125rem var(--sp-space-2);
    border-radius: var(--sp-radius-sm);
    white-space: nowrap;
}

.achievement-rarity--common { color: var(--sp-text-secondary); background: var(--sp-bg-tertiary); }
.achievement-rarity--uncommon { color: var(--sp-color-success); background: color-mix(in oklch, var(--sp-color-success) 15%, transparent); }
.achievement-rarity--rare { color: var(--sp-color-info); background: color-mix(in oklch, var(--sp-color-info) 15%, transparent); }
.achievement-rarity--epic { color: var(--sp-color-warning); background: color-mix(in oklch, var(--sp-color-warning) 15%, transparent); }
.achievement-rarity--legendary { color: var(--sp-accent); background: color-mix(in oklch, var(--sp-accent) 15%, transparent); }

.achievement-category {
    margin-bottom: var(--sp-space-4);
}

.achievement-category__header {
    display: flex;
    align-items: center;
    gap: var(--sp-space-3);
    padding: var(--sp-space-3) var(--sp-space-4);
    background: var(--sp-bg-surface-raised);
    border-radius: var(--sp-radius-md);
    cursor: pointer;
    list-style: none;
}

.achievement-category__header::-webkit-details-marker { display: none; }

.achievement-category__icon {
    font-size: var(--sp-text-xl);
}

.achievement-category__name {
    font-weight: 600;
    font-size: var(--sp-text-sm);
    color: var(--sp-text-primary);
    flex: 1;
}

.achievement-category__count {
    font-size: var(--sp-text-xs);
    color: var(--sp-text-tertiary);
    font-variant-numeric: tabular-nums;
}

.achievement-category__bar {
    width: 60px;
    height: 4px;
    background: var(--sp-bg-tertiary);
    border-radius: var(--sp-radius-xs);
    overflow: hidden;
}

.achievement-category__bar-fill {
    height: 100%;
    background: var(--sp-accent);
    border-radius: var(--sp-radius-xs);
}

.achievement-category__chevron {
    font-size: var(--sp-text-xs);
    color: var(--sp-text-tertiary);
    transition: transform var(--sp-duration-normal);
}

.achievement-category[open] .achievement-category__chevron {
    transform: rotate(90deg);
}

.achievement-category[open] .achievement-grid {
    margin-top: var(--sp-space-4);
}

.rank-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 24px;
    height: 24px;
    padding: 0 var(--sp-space-1);
    border-radius: var(--sp-radius-full);
    font-size: var(--sp-text-xs);
    font-weight: 700;
    color: var(--sp-text-on-accent);
    background: var(--sp-accent);
}

.xp-guide { margin-bottom: var(--sp-space-6); }
.xp-guide__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: var(--sp-space-3);
}
.xp-guide__title {
    font-size: var(--sp-text-base);
    font-weight: 700;
    color: var(--sp-text-primary);
}
.xp-guide__grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
    gap: var(--sp-space-3);
}
.xp-guide__item {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: var(--sp-space-3) var(--sp-space-4);
    background: var(--sp-bg-surface-raised);
    border-radius: var(--sp-radius-md);
    border: 1px solid var(--sp-border-subtle);
}
.xp-guide__action {
    font-size: var(--sp-text-sm);
    color: var(--sp-text-primary);
    font-weight: 500;
}
.xp-guide__amount {
    font-size: var(--sp-text-sm);
    font-weight: 700;
    color: var(--sp-accent);
    font-variant-numeric: tabular-nums;
}

}

@layer components {

.rank-ladder__step {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: var(--sp-space-1);
    min-width: 64px;
    flex-shrink: 0;
}

.rank-ladder__step--current {
    position: relative;
}
.rank-ladder__step--current .rank-ladder__step-badge {
    box-shadow: 0 0 0 3px color-mix(in oklch, var(--sp-accent) 30%, transparent);
}
.rank-ladder__step--current .rank-ladder__step-name {
    font-weight: 700;
    color: var(--sp-accent);
}
.rank-ladder__step--current::after {
    content: "Current";
    font-size: 0.625rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    color: var(--sp-accent);
}
.rank-ladder__step--completed .rank-ladder__step-badge {
    background: var(--sp-success);
}

@media (max-width: 480px) {
    .rank-ladder { gap: var(--sp-space-2); }
    .rank-ladder__step { min-width: 52px; }
    .rank-ladder__step-badge { width: 28px; height: 28px; font-size: var(--sp-text-xs); }
}

}

@layer components {

.profile-hero__completion {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.125rem;
    flex-shrink: 0;
    padding-left: var(--sp-space-4);
    border-left: 1px solid var(--sp-border-subtle);
}

.profile-hero__completion-value {
    font-weight: 700;
    font-size: var(--sp-text-xl);
    color: var(--sp-text-primary);
    font-variant-numeric: tabular-nums;
    line-height: 1.2;
}

.profile-hero__completion-total {
    font-weight: 400;
    color: var(--sp-text-tertiary);
    font-size: var(--sp-text-base);
}

.xp-value {
    font-size: var(--sp-text-sm);
    font-weight: 600;
    font-variant-numeric: tabular-nums;
    color: var(--sp-text-primary);
}

.xp-progress {
    height: 6px;
    background: var(--sp-bg-surface);
    border-radius: var(--sp-radius-sm);
    overflow: hidden;
    margin-top: var(--sp-space-1);
}

.xp-progress-fill {
    height: 100%;
    border-radius: var(--sp-radius-sm);
    transition: width var(--sp-duration-slow) var(--sp-ease-out);
}

.streak-badge {
    display: inline-flex;
    align-items: center;
    gap: var(--sp-space-1);
    font-size: var(--sp-text-sm);
    font-weight: 600;
    color: var(--sp-text-secondary);
}

.streak-badge.hot {
    color: var(--sp-warning);
}
.unlock-bar {
    height: 4px;
    background: var(--sp-bg-surface-raised);
    border-radius: var(--sp-radius-xs);
    margin-top: var(--sp-space-2);
    overflow: hidden;
}

.unlock-bar-fill {
    height: 100%;
    background: var(--sp-primary-400);
    border-radius: var(--sp-radius-xs);
    transition: width var(--sp-duration-slow) var(--sp-ease-out);
}

.achievement-icon {
    font-size: var(--sp-text-2xl);
    margin-bottom: var(--sp-space-2);
}

.metric-value {
    font-variant-numeric: tabular-nums;
}

.metric-value--small {
    font-size: var(--sp-text-xs);
}

.gamification-profile {
    background: var(--sp-bg-surface-gradient);
    border: 1px solid var(--sp-border-subtle);
    border-radius: var(--sp-radius-card-brand);
    padding: var(--sp-space-6);
    box-shadow: var(--sp-shadow-card), var(--sp-shadow-inner-glow);
}

.gamification-profile h3 {
    margin-bottom: var(--sp-space-4);
}

.rank-ladder-section { margin-bottom: var(--sp-space-6); }
.rank-ladder-title {
    font-size: var(--sp-text-base);
    font-weight: 700;
    color: var(--sp-text-primary);
    margin-bottom: var(--sp-space-4);
    display: flex;
    align-items: center;
    gap: var(--sp-space-3);
}
.rank-ladder-level-label {
    font-size: var(--sp-text-xs);
    font-weight: 500;
    color: var(--sp-text-tertiary);
}
.rank-ladder-wrapper {
    position: relative;
    overflow: hidden;
}
.rank-ladder {
    display: flex;
    gap: var(--sp-space-3);
    overflow-x: auto;
    padding: var(--sp-space-2) 0;
    scroll-behavior: smooth;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: thin;
}
.rank-ladder-nav {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    z-index: 2;
    background: var(--sp-bg-surface);
    border: 1px solid var(--sp-border-default);
    border-radius: var(--sp-radius-full);
    width: 32px;
    height: 32px;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    font-size: var(--sp-text-xs);
    color: var(--sp-text-secondary);
    box-shadow: var(--sp-shadow-card);
    transition: background var(--sp-duration-fast);
}
.rank-ladder-nav:hover { background: var(--sp-bg-surface-raised); }
.rank-ladder-nav--left { left: 0; }
.rank-ladder-nav--right { right: 0; }
.rank-ladder__step-badge {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 36px;
    height: 36px;
    border-radius: var(--sp-radius-full);
    font-weight: 700;
    font-size: var(--sp-text-sm);
    color: var(--sp-text-on-accent);
    background: var(--sp-accent);
    flex-shrink: 0;
}
.rank-ladder__step-name {
    font-size: var(--sp-text-xs);
    font-weight: 600;
    color: var(--sp-text-primary);
    text-align: center;
    white-space: nowrap;
}
.rank-ladder__step-xp {
    font-size: var(--sp-text-xs);
    color: var(--sp-text-tertiary);
    text-align: center;
}

}

@layer components {

@media (max-width: 768px) {
    .profile-hero {
        flex-direction: column;
        gap: var(--sp-space-2);
        padding: var(--sp-space-3) var(--sp-space-4);
        margin-bottom: var(--sp-space-4);
    }
    .profile-hero__rank {
        flex-direction: row;
        align-items: center;
        text-align: left;
    }
    .profile-hero__badge {
        width: 2rem;
        height: 2rem;
        font-size: var(--sp-text-sm);
    }
    .profile-hero__rank-name {
        font-size: var(--sp-text-sm);
    }
    .profile-hero__xp-bar { max-width: 100%; }
    .profile-hero__xp-label {
        font-size: 0.65rem;
    }
    .profile-hero__stats {
        flex-wrap: wrap;
        justify-content: flex-start;
        gap: var(--sp-space-3);
    }
    .profile-hero__stat {
        flex-direction: row;
        gap: var(--sp-space-1);
        align-items: baseline;
    }
    .profile-hero__stat-value {
        font-size: var(--sp-text-sm);
    }
    .profile-hero__stat-label {
        font-size: 0.65rem;
    }
    .profile-hero__completion {
        border-left: none;
        border-top: 1px solid var(--sp-border-subtle);
        padding-left: 0;
        padding-top: var(--sp-space-2);
    }
}

@media (max-width: 375px) {
    .profile-hero__stats {
        gap: var(--sp-space-2);
        display: grid;
        grid-template-columns: repeat(auto-fill, minmax(80px, 1fr));
    }
    .profile-hero__stat-value { font-size: var(--sp-text-xs); }
    .profile-hero__stat-label { font-size: 0.6rem; }
}

}

@layer components {

.profile-hero {
    display: flex;
    align-items: center;
    gap: var(--sp-space-5);
    padding: var(--sp-space-5) var(--sp-space-6);
    margin-bottom: var(--sp-space-6);
    background: var(--sp-bg-surface-gradient);
    border: 1px solid var(--sp-border-subtle);
    border-radius: var(--sp-radius-card-brand);
    box-shadow: var(--sp-shadow-card), var(--sp-shadow-inner-glow);
}

.profile-hero__rank {
    display: flex;
    align-items: center;
    gap: var(--sp-space-4);
    min-width: 0;
    flex: 1;
}

.profile-hero__badge {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 2.75rem;
    height: 2.75rem;
    border-radius: var(--sp-radius-full);
    font-weight: 700;
    font-size: var(--sp-text-lg);
    color: var(--sp-text-on-accent);
    background: var(--sp-accent);
    flex-shrink: 0;
    box-shadow: 0 0 0 3px color-mix(in oklch, var(--sp-accent) 20%, transparent);
}

.profile-hero__badge.rank-tier-1,
.profile-hero__badge.rank-tier-2,
.profile-hero__badge.rank-tier-3,
.profile-hero__badge.rank-tier-4,
.profile-hero__badge.rank-tier-5  { background: var(--sp-rank-tier-1-bg); }
.profile-hero__badge.rank-tier-6,
.profile-hero__badge.rank-tier-7,
.profile-hero__badge.rank-tier-8,
.profile-hero__badge.rank-tier-9,
.profile-hero__badge.rank-tier-10 { background: var(--sp-rank-tier-2-bg); }
.profile-hero__badge.rank-tier-11,
.profile-hero__badge.rank-tier-12,
.profile-hero__badge.rank-tier-13,
.profile-hero__badge.rank-tier-14,
.profile-hero__badge.rank-tier-15 { background: var(--sp-rank-tier-3-bg); }
.profile-hero__badge.rank-tier-16,
.profile-hero__badge.rank-tier-17,
.profile-hero__badge.rank-tier-18,
.profile-hero__badge.rank-tier-19,
.profile-hero__badge.rank-tier-20 { background: var(--sp-rank-tier-4-bg); }
.profile-hero__badge.rank-tier-21,
.profile-hero__badge.rank-tier-22,
.profile-hero__badge.rank-tier-23,
.profile-hero__badge.rank-tier-24,
.profile-hero__badge.rank-tier-25 { background: var(--sp-rank-tier-5-bg); }
.profile-hero__badge.rank-tier-26,
.profile-hero__badge.rank-tier-27,
.profile-hero__badge.rank-tier-28,
.profile-hero__badge.rank-tier-29,
.profile-hero__badge.rank-tier-30 { background: var(--sp-rank-tier-6-bg); }
.profile-hero__badge.rank-tier-31,
.profile-hero__badge.rank-tier-32,
.profile-hero__badge.rank-tier-33,
.profile-hero__badge.rank-tier-34,
.profile-hero__badge.rank-tier-35 { background: var(--sp-rank-tier-7-bg); }
.profile-hero__badge.rank-tier-36,
.profile-hero__badge.rank-tier-37,
.profile-hero__badge.rank-tier-38,
.profile-hero__badge.rank-tier-39,
.profile-hero__badge.rank-tier-40 { background: var(--sp-rank-tier-8-bg); }
.profile-hero__badge.rank-tier-41,
.profile-hero__badge.rank-tier-42,
.profile-hero__badge.rank-tier-43,
.profile-hero__badge.rank-tier-44,
.profile-hero__badge.rank-tier-45 { background: var(--sp-rank-tier-9-bg); }
.profile-hero__badge.rank-tier-46,
.profile-hero__badge.rank-tier-47,
.profile-hero__badge.rank-tier-48,
.profile-hero__badge.rank-tier-49,
.profile-hero__badge.rank-tier-50 { background: var(--sp-rank-tier-10-bg); }

.profile-hero__rank-info {
    display: flex;
    flex-direction: column;
    gap: var(--sp-space-1);
    min-width: 0;
}

.profile-hero__rank-name {
    font-weight: 700;
    font-size: var(--sp-text-base);
    color: var(--sp-text-primary);
    line-height: 1.2;
}

.profile-hero__xp-row {
    display: flex;
    flex-direction: column;
    gap: 0.1875rem;
}

.profile-hero__xp-bar {
    width: 100%;
    max-width: 220px;
    height: 5px;
    background: color-mix(in oklch, var(--sp-text-tertiary) 15%, transparent);
    border-radius: var(--sp-radius-full);
    overflow: hidden;
}

.profile-hero__xp-fill {
    height: 100%;
    background: var(--sp-accent);
    border-radius: var(--sp-radius-full);
    transition: width var(--sp-duration-normal) var(--sp-ease-out);
}

.profile-hero__xp-label {
    font-size: var(--sp-text-xs);
    color: var(--sp-text-tertiary);
    white-space: nowrap;
}

.profile-hero__stats {
    display: flex;
    gap: var(--sp-space-5);
    flex-shrink: 0;
}

.profile-hero__stat {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.125rem;
}

.profile-hero__stat-value {
    font-weight: 700;
    font-size: var(--sp-text-lg);
    color: var(--sp-text-primary);
    font-variant-numeric: tabular-nums;
    line-height: 1.2;
}

.profile-hero__stat-label {
    font-size: var(--sp-text-xs);
    color: var(--sp-text-tertiary);
    white-space: nowrap;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

}

@layer components {

.leaderboard-tabs {
    display: flex;
    gap: var(--sp-space-1);
    margin-bottom: var(--sp-space-4);
    border-bottom: 1px solid var(--sp-border-subtle);
    padding-bottom: var(--sp-space-2);
}

.leaderboard-podium {
    display: flex;
    justify-content: center;
    align-items: flex-end;
    gap: var(--sp-space-4);
    padding: var(--sp-space-6) 0;
    margin-bottom: var(--sp-space-6);
}

.leaderboard-podium__card {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: var(--sp-space-2);
    padding: var(--sp-space-4) var(--sp-space-5);
    background: var(--sp-bg-surface-gradient);
    border: 1px solid var(--sp-border-subtle);
    border-radius: var(--sp-radius-card-brand);
    box-shadow: var(--sp-shadow-card);
    min-width: 140px;
    text-align: center;
    transition: transform var(--sp-duration-fast), box-shadow var(--sp-duration-fast);
}
.leaderboard-podium__card:hover {
    transform: translateY(-2px);
    box-shadow: var(--sp-shadow-card), var(--sp-shadow-accent-sm);
}

.leaderboard-podium__position {
    font-size: var(--sp-text-2xl);
    font-weight: 800;
    color: var(--sp-accent);
    line-height: 1;
    font-variant-numeric: tabular-nums;
}

.leaderboard-podium__badge {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 44px;
    height: 44px;
    border-radius: var(--sp-radius-full);
    background: var(--sp-accent);
    color: var(--sp-text-on-accent);
    font-weight: 700;
    font-size: var(--sp-text-lg);
}

.leaderboard-podium__name {
    font-weight: 600;
    font-size: var(--sp-text-sm);
    color: var(--sp-text-primary);
}

.leaderboard-podium__xp {
    font-size: var(--sp-text-xs);
    color: var(--sp-text-tertiary);
    font-variant-numeric: tabular-nums;
}

.leaderboard-podium__level-label {
    font-size: var(--sp-text-xs);
    color: var(--sp-text-secondary);
}

.leaderboard-podium__metrics {
    display: flex;
    gap: var(--sp-space-3);
    font-size: var(--sp-text-xs);
    color: var(--sp-text-tertiary);
}

.leaderboard-podium__metric {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.125rem;
    font-variant-numeric: tabular-nums;
}

.leaderboard-streak {
    font-size: var(--sp-text-xs);
    font-weight: 600;
    font-variant-numeric: tabular-nums;
    color: var(--sp-text-secondary);
}
.leaderboard-streak--hot {
    color: var(--sp-warning);
}

.leaderboard-table-note {
    font-size: var(--sp-text-xs);
    color: var(--sp-text-tertiary);
    padding: var(--sp-space-2) var(--sp-space-4);
    text-align: center;
}

.leaderboard-table__self {
    background: color-mix(in oklch, var(--sp-accent) 6%, transparent);
    border-left: 3px solid var(--sp-accent);
    font-weight: 600;
}
.leaderboard-table__averages { font-style: italic; color: var(--sp-text-tertiary); }

.legend-traffic-sessions {
    display: inline-flex;
    align-items: center;
    gap: var(--sp-space-2);
    font-size: var(--sp-text-xs);
    color: var(--sp-text-tertiary);
}

.level-number-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 22px;
    height: 22px;
    padding: 0 var(--sp-space-1);
    border-radius: var(--sp-radius-full);
    font-size: 0.625rem;
    font-weight: 700;
    color: var(--sp-text-on-accent);
    background: var(--sp-accent);
}

.loading-center {
    display: flex;
    justify-content: center;
    padding: var(--sp-space-8);
}

@media (max-width: 768px) {
    .leaderboard-tabs {
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
        scrollbar-width: thin;
        flex-wrap: nowrap;
    }
    .leaderboard-tab { white-space: nowrap; flex-shrink: 0; }
}

@media (max-width: 600px) {
    .leaderboard-podium {
        flex-direction: column;
        align-items: stretch;
        gap: var(--sp-space-3);
        padding: var(--sp-space-4) 0;
    }
    .leaderboard-podium__card {
        flex-direction: row;
        align-items: center;
        gap: var(--sp-space-3);
        min-width: 0;
        text-align: left;
        padding: var(--sp-space-3) var(--sp-space-4);
    }
    .leaderboard-podium__card--gold { order: 1; }
    .leaderboard-podium__card--silver { order: 2; }
    .leaderboard-podium__card--bronze { order: 3; }
    .leaderboard-podium__badge { width: 36px; height: 36px; }
    .leaderboard-podium__metrics { flex-direction: row; }
}

}

@layer components {

    .json-view {
        max-height: 300px;
        overflow: auto;
        font-size: var(--sp-text-xs);
        background: var(--sp-bg-surface-raised);
        padding: var(--sp-space-3);
        border-radius: var(--sp-radius-sm);
        border: 1px solid var(--sp-border-subtle);
        white-space: pre-wrap;
        word-break: break-word;
    }

    .detail-row-content {
        padding: var(--sp-space-3);
    }

    .detail-section {
        margin-bottom: var(--sp-space-3);
    }

    .detail-section strong {
        font-size: var(--sp-text-sm);
        color: var(--sp-text-primary);
    }

    .assign-row td {
        padding-top: var(--sp-space-2);
        border-top: 1px dashed var(--sp-border-subtle);
    }

    .badge-row {
        display: flex;
        flex-wrap: wrap;
        gap: var(--sp-space-1);
        align-items: center;
    }


    .expand-indicator {
        transition: transform var(--sp-duration-normal);
        display: inline-block;
    }
    .expand-indicator.expanded {
        transform: rotate(90deg);
    }

    @media (prefers-reduced-motion: reduce) {
        .expand-indicator {
            transition: none;
        }
    }

    
    tr.detail-row {
        display: none;
    }
    tr.detail-row.visible {
        display: table-row;
    }
    tr.detail-row > td {
        padding: 0;
        border-top: none;
    }

    
    .detail-sub-table {
        width: 100%;
        margin-bottom: var(--sp-space-2);
    }
    .detail-sub-table th {
        font-size: var(--sp-text-xs);
        text-transform: uppercase;
        color: var(--sp-text-muted);
        padding: var(--sp-space-1) var(--sp-space-2);
    }
    .detail-sub-table td {
        padding: var(--sp-space-1) var(--sp-space-2);
        font-size: var(--sp-text-sm);
    }

    
    .assign-panel {
        position: fixed;
        right: -400px;
        top: 0;
        width: 400px;
        height: 100vh;
        background: var(--sp-bg-surface);
        border-left: 1px solid var(--sp-border-subtle);
        z-index: var(--sp-z-dropdown);
        transition: right var(--sp-duration-slow) ease;
        display: flex;
        flex-direction: column;
    }
    .assign-panel.open {
        right: 0;
    }
    .assign-panel-header {
        padding: var(--sp-space-3);
        border-bottom: 1px solid var(--sp-border-subtle);
    }
    .assign-panel-body {
        flex: 1;
        overflow-y: auto;
        padding: var(--sp-space-3);
    }
    .assign-panel-footer {
        padding: var(--sp-space-3);
        border-top: 1px solid var(--sp-border-subtle);
    }

    
    .assign-panel-checklist {
        display: flex;
        flex-direction: column;
        gap: var(--sp-space-1);
    }

}

@layer components {

    
    .filter-toolbar {
        display: flex;
        flex-wrap: wrap;
        gap: var(--sp-space-2);
        align-items: center;
        margin-bottom: var(--sp-space-3);
    }

    .filter-toolbar .filter-select {
        min-width: 140px;
    }

    
    .metadata-timestamp {
        font-size: var(--sp-text-xs);
        color: var(--sp-text-tertiary);
        white-space: nowrap;
    }

    
    .rating-display {
        font-size: var(--sp-text-sm);
        color: var(--sp-text-secondary);
        white-space: nowrap;
    }

    .rating-display .rating-stars {
        color: var(--sp-warning);
        letter-spacing: -1px;
    }

    
    .edit-panel {
        position: fixed;
        right: -600px;
        top: 0;
        width: 600px;
        height: 100vh;
        background: var(--sp-bg-surface);
        border-left: 1px solid var(--sp-border-subtle);
        z-index: var(--sp-z-panel);
        transition: right var(--sp-duration-slow) var(--sp-ease-out);
        display: flex;
        flex-direction: column;
    }
    .edit-panel.open {
        right: 0;
    }
    .edit-panel-header {
        display: flex;
        justify-content: space-between;
        align-items: center;
        padding: var(--sp-space-3);
        border-bottom: 1px solid var(--sp-border-subtle);
    }
    .edit-panel-body {
        flex: 1;
        overflow-y: auto;
        padding: var(--sp-space-3);
    }
    .edit-panel-footer {
        display: flex;
        justify-content: flex-end;
        gap: var(--sp-space-2);
        padding: var(--sp-space-3);
        border-top: 1px solid var(--sp-border-subtle);
    }
    .edit-panel-form .form-group {
        margin-bottom: var(--sp-space-3);
    }
    .edit-panel-form .form-label {
        display: block;
        font-size: var(--sp-text-sm);
        font-weight: 500;
        color: var(--sp-text-primary);
        margin-bottom: var(--sp-space-1);
    }
    .edit-panel-form .form-control {
        width: 100%;
        padding: var(--sp-space-2);
        background: var(--sp-bg-input);
        border: 1px solid var(--sp-border-default);
        border-radius: var(--sp-radius-md);
        color: var(--sp-text-primary);
        font-size: var(--sp-text-sm);
    }
    .edit-panel-form textarea.form-control {
        min-height: 200px;
        font-family: var(--sp-font-mono);
        resize: vertical;
    }

    
    .usage-badge {
        display: inline-flex;
        align-items: center;
        padding: var(--sp-space-1) var(--sp-space-2);
        font-size: var(--sp-text-xs);
        font-weight: 500;
        background: var(--sp-bg-surface-raised);
        border-radius: var(--sp-radius-full);
        color: var(--sp-text-secondary);
    }

    .sp-acl-badge-row {
        margin-top: var(--sp-space-2);
    }

    .sp-acl-no-roles {
        color: var(--sp-text-tertiary);
        font-size: var(--sp-text-sm);
    }

    .checklist-empty {
        color: var(--sp-text-tertiary);
        font-size: var(--sp-text-sm);
    }

    .detail-description {
        margin: var(--sp-space-1) 0;
        color: var(--sp-text-secondary);
        font-size: var(--sp-text-sm);
    }

    .detail-command-pre {
        margin: var(--sp-space-1) 0;
        font-size: var(--sp-text-xs);
        background: var(--sp-bg-surface-raised);
        padding: var(--sp-space-2);
        border-radius: var(--sp-radius-sm);
        overflow-x: auto;
    }

    .detail-tags-row {
        margin-top: var(--sp-space-1);
    }

    .detail-json-summary {
        cursor: pointer;
        font-size: var(--sp-text-sm);
        color: var(--sp-text-secondary);
    }

    .acl-bulk-intro {
        margin-bottom: var(--sp-space-4);
        color: var(--sp-text-secondary);
        font-size: var(--sp-text-sm);
    }

}

@layer components {
.usage-limits-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--sp-space-4);
}
.usage-limit-item {
    padding: var(--sp-space-4);
    border-radius: var(--sp-radius-card-brand);
    border: 1px solid var(--sp-border-subtle);
    background: var(--sp-bg-surface);
}
.usage-limit-item--warning {
    border-color: color-mix(in oklch, var(--sp-danger) 40%, var(--sp-border-default));
    background: var(--sp-danger-dim);
}
.usage-limit-header {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    margin-bottom: var(--sp-space-2);
}
.usage-limit-label,
.usage-limit-value {
    font-size: var(--sp-text-sm);
    font-weight: 600;
}
.usage-limit-label { color: var(--sp-text-primary); }
.usage-limit-value { color: var(--sp-text-secondary); }
.usage-limit-bar {
    height: 6px;
    background: color-mix(in oklch, var(--sp-text-tertiary) 15%, transparent);
    border-radius: var(--sp-radius-xs);
    overflow: hidden;
}
.usage-limit-fill {
    height: 100%;
    border-radius: var(--sp-radius-xs);
    background: var(--sp-accent);
    transition: width var(--sp-duration-normal) var(--sp-ease-out);
}
.usage-limit-fill--danger { background: var(--sp-danger); }
.usage-limit-fill--unlimited { background: color-mix(in oklch, var(--sp-success) 30%, transparent); }
.usage-limit-pct {
    display: block;
    margin-top: var(--sp-space-1);
    font-variant-numeric: tabular-nums;
}
.settings-upgrade-cta {
    background: var(--sp-bg-accent-wash);
    border-radius: var(--sp-radius-card-brand);
    padding: var(--sp-space-8);
    margin-bottom: var(--sp-space-6);
    border: 1px solid color-mix(in oklch, var(--sp-accent) 20%, var(--sp-border-subtle));
    box-shadow: var(--sp-shadow-card);
}
.settings-upgrade-cta h3 {
    color: var(--sp-text-primary);
    margin-bottom: var(--sp-space-2);
    font-size: var(--sp-text-xl);
}
.settings-upgrade-cta p {
    color: var(--sp-text-secondary);
    margin-bottom: var(--sp-space-4);
}
.settings-upgrade-cta .btn {
    background: var(--sp-accent);
    color: var(--sp-text-on-accent);
    border: none;
    font-weight: 600;
    box-shadow: var(--sp-shadow-accent-sm);
}
.settings-upgrade-cta .btn:hover {
    background: var(--sp-accent-hover);
    box-shadow: var(--sp-shadow-accent-md);
}
.settings-upgrade-cta-content {
    display: flex;
    flex-direction: column;
    gap: var(--sp-space-3);
}

.subscribe-btn {
    display: inline-flex;
    align-items: center;
    gap: var(--sp-space-2);
    padding: var(--sp-space-2) var(--sp-space-4);
    background: var(--sp-accent);
    color: var(--sp-text-on-accent);
    border: none;
    border-radius: var(--sp-radius-button);
    font-size: var(--sp-text-sm);
    font-weight: 600;
    cursor: pointer;
    transition: background var(--sp-duration-fast);
}
.subscribe-btn:hover { background: var(--sp-accent-hover); }

.billing-stats-grid .text-lg {
    font-variant-numeric: tabular-nums;
}

@media (max-width: 768px) {
    .usage-limits-grid { grid-template-columns: repeat(2, 1fr); }
    .billing-comparison-table .billing-td-label,
    .billing-comparison-table .billing-th-label,
    .billing-comparison-table .billing-section-label {
        position: sticky;
        left: 0;
        background: var(--sp-bg-surface);
        z-index: 1;
    }
    .billing-comparison-table .billing-section-label {
        background: var(--sp-bg-tertiary);
    }
    .billing-plans-grid {
        grid-template-columns: 1fr;
    }
}
@media (max-width: 480px) {
    .usage-limits-grid { grid-template-columns: 1fr; }
}
}

@layer components {
.settings-form-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--sp-space-5);
}
.settings-field {
    display: flex;
    flex-direction: column;
    gap: var(--sp-space-1);
}
.settings-label {
    font-weight: 600;
    font-size: var(--sp-text-sm);
    color: var(--sp-text-primary);
}
.settings-hint { font-size: var(--sp-text-xs); color: var(--sp-text-tertiary); }
.settings-avatar-row { display: flex; gap: var(--sp-space-3); align-items: center; }
.settings-avatar-row .form-input { flex: 1; }
.settings-avatar-preview {
    width: 40px;
    height: 40px;
    border-radius: var(--sp-radius-full);
    overflow: hidden;
    background: var(--sp-bg-surface-raised);
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    border: 2px solid var(--sp-border-default);
}
.settings-avatar-preview img { width: 100%; height: 100%; object-fit: cover; }
.settings-avatar-placeholder {
    font-size: var(--sp-text-lg);
    color: var(--sp-text-tertiary);
    font-weight: 600;
}
.settings-divider {
    height: 1px;
    background: var(--sp-border-subtle);
    margin: var(--sp-space-6) 0;
}
.settings-section-title {
    font-size: var(--sp-text-base);
    font-weight: 600;
    margin-bottom: var(--sp-space-4);
    color: var(--sp-text-primary);
}
.settings-toggles { display: flex; flex-direction: column; gap: var(--sp-space-4); }
.settings-toggle {
    display: flex;
    align-items: flex-start;
    gap: var(--sp-space-3);
    cursor: pointer;
    padding: var(--sp-space-3) var(--sp-space-4);
    border-radius: var(--sp-radius-card-brand);
    border: 1px solid var(--sp-border-subtle);
    transition: background var(--sp-duration-fast) var(--sp-ease-out);
}
.settings-toggle:hover {
    background: var(--sp-accent-dim);
}
.settings-toggle input[type="checkbox"] {
    position: absolute;
    opacity: 0;
    width: 0;
    height: 0;
}
.settings-toggle-slider {
    position: relative;
    width: 44px;
    height: 24px;
    background: color-mix(in oklch, var(--sp-text-tertiary) 25%, transparent);
    border-radius: var(--sp-radius-lg);
    transition: background var(--sp-duration-fast) var(--sp-ease-out);
    flex-shrink: 0;
    margin-top: 0.125rem;
}
.settings-toggle-slider::after {
    content: '';
    position: absolute;
    top: 2px;
    left: 2px;
    width: 20px;
    height: 20px;
    background: var(--sp-toggle-knob);
    border-radius: var(--sp-radius-full);
    transition: transform var(--sp-duration-fast) var(--sp-ease-out);
    box-shadow: var(--sp-shadow-xs);
}
.settings-toggle input:checked + .settings-toggle-slider { background: var(--sp-accent); }
.settings-toggle input:checked + .settings-toggle-slider::after { transform: translateX(20px); }
.settings-toggle input:focus-visible + .settings-toggle-slider {
    outline: 2px solid var(--sp-accent);
    outline-offset: 2px;
}
.settings-toggle-text { display: flex; flex-direction: column; gap: 0.125rem; }
.settings-toggle-text strong { font-size: var(--sp-text-sm); color: var(--sp-text-primary); }
.settings-actions {
    display: flex;
    align-items: center;
    gap: var(--sp-space-3);
    margin-top: var(--sp-space-6);
}
.settings-save-status {
    font-size: var(--sp-text-sm);
    transition: opacity var(--sp-duration-fast) var(--sp-ease-out);
}
.settings-save-status--success { color: var(--sp-success); }
.settings-save-status--error { color: var(--sp-danger); }

.secret-value-input {
    font-family: var(--sp-font-mono);
    font-size: var(--sp-text-sm);
    padding: var(--sp-space-2) var(--sp-space-3);
    background: var(--sp-bg-surface);
    border: 1px solid var(--sp-border-default);
    border-radius: var(--sp-radius-button);
    color: var(--sp-text-primary);
    width: 100%;
}
.secret-value-input:focus { outline: none; border-color: var(--sp-accent); }

.save-secret-btn,
.toggle-hook-btn {
    padding: var(--sp-space-1) var(--sp-space-3);
    font-size: var(--sp-text-xs);
    font-weight: 600;
    border: 1px solid var(--sp-border-default);
    border-radius: var(--sp-radius-button);
    background: transparent;
    color: var(--sp-text-secondary);
    cursor: pointer;
    transition: all var(--sp-duration-fast);
}
.save-secret-btn:hover,
.toggle-hook-btn:hover {
    background: var(--sp-accent-dim);
    border-color: var(--sp-accent);
    color: var(--sp-accent);
}
@media (max-width: 768px) {
    .settings-form-grid { grid-template-columns: 1fr; }
}
}

@layer components {

.sp-skill-files-overlay {
    position: fixed;
    inset: 0;
    background: var(--sp-overlay-medium);
    backdrop-filter: blur(4px);
    z-index: var(--sp-z-modal);
    display: flex;
    align-items: center;
    justify-content: center;
    animation: fadeIn var(--sp-duration-normal) var(--sp-ease-out);
}

.sp-skill-files-panel {
    background: var(--sp-bg-surface);
    border: 1px solid var(--sp-border-default);
    border-radius: var(--sp-radius-lg);
    width: 90vw;
    max-width: 1100px;
    height: 80vh;
    overflow: hidden;
    box-shadow: var(--sp-shadow-lg);
    display: flex;
    flex-direction: column;
}

.sp-skill-files-loading {
    display: flex;
    align-items: center;
    justify-content: center;
    height: 100%;
    color: var(--sp-text-tertiary);
}

.sp-skill-files-validation-error {
    color: var(--sp-danger);
}

}

@layer components {

.admin-footer {
    padding: var(--sp-space-4) var(--sp-space-10);
    border-top: 1px solid var(--sp-sidebar-border);
    text-align: center;
    font-size: var(--sp-text-xs);
    color: var(--sp-text-tertiary);
    flex-shrink: 0;
}

.admin-footer-inner {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--sp-space-2);
    flex-wrap: wrap;
}

.admin-footer-brand {
    font-weight: 600;
    color: var(--sp-text-secondary);
}

.admin-footer-sep {
    opacity: 0.4;
}

.admin-footer-link {
    color: var(--sp-text-tertiary);
    text-decoration: none;
    transition: color var(--sp-duration-fast);
}

.admin-footer-link:hover {
    color: var(--sp-accent);
}

.admin-footer-link:focus-visible {
    outline: 2px solid var(--sp-accent);
    outline-offset: 2px;
    border-radius: var(--sp-radius-sm);
}

@media (max-width: 480px) {
    .admin-footer {
        padding: var(--sp-space-3) var(--sp-space-4);
        padding-bottom: calc(var(--sp-space-3) + env(safe-area-inset-bottom, 0px));
    }
}

}

@layer components {

.login-container {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 100vh;
    padding: var(--sp-space-5);
    background:
        radial-gradient(ellipse at 30% 20%, color-mix(in oklch, var(--sp-accent) 6%, transparent) 0%, transparent 50%),
        radial-gradient(ellipse at 70% 80%, color-mix(in oklch, oklch(0.62 0.18 260) 4%, transparent) 0%, transparent 50%),
        linear-gradient(180deg, var(--sp-bg-canvas) 0%, var(--sp-bg-base) 100%);
}

.login-container .card {
    width: 100%;
    max-width: 420px;
    text-align: center;
    box-shadow: 0 8px 32px oklch(0.20 0.02 50 / 0.10), 0 2px 8px oklch(0.20 0.02 50 / 0.06);
    border-radius: var(--sp-radius-card-brand);
    background: light-dark(oklch(1.0 0 0), var(--sp-bg-glass));
    backdrop-filter: light-dark(none, blur(16px));
    border: 1px solid light-dark(oklch(0.20 0.01 50 / 0.06), var(--sp-bg-glass-border));
    padding: var(--sp-space-8) var(--sp-space-6);
}

.login-title {
    font-size: var(--sp-text-xl);
    font-weight: 700;
    margin: 0 0 var(--sp-space-1);
    color: var(--sp-text-primary);
}

.login-subtitle {
    font-size: var(--sp-text-sm);
    color: var(--sp-text-tertiary);
    margin: 0 0 var(--sp-space-5);
}

.login-error {
    display: none;
    background: var(--sp-danger-dim);
    color: var(--sp-danger);
    padding: var(--sp-space-2) var(--sp-space-4);
    border-radius: var(--sp-radius-md);
    font-size: var(--sp-text-sm);
    margin-bottom: var(--sp-space-4);
    text-align: left;
}

.login-error.visible {
    display: block;
}

.login-loading {
    flex-direction: column;
    align-items: center;
    gap: var(--sp-space-2);
    padding: var(--sp-space-5);
    color: var(--sp-text-tertiary);
    font-size: var(--sp-text-sm);
}

.login-loading:not([hidden]) {
    display: flex;
}

.login-spinner {
    width: 32px;
    height: 32px;
    border: 3px solid var(--sp-border-default);
    border-top-color: var(--sp-accent);
    border-radius: var(--sp-radius-full);
    animation: spin var(--sp-duration-slow) linear infinite;
}

.login-retry {
    display: none;
    margin-top: var(--sp-space-2);
}

.login-retry.visible {
    display: block;
}

.login-retry a {
    color: var(--sp-accent);
    text-decoration: none;
    font-size: var(--sp-text-sm);
}

.login-retry a:hover {
    text-decoration: underline;
}

.login-logo img {
    max-width: 100%;
    height: auto;
}

.login-logo .logo-dark { display: none; }

[data-theme="dark"] .login-logo .logo-light { display: none; }
[data-theme="dark"] .login-logo .logo-dark { display: block; }

@media (prefers-color-scheme: dark) {
    .login-logo .logo-light { display: none; }
    .login-logo .logo-dark { display: block; }
}


.login-container .form-input {
    background: light-dark(var(--sp-bg-surface), oklch(0.25 0.01 48));
    border-color: light-dark(var(--sp-border-default), oklch(0.40 0.01 50));
    color: var(--sp-text-primary);
}

.login-container .form-group label {
    color: var(--sp-text-primary);
    font-weight: 600;
}

.login-container .form-group input:focus-visible,
.login-container .form-group select:focus-visible,
.login-container .form-group textarea:focus-visible {
    outline: 2px solid var(--sp-accent);
    outline-offset: 2px;
}


.login-container .btn,
.login-container button[type="submit"] {
    border-radius: var(--sp-radius-button);
}


main.login-container {
    display: flex;
}

@media (prefers-reduced-motion: reduce) {
    .login-spinner {
        animation: none;
    }
}

}

@layer components {

@media (max-width: 768px) {

    .user-widget {
        width: 38px;
        height: 38px;
    }

    .user-widget__avatar {
        width: 30px;
        height: 30px;
        font-size: 0.6rem;
    }

    .user-widget__xp-ring {
        width: 38px;
        height: 38px;
    }

    .user-widget__level {
        width: 18px;
        height: 18px;
        font-size: 0.55rem;
    }

    .user-meta {
        display: none;
    }

    .toolbar {
        flex-direction: row;
        flex-wrap: wrap;
        gap: var(--sp-space-2);
        align-items: center;
    }

    .toolbar .search-group {
        flex: 1 1 140px;
        min-width: 140px;
    }

    .toolbar .search-input,
    .search-input {
        min-width: 0;
        width: 100%;
    }

    .toolbar .filter-select,
    .toolbar .filter-group {
        flex: 0 1 auto;
        min-width: 100px;
    }

    .toolbar .btn-primary {
        flex: 0 0 auto;
        white-space: nowrap;
        padding: var(--sp-space-2) var(--sp-space-3);
        font-size: var(--sp-text-sm);
    }

    .toolbar .flex-1 {
        display: none;
    }

    .btn {
        min-height: 44px;
        font-weight: 500;
    }

    .admin-main > p.text-muted.mb-4 {
        display: none;
    }

    .config-stats.mb-4 {
        margin-bottom: var(--sp-space-2);
    }

    .btn-sm {
        min-height: 36px;
    }

    .actions-trigger,
    .btn-actions-trigger {
        min-width: 44px;
        min-height: 44px;
    }

    .install-trigger {
        min-width: 44px;
        min-height: 44px;
    }

    .install-dropdown {
        width: calc(100vw - var(--sp-space-6));
        right: calc(-1 * var(--sp-space-3));
    }

    .plugin-cards {
        grid-template-columns: 1fr;
    }

    .gs-banner {
        padding: var(--sp-space-6) var(--sp-space-4);
    }

    .gs-banner-title {
        font-size: var(--sp-text-lg);
    }

    .gs-stat-ribbon {
        flex-wrap: wrap;
    }

    .gs-stat-ribbon .card {
        min-width: calc(50% - var(--sp-space-2));
    }
}

@media (max-width: 480px) {

    .toolbar {
        flex-direction: row;
        flex-wrap: wrap;
        gap: var(--sp-space-2);
    }

    .toolbar .search-group {
        flex: 1 1 0;
        min-width: 120px;
    }

    .toolbar .btn-primary {
        flex: 0 0 auto;
        width: auto;
        min-width: auto;
    }

    .toolbar .filter-select,
    .toolbar .filter-group {
        flex: 1 1 100%;
        min-width: 100%;
    }

    .user-widget {
        width: 34px;
        height: 34px;
    }

    .user-widget__avatar {
        width: 26px;
        height: 26px;
        font-size: 0.55rem;
    }

    .user-widget__xp-ring {
        width: 34px;
        height: 34px;
    }

    .user-widget__level {
        width: 16px;
        height: 16px;
        font-size: 0.5rem;
    }

    .install-dropdown {
        width: calc(100vw - var(--sp-space-4));
        right: calc(-1 * var(--sp-space-2));
    }

    .install-dropdown .install-widget-stats {
        flex-wrap: wrap;
        gap: var(--sp-space-2) var(--sp-space-3);
    }

    .gs-stat-ribbon .card {
        min-width: 100%;
    }
}

}

@layer responsive {


@media (max-width: 768px) {
    .dashboard-two-col {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 480px) {
    .admin-main > *:not(.admin-footer) {
        padding-left: var(--sp-space-2);
        padding-right: var(--sp-space-2);
    }
    .admin-footer {
        padding-left: var(--sp-space-2);
        padding-right: var(--sp-space-2);
        padding-bottom: calc(var(--sp-space-3) + env(safe-area-inset-bottom, 0px));
    }

    .admin-header {
        padding: var(--sp-space-2);
    }

    .admin-header h1 {
        font-size: var(--sp-text-base);
    }

    .admin-sidebar {
        width: 100vw;
    }


    .card, .stat-card, .health-card {
        --sp-shadow-card: var(--sp-shadow-sm);
        --sp-shadow-card-hover: var(--sp-shadow-md);
    }
    .plugin-card {
        --sp-shadow-card: var(--sp-shadow-sm);
        --sp-shadow-card-hover: var(--sp-shadow-md);
    }

    .sf-session-title {
        white-space: normal;
        word-break: break-word;
    }

    .sf-session-header {
        padding-right: var(--sp-space-8);
    }

    .dashboard-two-col {
        grid-template-columns: 1fr;
    }
}


@media (hover: none) {
    .data-table tr:hover td {
        background: inherit;
    }
    .btn-actions-trigger:hover,
    .actions-trigger:hover {
        background: transparent;
        border-color: var(--sp-border-default);
        color: var(--sp-text-secondary);
    }
    .admin-sidebar nav a:hover {
        background: transparent;
        color: var(--sp-text-secondary);
    }
    .stat-card:hover {
        transform: none;
        box-shadow: none;
    }
}


@media print {
    .admin-layout .admin-sidebar,
    .admin-layout .sidebar-toggle,
    .admin-layout .sidebar-overlay,
    .admin-layout .toolbar .btn-primary,
    .admin-layout .pagination,
    .admin-layout .actions-popup,
    .admin-layout .col-actions {
        display: none;
    }

    .admin-layout .admin-main {
        padding: 0;
    }

    .admin-layout .table-container {
        border: none;
        margin: 0;
    }
}

}

@layer responsive {
@media (max-width: 768px) {
    .header-actions {
        position: relative;
        flex-shrink: 0;
    }
    .header-actions-toggle {
        display: flex;
    }
    .header-actions-menu {
        display: none;
        position: absolute;
        top: calc(100% + var(--sp-space-2));
        right: 0;
        background: var(--sp-bg-surface);
        border: 1px solid var(--sp-border-default);
        border-radius: var(--sp-radius-md);
        box-shadow: var(--sp-shadow-lg);
        padding: var(--sp-space-2);
        min-width: 200px;
        z-index: var(--sp-z-sticky-header);
        flex-direction: column;
        gap: var(--sp-space-2);
    }
    .header-actions.open .header-actions-menu {
        display: flex;
    }
    .header-actions-menu .header-help-link {
        width: 100%;
        height: auto;
        border-radius: var(--sp-radius-sm);
        padding: var(--sp-space-2) var(--sp-space-3);
        justify-content: flex-start;
        gap: var(--sp-space-2);
    }
    .header-actions-menu .header-help-link::after {
        content: 'Help';
        font-size: var(--sp-text-sm);
        color: var(--sp-text-secondary);
    }
    .header-actions-menu .install-menu {
        width: 100%;
    }
    .header-actions-menu .install-trigger {
        width: 100%;
        justify-content: flex-start;
        padding: var(--sp-space-2) var(--sp-space-3);
        gap: var(--sp-space-2);
        border-radius: var(--sp-radius-sm);
        min-height: 40px;
    }
    .header-actions-menu .install-trigger::after {
        content: 'Share & Install';
        font-size: var(--sp-text-sm);
        color: var(--sp-text-secondary);
    }
    .header-actions-menu .user-widget-row {
        display: flex;
        align-items: center;
        gap: var(--sp-space-2);
        padding: var(--sp-space-2) var(--sp-space-3);
    }
    .header-actions-menu .user-widget {
        width: 38px;
        height: 38px;
    }
    .header-actions-menu .user-widget__xp-ring {
        width: 38px;
        height: 38px;
    }
    .header-actions-menu .install-dropdown {
        position: fixed;
        top: auto;
        right: var(--sp-space-3);
        left: var(--sp-space-3);
        width: auto;
    }

    .section-title {
        font-size: var(--sp-text-sm);
        margin: var(--sp-space-4) 0 var(--sp-space-2);
    }

    .form-grid {
        grid-template-columns: 1fr;
    }

    .toast-container {
        left: var(--sp-space-3);
        right: var(--sp-space-3);
        top: var(--sp-space-3);
    }
    .toast {
        max-width: none;
    }
    .platform-info-bar { flex-wrap: wrap; }
    .section-header { flex-wrap: wrap; }
    .selection-save-bar { flex-direction: column; gap: var(--sp-space-2); }

    html .hide-mobile { display: none; }
}
}

@layer responsive {
html, body {
    overflow-x: hidden;
}
@media (max-width: 1024px) {
    .admin-main > *:not(.admin-footer) {
        padding-left: var(--sp-space-4);
        padding-right: var(--sp-space-5);
    }
    .admin-main .table-container,
    .admin-main .metric-ribbon,
    .admin-main .cc-tabs,
    .admin-main .toolbar,
    .admin-main .usage-chart-container,
    .admin-main .cc-stats-bar {
        margin-left: calc(-1 * var(--sp-space-4));
    }
    .admin-main .dashboard-grid,
    .admin-main .stats-grid-3col,
    .admin-main .quick-stats-grid,
    .admin-main .realtime-pulse-grid,
    .admin-main .health-cards,
    .admin-main .dashboard-stats,
    .admin-main .dashboard-two-col,
    .admin-main .alerts-row,
    .admin-main .dashboard-tabs {
        margin-left: calc(-1 * var(--sp-space-4));
        padding-left: var(--sp-space-4);
    }
}

@media (max-width: 768px) {
    .admin-layout {
        display: block;
        height: auto;
        overflow-y: auto;
    }

    .sidebar-toggle {
        display: flex;
    }
    .sidebar-close-btn {
        display: flex;
    }
    .admin-sidebar {
        position: fixed;
        top: 0;
        left: 0;
        width: 280px;
        height: 100vh;
        z-index: var(--sp-z-sidebar-drawer);
        transform: translateX(-100%);
        transition: transform var(--sp-duration-slow) var(--sp-ease-out);
        box-shadow: none;
        padding-bottom: env(safe-area-inset-bottom);
    }
    .admin-sidebar.open {
        transform: translateX(0);
        box-shadow: var(--sp-shadow-xl);
    }
    .admin-sidebar nav a {
        padding: var(--sp-space-3) var(--sp-space-5);
        min-height: 44px;
    }

    .admin-main {
        overflow-x: hidden;
        max-width: 100vw;
    }
    .admin-main > *:not(.admin-footer) {
        padding-left: var(--sp-space-3);
        padding-right: var(--sp-space-3);
    }
    .admin-main .table-container,
    .admin-main .metric-ribbon,
    .admin-main .cc-tabs,
    .admin-main .toolbar,
    .admin-main .usage-chart-container,
    .admin-main .cc-stats-bar {
        margin-left: calc(-1 * var(--sp-space-3));
    }
    .admin-main .dashboard-grid,
    .admin-main .stats-grid-3col,
    .admin-main .quick-stats-grid,
    .admin-main .realtime-pulse-grid,
    .admin-main .health-cards,
    .admin-main .dashboard-stats,
    .admin-main .dashboard-two-col,
    .admin-main .alerts-row,
    .admin-main .dashboard-tabs {
        margin-left: calc(-1 * var(--sp-space-3));
        padding-left: var(--sp-space-3);
    }
    .admin-footer {
        padding-left: var(--sp-space-3);
        padding-right: var(--sp-space-3);
        padding-bottom: calc(var(--sp-space-4) + env(safe-area-inset-bottom, 0px));
    }

    .admin-header {
        position: sticky;
        top: 0;
        z-index: var(--sp-z-sticky-header);
        background: var(--sp-bg-canvas);
        gap: var(--sp-space-2);
        margin-top: 0;
        padding: var(--sp-space-2) var(--sp-space-3);
        margin-bottom: var(--sp-space-3);
        border-bottom: 1px solid var(--sp-border-subtle);
        box-shadow: var(--sp-shadow-sm);
        flex-wrap: nowrap;
    }
    .admin-header h1 {
        font-size: var(--sp-text-lg);
        white-space: nowrap;
        overflow: hidden;
        text-overflow: ellipsis;
        min-width: 0;
    }
}

@media (max-width: 768px) and (prefers-reduced-motion: reduce) {
    .admin-sidebar {
        transition: none;
    }
}
}

@layer utilities {

.marketplace-empty-heading {
  font-size: var(--sp-text-lg);
  font-weight: 600;
  margin: 0 0 var(--sp-space-2);
}
.marketplace-empty-text {
  max-width: 420px;
  margin: 0 auto var(--sp-space-5);
  line-height: 1.5;
}

.plugin-view-header {
  margin: 0 0 var(--sp-space-2);
  font-size: var(--sp-text-xl);
  font-weight: 700;
}
.plugin-view-desc {
  margin: 0 0 var(--sp-space-3);
  max-width: 600px;
}

.panel-title-inline {
  margin: 0;
  font-size: var(--sp-text-lg);
}

.link-primary-bold {
  color: var(--sp-text-primary);
  text-decoration: underline;
  font-weight: 500;
}

.badge-padded { padding: var(--sp-space-1) var(--sp-space-3); }
.btn-compact { font-size: var(--sp-text-xs); padding: 0.125rem var(--sp-space-2); }

.billing-stats-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: var(--sp-space-4);
}
.billing-stats-grid > div {
  background: var(--sp-bg-tertiary);
  border-radius: var(--sp-radius-md);
  padding: var(--sp-space-4);
  border: 1px solid var(--sp-border-subtle);
}
.billing-plans-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: var(--sp-space-6);
}
.plan-card {
  background: var(--sp-bg-tertiary);
  border: 1px solid var(--sp-border-subtle);
  border-radius: var(--sp-radius-card-brand);
  overflow: hidden;
  transition: box-shadow var(--sp-duration-normal) var(--sp-ease-out),
              border-color var(--sp-duration-normal);
}
.plan-card:hover {
  box-shadow: var(--sp-shadow-card-hover);
}
.plan-card-active {
  border-color: var(--sp-color-primary);
  box-shadow: 0 0 0 1px var(--sp-color-primary), var(--sp-shadow-card);
}
.plan-card-featured {
  border: 2px solid var(--sp-color-primary);
  box-shadow: 0 4px 16px oklch(0.67 0.18 50 / 0.2);
  background: var(--sp-bg-surface-gradient);
  position: relative;
}
.plan-card-featured::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 3px;
  background: linear-gradient(90deg, var(--sp-color-primary), oklch(0.75 0.15 50));
}
.plan-card-body {
  text-align: center;
  display: flex;
  flex-direction: column;
  padding: var(--sp-space-6);
}
.plan-badge {
  margin-bottom: var(--sp-space-2);
  align-self: center;
}
.plan-badge-recommended {
  margin-bottom: var(--sp-space-2);
  background: var(--sp-color-primary);
  color: var(--sp-text-on-accent);
  align-self: center;
}
.plan-price {
  font-size: var(--sp-text-2xl);
  font-weight: 700;
  margin-bottom: var(--sp-space-1);
  color: var(--sp-text-primary);
}
.plan-features {
  list-style: none;
  padding: 0;
  margin: 0 0 var(--sp-space-4) 0;
  text-align: left;
  flex: 1;
}
.plan-features li {
  padding: var(--sp-space-2) 0;
  font-size: var(--sp-text-sm);
  border-bottom: 1px solid var(--sp-border-subtle);
  color: var(--sp-text-secondary);
}
.plan-features li:last-child {
  border-bottom: none;
}

.billing-table-wrap {
  overflow-x: auto;
  border-radius: var(--sp-radius-md);
  border: 1px solid var(--sp-border-subtle);
}
.billing-comparison-table {
  width: 100%;
  border-collapse: collapse;
  font-size: var(--sp-text-sm);
}
.billing-thead-row {
  background: var(--sp-bg-tertiary);
  border-bottom: 2px solid var(--sp-border-subtle);
}
.billing-th-label { text-align: left; padding: var(--sp-space-3) var(--sp-space-4); width: 40%; }
.billing-th { text-align: center; padding: var(--sp-space-3) var(--sp-space-4); width: 20%; font-weight: 600; }
.billing-th-featured { color: var(--sp-color-primary); font-weight: 700; }
.billing-section-row { background: var(--sp-bg-tertiary); }
.billing-section-label { padding: var(--sp-space-3) var(--sp-space-4); font-weight: 600; color: var(--sp-text-primary); }
.billing-data-row { border-bottom: 1px solid var(--sp-border-subtle); }
.billing-data-row:hover { background: var(--sp-bg-tertiary); }
.billing-td-label { padding: var(--sp-space-3) var(--sp-space-4); color: var(--sp-text-secondary); }
.billing-td-val { text-align: center; padding: var(--sp-space-3); }

.mkt-list { display: flex; flex-direction: column; gap: var(--sp-space-3); }
.mkt-card-accent { border-left: 3px solid var(--sp-accent); }
.mkt-rank-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
  border-radius: var(--sp-radius-full);
  background: var(--sp-accent);
  color: var(--sp-text-on-accent);
  font-weight: 700;
  font-size: var(--sp-text-xs);
}
.mkt-card-title { margin: 0; font-size: var(--sp-text-base); font-weight: 600; color: var(--sp-text-primary); }
.mkt-card-desc { margin: var(--sp-space-1) 0 0; font-size: var(--sp-text-sm); color: var(--sp-text-secondary); }
.mkt-expand-icon {
  font-size: var(--sp-text-sm);
  color: var(--sp-text-tertiary);
  transition: transform var(--sp-duration-fast) var(--sp-ease-out);
  display: inline-block;
}
.mkt-details {
  padding: var(--sp-space-3);
  border-top: 1px solid var(--sp-border-primary);
}
.min-w-0 { min-width: 0; }

.xp-bar-track {
  background: var(--sp-bg-tertiary);
  border-radius: var(--sp-radius-sm);
  height: 8px;
  overflow: hidden;
}
.xp-bar-fill {
  background: var(--sp-color-primary);
  width: var(--sp-fill);
  height: 100%;
  border-radius: var(--sp-radius-sm);
}

.py-2 { padding-top: var(--sp-space-2); padding-bottom: var(--sp-space-2); }
.mb-1 { margin-bottom: var(--sp-space-1); }

}

@layer utilities {

.review-grid {
  display: grid;
  grid-template-columns: 140px 1fr;
  gap: var(--sp-space-3);
}

.bar-track {
  flex: 1;
  background: var(--sp-bg-secondary);
  border-radius: var(--sp-radius-xs);
  height: 20px;
  overflow: hidden;
}
.bar-fill {
  background: var(--sp-accent);
  width: var(--sp-fill);
  height: 100%;
  border-radius: var(--sp-radius-xs);
  transition: width 0.3s;
}

.hook-code-row { display: none; }
.form-row { display: flex; gap: var(--sp-space-3); }
.form-row > * { flex: 1; }

.empty-centered {
  text-align: center;
  padding: var(--sp-space-12) var(--sp-space-6);
  color: var(--sp-text-secondary);
}

.label-flex {
  display: flex;
  align-items: center;
  gap: var(--sp-space-2);
  cursor: pointer;
}

.mt-1 { margin-top: var(--sp-space-1); }
.ml-1 { margin-left: var(--sp-space-1); }
.ml-2 { margin-left: var(--sp-space-2); }
.mr-2 { margin-right: var(--sp-space-2); }

.text-accent { color: var(--sp-accent); }
.text-no-decor { text-decoration: none; }
.cursor-pointer { cursor: pointer; }
.cursor-default { cursor: default; }
.nowrap { white-space: nowrap; }
.flex-col { flex-direction: column; }
.overflow-hidden { overflow: hidden; }

.min-w-sm { min-width: 40px; }
.min-w-filter { min-width: 140px; }
.input-narrow { width: 180px; font-size: var(--sp-text-sm); }

.progress-track-sm {
  background: var(--sp-bg-tertiary);
  border-radius: var(--sp-radius-sm);
  height: 8px;
  overflow: hidden;
}
.progress-fill-primary {
  background: var(--sp-color-primary);
  height: 100%;
  border-radius: var(--sp-radius-sm);
}

.fork-indicator {
  margin-bottom: var(--sp-space-3);
  padding: var(--sp-space-2) var(--sp-space-3);
  background: var(--sp-bg-warning);
  border-radius: var(--sp-radius-md);
  font-size: var(--sp-text-sm);
}

.achievement-name { font-weight: 600; font-size: var(--sp-text-sm); color: var(--sp-text-primary); }
.achievement-detail { font-size: var(--sp-text-xs); color: var(--sp-text-tertiary); margin-top: var(--sp-space-1); }

.detail-pre-wrap {
  white-space: pre-wrap;
  font-size: var(--sp-text-sm);
  color: var(--sp-text-secondary);
  max-height: 200px;
  overflow: auto;
  margin-top: var(--sp-space-2);
}

.ribbon-heading {
  font-weight: 700;
  font-size: var(--sp-text-base);
  color: var(--sp-text-primary);
  margin-right: var(--sp-space-2);
}

.user-level-badge--sm {
  width: 24px;
  height: 24px;
  font-size: 0.6rem;
}

.login-error--success {
  color: var(--sp-color-success);
  border-color: var(--sp-color-success);
}

.card-footer {
  padding: var(--sp-space-4) var(--sp-space-6);
  border-top: 1px solid var(--sp-border-subtle);
  display: flex;
  align-items: center;
  gap: var(--sp-space-3);
}

.font-normal { font-weight: 400; }
.theme-label {
  font-size: var(--sp-text-sm);
  color: var(--sp-text-secondary);
  font-weight: 500;
}
}

@layer utilities {
.d-flex { display: flex; }
.d-grid { display: grid; }
.d-none { display: none; }
.d-inline-flex { display: inline-flex; }
.flex-1 { flex: 1; }
.flex-wrap { flex-wrap: wrap; }
.align-center { align-items: center; }
.align-start { align-items: flex-start; }
.justify-end { justify-content: flex-end; }
.justify-between { justify-content: space-between; }
.justify-center { justify-content: center; }
.gap-1 { gap: var(--sp-space-1); }
.gap-2 { gap: var(--sp-space-2); }
.gap-3 { gap: var(--sp-space-3); }
.gap-4 { gap: var(--sp-space-4); }
.gap-5 { gap: var(--sp-space-5); }
.gap-6 { gap: var(--sp-space-6); }
.mb-0 { margin-bottom: 0; }
.mb-1 { margin-bottom: var(--sp-space-1); }
.mb-2 { margin-bottom: var(--sp-space-2); }
.mb-3 { margin-bottom: var(--sp-space-3); }
.mb-4 { margin-bottom: var(--sp-space-4); }
.mb-5 { margin-bottom: var(--sp-space-5); }
.mb-6 { margin-bottom: var(--sp-space-6); }
.mt-0 { margin-top: 0; }
.mt-2 { margin-top: var(--sp-space-2); }
.mt-3 { margin-top: var(--sp-space-3); }
.mt-4 { margin-top: var(--sp-space-4); }
.mt-5 { margin-top: var(--sp-space-5); }
.mt-6 { margin-top: var(--sp-space-6); }
.mx-auto { margin-left: auto; margin-right: auto; }
.ml-auto { margin-left: auto; }
.p-2 { padding: var(--sp-space-2); }
.p-3 { padding: var(--sp-space-3); }
.p-4 { padding: var(--sp-space-4); }
.p-5 { padding: var(--sp-space-5); }
.p-6 { padding: var(--sp-space-6); }
.px-6 { padding-left: var(--sp-space-6); padding-right: var(--sp-space-6); }
.py-12 { padding-top: var(--sp-space-12); padding-bottom: var(--sp-space-12); }

.text-xs { font-size: var(--sp-text-xs); }
.text-sm { font-size: var(--sp-text-sm); }
.text-base { font-size: var(--sp-text-base); }
.text-lg { font-size: var(--sp-text-lg); }
.text-xl { font-size: var(--sp-text-xl); }
.text-2xl { font-size: var(--sp-text-2xl); }
.font-medium { font-weight: 500; }
.font-semibold { font-weight: 600; }
.font-bold { font-weight: 700; }
.text-center { text-align: center; }
.text-right { text-align: right; }
.text-primary { color: var(--sp-text-primary); }
.text-secondary { color: var(--sp-text-secondary); }
.text-tertiary { color: var(--sp-text-tertiary); }
.text-danger { color: var(--sp-danger); }
.text-success { color: var(--sp-success); }
.text-underline { text-decoration: underline; }

.w-full { width: 100%; }
.w-auto { width: auto; }
.max-w-md { max-width: 560px; }
.max-w-lg { max-width: 800px; }
.max-w-xl { max-width: 1080px; }
.box-border { box-sizing: border-box; }

.min-w-label { min-width: 180px; }
.min-w-count { min-width: 60px; }

.wizard-heading {
  margin: 0 0 var(--sp-space-4);
  font-size: var(--sp-text-lg);
  font-weight: 600;
}
.wizard-card {
  max-width: 800px;
  padding: var(--sp-space-5);
}
.wizard-heading-xl {
  margin: var(--sp-space-4) 0 var(--sp-space-5);
  font-size: var(--sp-text-xl);
  font-weight: 600;
}

.checklist-scroll {
  max-height: 300px;
  overflow-y: auto;
  border: 1px solid var(--sp-border-subtle);
  border-radius: var(--sp-radius-md);
  padding: var(--sp-space-2);
}
.checklist-filter-row {
  display: flex;
  gap: var(--sp-space-2);
  margin-bottom: var(--sp-space-2);
}
.checklist-empty { padding: var(--sp-space-4); }

.confirm-actions {
  display: flex;
  gap: var(--sp-space-3);
  justify-content: flex-end;
  margin-top: var(--sp-space-5);
}

}
