@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+Display&display=swap');/**
 * Main CSS entry point for CartoVision UI
 * 
 * This file imports all base styles and tokens.
 * AG Grid theming is handled via the Theming API (themeFactory.ts),
 * so no theme CSS files are needed.
 */
/**
 * Google Fonts imports
 * 
 * Import custom fonts used in theme presets
 */
/* Font imports moved to src/styles/index.css to satisfy PostCSS ordering */
/**
 * Base styles - Resets and base styles for the library
 * 
 * Note: All styles are scoped to .cv-data-table to avoid conflicts
 * with the consuming project's styles.
 */
/* Reset box-sizing - Scoped to DataTable only */
.cv-data-table,
.cv-data-table *,
.cv-data-table *::before,
.cv-data-table *::after {
    box-sizing: border-box;
}
/* Base styles for DataTable component */
.cv-data-table {
    font-family: var(--cv-ui-font-family);
    font-size: var(--cv-ui-font-size-sm);
    color: var(--cv-ui-text-primary);
    line-height: 1.5;
}
/* Ensure tables are properly styled */
.cv-data-table table {
    width: 100%;
    border-collapse: collapse;
    border-spacing: 0;
}
/* Remove default button styles */
.cv-data-table button {
    font-family: inherit;
    font-size: inherit;
    line-height: inherit;
    cursor: pointer;
}
/* Remove default input styles */
.cv-data-table input,
.cv-data-table select,
.cv-data-table textarea {
    font-family: inherit;
    font-size: inherit;
    line-height: inherit;
    margin: 0;
}
/* Remove default list styles */
.cv-data-table ul,
.cv-data-table ol {
    margin: 0;
    padding: 0;
    list-style: none;
}
/* Ensure proper text rendering */
.cv-data-table {
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    text-rendering: optimizeLegibility;
}
/* Remove default focus outline (will be replaced by custom focus styles) */
.cv-data-table *:focus {
    outline: none;
}
/**
 * CSS Tokens - Variables CSS communes à toute la librairie
 * Préfixe: --cv-ui-* (CartoVision UI)
 * 
 * Ces tokens peuvent être overridés par les projets receveurs via le plugin
 */
:root {
    /* ============================================
     COLORS - Base
     ============================================ */
    --cv-ui-color-primary: #3b82f6;
    --cv-ui-color-primary-hover: #2563eb;
    --cv-ui-color-primary-light: #dbeafe;
    --cv-ui-color-primary-dark: #1e40af;

    --cv-ui-color-secondary: #6b7280;
    --cv-ui-color-secondary-hover: #4b5563;
    --cv-ui-color-secondary-light: #f3f4f6;
    --cv-ui-color-secondary-dark: #374151;

    --cv-ui-color-success: #10b981;
    --cv-ui-color-success-hover: #059669;
    --cv-ui-color-success-light: #d1fae5;
    --cv-ui-color-success-dark: #047857;

    --cv-ui-color-warning: #f59e0b;
    --cv-ui-color-warning-hover: #d97706;
    --cv-ui-color-warning-light: #fef3c7;
    --cv-ui-color-warning-dark: #b45309;

    --cv-ui-color-danger: #ef4444;
    --cv-ui-color-danger-hover: #dc2626;
    --cv-ui-color-danger-light: #fee2e2;
    --cv-ui-color-danger-dark: #b91c1c;

    --cv-ui-color-info: #3b82f6;
    --cv-ui-color-info-hover: #2563eb;
    --cv-ui-color-info-light: #dbeafe;
    --cv-ui-color-info-dark: #1e40af;

    /* ============================================
     COLORS - Backgrounds
     ============================================ */
    --cv-ui-bg-primary: #ffffff;
    --cv-ui-bg-secondary: #f8fafc;
    --cv-ui-bg-tertiary: #f1f5f9;
    --cv-ui-bg-hover: #f9fafb;
    --cv-ui-bg-active: #f3f4f6;

    /* ============================================
     COLORS - Text
     ============================================ */
    --cv-ui-text-primary: #1e293b;
    --cv-ui-text-secondary: #64748b;
    --cv-ui-text-tertiary: #94a3b8;
    --cv-ui-text-disabled: #cbd5e1;
    --cv-ui-text-inverse: #ffffff;

    /* ============================================
     COLORS - Borders
     ============================================ */
    --cv-ui-border-color: #e2e8f0;
    --cv-ui-border-color-hover: #cbd5e1;
    --cv-ui-border-color-focus: #3b82f6;
    --cv-ui-border-color-error: #ef4444;

    /* ============================================
     SPACING
     ============================================ */
    --cv-ui-spacing-xs: 4px;
    --cv-ui-spacing-sm: 8px;
    --cv-ui-spacing-md: 16px;
    --cv-ui-spacing-lg: 24px;
    --cv-ui-spacing-xl: 32px;
    --cv-ui-spacing-2xl: 48px;

    /* ============================================
     BORDER RADIUS
     ============================================ */
    --cv-ui-radius-sm: 4px;
    --cv-ui-radius-md: 6px;
    --cv-ui-radius-lg: 8px;
    --cv-ui-radius-xl: 12px;
    --cv-ui-radius-full: 9999px;

    /* ============================================
     SHADOWS
     ============================================ */
    --cv-ui-shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, 0.05);
    --cv-ui-shadow-md: 0 4px 6px -1px rgba(0, 0, 0, 0.1), 0 2px 4px -1px rgba(0, 0, 0, 0.06);
    --cv-ui-shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -2px rgba(0, 0, 0, 0.05);
    --cv-ui-shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, 0.1), 0 10px 10px -5px rgba(0, 0, 0, 0.04);

    /* Focus / validation rings — utilisés sur tous les inputs/controls */
    --cv-ui-shadow-focus: 0 0 0 3px rgba(59, 130, 246, 0.15);
    --cv-ui-shadow-focus-error: 0 0 0 3px rgba(239, 68, 68, 0.15);
    --cv-ui-shadow-focus-success: 0 0 0 3px rgba(34, 197, 94, 0.15);

    /* ============================================
     TYPOGRAPHY
     ============================================ */
    --cv-ui-font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;
    --cv-ui-font-size-xs: 12px;
    --cv-ui-font-size-sm: 14px;
    --cv-ui-font-size-md: 16px;
    --cv-ui-font-size-lg: 18px;
    --cv-ui-font-size-xl: 20px;
    --cv-ui-font-weight-normal: 400;
    --cv-ui-font-weight-medium: 500;
    --cv-ui-font-weight-semibold: 600;
    --cv-ui-font-weight-bold: 700;

    /* ============================================
     Z-INDEX
     ============================================ */
    --cv-ui-z-base: 1;
    --cv-ui-z-dropdown: 5000;
    --cv-ui-z-sticky: 1020;
    --cv-ui-z-fixed: 1030;
    --cv-ui-z-modal-backdrop: 1040;
    --cv-ui-z-modal: 1050;
    --cv-ui-z-popover: 1060;
    --cv-ui-z-tooltip: 1070;
    --cv-ui-z-toast: 1080;

    /* ============================================
     TRANSITIONS
     ============================================ */
    --cv-ui-transition-fast: 150ms;
    --cv-ui-transition-base: 200ms;
    --cv-ui-transition-slow: 300ms;
    --cv-ui-transition-timing: cubic-bezier(0.4, 0, 0.2, 1);

    /* ============================================
     DATATABLE - Custom Tool Panels Only
     Note: AG Grid styling uses Theme API, not CSS variables
     Les panels custom utilisent maintenant exclusivement les variables AG Grid
     ============================================ */

    /* ============================================
     TREE
     ============================================ */
    --cv-tree-bg: var(--cv-ui-bg-primary);
    --cv-tree-row-hover-bg: var(--cv-ui-bg-hover);
    --cv-tree-row-active-bg: var(--cv-ui-bg-active);
    --cv-tree-text: var(--cv-ui-text-primary);
    --cv-tree-muted: var(--cv-ui-text-secondary);
    --cv-tree-focus-ring: var(--cv-ui-border-color-focus);
    --cv-tree-indent: 16px;
    --cv-tree-border: var(--cv-ui-border-color);
}
/**
 * Brand theme — overrides --cv-ui-* tokens for [data-theme="brand"].
 *
 * Palette : bleu-indigo (oklch hue ~250).
 * Les couleurs sémantiques (success, warning, danger, info) conservent
 * leurs valeurs par défaut ; seules les couleurs primaires, secondaires,
 * backgrounds, textes et bordures sont adaptées à la marque.
 *
 * Applied when data-theme="brand" (light par défaut, dark si data-mode="dark").
 */
/* ============================================================
   BRAND LIGHT
   ============================================================ */
[data-theme='brand']:not([data-mode='dark']),
.cv-theme-brand {
    /* Primary */
    --cv-ui-color-primary: oklch(0.6 0.22 250); /* ~#4C6CF5 */
    --cv-ui-color-primary-hover: oklch(0.54 0.22 250); /* ~#3B5CE0 */
    --cv-ui-color-primary-light: oklch(0.94 0.05 250); /* ~#EEF0FD */
    --cv-ui-color-primary-dark: oklch(0.4 0.22 250); /* ~#2341C0 */

    /* Secondary */
    --cv-ui-color-secondary: oklch(0.52 0.08 255);
    --cv-ui-color-secondary-hover: oklch(0.45 0.08 255);
    --cv-ui-color-secondary-light: oklch(0.94 0.02 255);
    --cv-ui-color-secondary-dark: oklch(0.32 0.08 255);

    /* Backgrounds — légèrement blue-tintés */
    --cv-ui-bg-primary: oklch(0.99 0.01 250); /* ~#FAFBFF */
    --cv-ui-bg-secondary: oklch(0.96 0.02 250); /* ~#F0F4FF */
    --cv-ui-bg-tertiary: oklch(0.93 0.03 250); /* ~#E8EDFF */
    --cv-ui-bg-hover: oklch(0.95 0.02 250);
    --cv-ui-bg-active: oklch(0.91 0.04 250);

    /* Text — blue-tintés */
    --cv-ui-text-primary: oklch(0.22 0.06 255); /* ~#1A2340 */
    --cv-ui-text-secondary: oklch(0.45 0.08 255);
    --cv-ui-text-tertiary: oklch(0.62 0.06 255);
    --cv-ui-text-disabled: oklch(0.75 0.04 255);
    --cv-ui-text-inverse: #ffffff;

    /* Borders */
    --cv-ui-border-color: oklch(0.88 0.03 250); /* ~#D5DCF5 */
    --cv-ui-border-color-hover: oklch(0.78 0.06 250);
    --cv-ui-border-color-focus: oklch(0.6 0.22 250); /* = primary */
    --cv-ui-border-color-error: oklch(0.6 0.22 25); /* = danger */

    /* Border radius — légèrement plus arrondi */
    --cv-ui-radius-sm: 6px;
    --cv-ui-radius-md: 8px;
    --cv-ui-radius-lg: 12px;
    --cv-ui-radius-xl: 16px;
}
/* ============================================================
   BRAND DARK
   ============================================================ */
[data-theme='brand'][data-mode='dark'] {
    /* Primary */
    --cv-ui-color-primary: oklch(0.72 0.18 250);
    --cv-ui-color-primary-hover: oklch(0.8 0.15 250);
    --cv-ui-color-primary-light: oklch(0.25 0.1 250);
    --cv-ui-color-primary-dark: oklch(0.85 0.12 250);

    /* Secondary */
    --cv-ui-color-secondary: oklch(0.62 0.06 255);
    --cv-ui-color-secondary-hover: oklch(0.7 0.04 255);
    --cv-ui-color-secondary-light: oklch(0.28 0.05 255);
    --cv-ui-color-secondary-dark: oklch(0.8 0.04 255);

    /* Backgrounds */
    --cv-ui-bg-primary: oklch(0.18 0.03 255); /* ~#0F1525 */
    --cv-ui-bg-secondary: oklch(0.22 0.04 255); /* ~#151E30 */
    --cv-ui-bg-tertiary: oklch(0.27 0.04 255); /* ~#1E293D */
    --cv-ui-bg-hover: oklch(0.24 0.04 255);
    --cv-ui-bg-active: oklch(0.3 0.05 255);

    /* Text */
    --cv-ui-text-primary: oklch(0.94 0.02 250); /* ~#EBF0FF */
    --cv-ui-text-secondary: oklch(0.78 0.04 250);
    --cv-ui-text-tertiary: oklch(0.62 0.04 250);
    --cv-ui-text-disabled: oklch(0.45 0.04 255);
    --cv-ui-text-inverse: oklch(0.18 0.03 255);

    /* Borders */
    --cv-ui-border-color: oklch(0.3 0.05 255);
    --cv-ui-border-color-hover: oklch(0.38 0.06 255);
    --cv-ui-border-color-focus: oklch(0.72 0.18 250); /* = primary */
    --cv-ui-border-color-error: oklch(0.67 0.2 25);

    /* Shadows — plus prononcées sur fond sombre */
    --cv-ui-shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, 0.4);
    --cv-ui-shadow-md: 0 4px 6px -1px rgba(0, 0, 0, 0.4), 0 2px 4px -1px rgba(0, 0, 0, 0.3);
    --cv-ui-shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, 0.4), 0 4px 6px -2px rgba(0, 0, 0, 0.3);
    --cv-ui-shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, 0.5), 0 10px 10px -5px rgba(0, 0, 0, 0.3);

    /* Border radius — cohérent avec light */
    --cv-ui-radius-sm: 6px;
    --cv-ui-radius-md: 8px;
    --cv-ui-radius-lg: 12px;
    --cv-ui-radius-xl: 16px;
}
/**
 * Dark theme - overrides --cv-ui-* tokens for dark mode.
 * Applied when data-theme="dark" or data-mode="dark".
 */
[data-theme='dark'],
[data-mode='dark'],
.cv-theme-dark {
    /* Colors - Backgrounds */
    --cv-ui-bg-primary: #1e293b;
    --cv-ui-bg-secondary: #334155;
    --cv-ui-bg-tertiary: #475569;
    --cv-ui-bg-hover: #334155;
    --cv-ui-bg-active: #475569;

    /* Colors - Text */
    --cv-ui-text-primary: #f1f5f9;
    --cv-ui-text-secondary: #cbd5e1;
    --cv-ui-text-tertiary: #94a3b8;
    --cv-ui-text-disabled: #64748b;
    --cv-ui-text-inverse: #0f172a;

    /* Colors - Borders */
    --cv-ui-border-color: #475569;
    --cv-ui-border-color-hover: #64748b;
    --cv-ui-border-color-focus: #60a5fa;
    --cv-ui-border-color-error: #f87171;

    /* Primary (lighter in dark for contrast) */
    --cv-ui-color-primary: #60a5fa;
    --cv-ui-color-primary-hover: #93c5fd;
    --cv-ui-color-primary-light: #1e3a5f;
    --cv-ui-color-primary-dark: #93c5fd;

    /* Secondary */
    --cv-ui-color-secondary: #9ca3af;
    --cv-ui-color-secondary-hover: #d1d5db;
    --cv-ui-color-secondary-light: #374151;
    --cv-ui-color-secondary-dark: #e5e7eb;

    /* Success */
    --cv-ui-color-success: #34d399;
    --cv-ui-color-success-hover: #6ee7b7;
    --cv-ui-color-success-light: #064e3b;
    --cv-ui-color-success-dark: #a7f3d0;

    /* Warning */
    --cv-ui-color-warning: #fbbf24;
    --cv-ui-color-warning-hover: #fcd34d;
    --cv-ui-color-warning-light: #451a03;
    --cv-ui-color-warning-dark: #fde68a;

    /* Danger */
    --cv-ui-color-danger: #f87171;
    --cv-ui-color-danger-hover: #fca5a5;
    --cv-ui-color-danger-light: #450a0a;
    --cv-ui-color-danger-dark: #fecaca;

    /* Info */
    --cv-ui-color-info: #60a5fa;
    --cv-ui-color-info-hover: #93c5fd;
    --cv-ui-color-info-light: #1e3a5f;
    --cv-ui-color-info-dark: #bfdbfe;

    /* Focus rings — teintés avec la couleur primaire dark */
    --cv-ui-shadow-focus: 0 0 0 3px rgba(96, 165, 250, 0.25);
    --cv-ui-shadow-focus-error: 0 0 0 3px rgba(248, 113, 113, 0.25);
    --cv-ui-shadow-focus-success: 0 0 0 3px rgba(52, 211, 153, 0.25);

    /* Shadows (subtle in dark) */
    --cv-ui-shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, 0.3);
    --cv-ui-shadow-md: 0 4px 6px -1px rgba(0, 0, 0, 0.3), 0 2px 4px -1px rgba(0, 0, 0, 0.2);
    --cv-ui-shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, 0.3), 0 4px 6px -2px rgba(0, 0, 0, 0.2);
    --cv-ui-shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, 0.3), 0 10px 10px -5px rgba(0, 0, 0, 0.2);
}
/* Optional theme overrides for consuming apps */
:root {
    --color-primary: var(--cv-ui-color-primary);
    --color-primary-hover: var(--cv-ui-color-primary-hover);
    --color-info: var(--cv-ui-color-info);
    --color-warning: var(--cv-ui-color-warning);
    --color-error: var(--cv-ui-color-danger);
}
/**
 * Google Fonts imports
 * 
 * Import custom fonts used in theme presets
 */

/* Font imports moved to src/styles/index.css to satisfy PostCSS ordering */
/**
 * Base styles - Resets and base styles for the library
 * 
 * Note: All styles are scoped to .cv-data-table to avoid conflicts
 * with the consuming project's styles.
 */

/* Reset box-sizing - Scoped to DataTable only */
.cv-data-table,
.cv-data-table *,
.cv-data-table *::before,
.cv-data-table *::after {
    box-sizing: border-box;
}

/* Base styles for DataTable component */
.cv-data-table {
    font-family: var(--cv-ui-font-family);
    font-size: var(--cv-ui-font-size-sm);
    color: var(--cv-ui-text-primary);
    line-height: 1.5;
}

/* Ensure tables are properly styled */
.cv-data-table table {
    width: 100%;
    border-collapse: collapse;
    border-spacing: 0;
}

/* Remove default button styles */
.cv-data-table button {
    font-family: inherit;
    font-size: inherit;
    line-height: inherit;
    cursor: pointer;
}

/* Remove default input styles */
.cv-data-table input,
.cv-data-table select,
.cv-data-table textarea {
    font-family: inherit;
    font-size: inherit;
    line-height: inherit;
    margin: 0;
}

/* Remove default list styles */
.cv-data-table ul,
.cv-data-table ol {
    margin: 0;
    padding: 0;
    list-style: none;
}

/* Ensure proper text rendering */
.cv-data-table {
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    text-rendering: optimizeLegibility;
}

/* Remove default focus outline (will be replaced by custom focus styles) */
.cv-data-table *:focus {
    outline: none;
}
/**
 * CSS Tokens - Variables CSS communes à toute la librairie
 * Préfixe: --cv-ui-* (CartoVision UI)
 * 
 * Ces tokens peuvent être overridés par les projets receveurs via le plugin
 */

:root {
    /* ============================================
     COLORS - Base
     ============================================ */
    --cv-ui-color-primary: #3b82f6;
    --cv-ui-color-primary-hover: #2563eb;
    --cv-ui-color-primary-light: #dbeafe;
    --cv-ui-color-primary-dark: #1e40af;

    --cv-ui-color-secondary: #6b7280;
    --cv-ui-color-secondary-hover: #4b5563;
    --cv-ui-color-secondary-light: #f3f4f6;
    --cv-ui-color-secondary-dark: #374151;

    --cv-ui-color-success: #10b981;
    --cv-ui-color-success-hover: #059669;
    --cv-ui-color-success-light: #d1fae5;
    --cv-ui-color-success-dark: #047857;

    --cv-ui-color-warning: #f59e0b;
    --cv-ui-color-warning-hover: #d97706;
    --cv-ui-color-warning-light: #fef3c7;
    --cv-ui-color-warning-dark: #b45309;

    --cv-ui-color-danger: #ef4444;
    --cv-ui-color-danger-hover: #dc2626;
    --cv-ui-color-danger-light: #fee2e2;
    --cv-ui-color-danger-dark: #b91c1c;

    --cv-ui-color-info: #3b82f6;
    --cv-ui-color-info-hover: #2563eb;
    --cv-ui-color-info-light: #dbeafe;
    --cv-ui-color-info-dark: #1e40af;

    /* ============================================
     COLORS - Backgrounds
     ============================================ */
    --cv-ui-bg-primary: #ffffff;
    --cv-ui-bg-secondary: #f8fafc;
    --cv-ui-bg-tertiary: #f1f5f9;
    --cv-ui-bg-hover: #f9fafb;
    --cv-ui-bg-active: #f3f4f6;

    /* ============================================
     COLORS - Text
     ============================================ */
    --cv-ui-text-primary: #1e293b;
    --cv-ui-text-secondary: #64748b;
    --cv-ui-text-tertiary: #94a3b8;
    --cv-ui-text-disabled: #cbd5e1;
    --cv-ui-text-inverse: #ffffff;

    /* ============================================
     COLORS - Borders
     ============================================ */
    --cv-ui-border-color: #e2e8f0;
    --cv-ui-border-color-hover: #cbd5e1;
    --cv-ui-border-color-focus: #3b82f6;
    --cv-ui-border-color-error: #ef4444;

    /* ============================================
     SPACING
     ============================================ */
    --cv-ui-spacing-xs: 4px;
    --cv-ui-spacing-sm: 8px;
    --cv-ui-spacing-md: 16px;
    --cv-ui-spacing-lg: 24px;
    --cv-ui-spacing-xl: 32px;
    --cv-ui-spacing-2xl: 48px;

    /* ============================================
     BORDER RADIUS
     ============================================ */
    --cv-ui-radius-sm: 4px;
    --cv-ui-radius-md: 6px;
    --cv-ui-radius-lg: 8px;
    --cv-ui-radius-xl: 12px;
    --cv-ui-radius-full: 9999px;

    /* ============================================
     SHADOWS
     ============================================ */
    --cv-ui-shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, 0.05);
    --cv-ui-shadow-md: 0 4px 6px -1px rgba(0, 0, 0, 0.1), 0 2px 4px -1px rgba(0, 0, 0, 0.06);
    --cv-ui-shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -2px rgba(0, 0, 0, 0.05);
    --cv-ui-shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, 0.1), 0 10px 10px -5px rgba(0, 0, 0, 0.04);

    /* Focus / validation rings — utilisés sur tous les inputs/controls */
    --cv-ui-shadow-focus: 0 0 0 3px rgba(59, 130, 246, 0.15);
    --cv-ui-shadow-focus-error: 0 0 0 3px rgba(239, 68, 68, 0.15);
    --cv-ui-shadow-focus-success: 0 0 0 3px rgba(34, 197, 94, 0.15);

    /* ============================================
     TYPOGRAPHY
     ============================================ */
    --cv-ui-font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;
    --cv-ui-font-size-xs: 12px;
    --cv-ui-font-size-sm: 14px;
    --cv-ui-font-size-md: 16px;
    --cv-ui-font-size-lg: 18px;
    --cv-ui-font-size-xl: 20px;
    --cv-ui-font-weight-normal: 400;
    --cv-ui-font-weight-medium: 500;
    --cv-ui-font-weight-semibold: 600;
    --cv-ui-font-weight-bold: 700;

    /* ============================================
     Z-INDEX
     ============================================ */
    --cv-ui-z-base: 1;
    --cv-ui-z-dropdown: 5000;
    --cv-ui-z-sticky: 1020;
    --cv-ui-z-fixed: 1030;
    --cv-ui-z-modal-backdrop: 1040;
    --cv-ui-z-modal: 1050;
    --cv-ui-z-popover: 1060;
    --cv-ui-z-tooltip: 1070;
    --cv-ui-z-toast: 1080;

    /* ============================================
     TRANSITIONS
     ============================================ */
    --cv-ui-transition-fast: 150ms;
    --cv-ui-transition-base: 200ms;
    --cv-ui-transition-slow: 300ms;
    --cv-ui-transition-timing: cubic-bezier(0.4, 0, 0.2, 1);

    /* ============================================
     DATATABLE - Custom Tool Panels Only
     Note: AG Grid styling uses Theme API, not CSS variables
     Les panels custom utilisent maintenant exclusivement les variables AG Grid
     ============================================ */

    /* ============================================
     TREE
     ============================================ */
    --cv-tree-bg: var(--cv-ui-bg-primary);
    --cv-tree-row-hover-bg: var(--cv-ui-bg-hover);
    --cv-tree-row-active-bg: var(--cv-ui-bg-active);
    --cv-tree-text: var(--cv-ui-text-primary);
    --cv-tree-muted: var(--cv-ui-text-secondary);
    --cv-tree-focus-ring: var(--cv-ui-border-color-focus);
    --cv-tree-indent: 16px;
    --cv-tree-border: var(--cv-ui-border-color);
}

.cv-ht[data-v-718ad0b8] {
        position: fixed;
        bottom: 16px;
        right: 16px;
        z-index: 9999;
        display: flex;
        gap: 6px;
        padding: 6px;
        background: rgba(255, 255, 255, 0.85);
        backdrop-filter: blur(8px);
        border: 1px solid rgba(0, 0, 0, 0.08);
        border-radius: 999px;
        box-shadow: 0 2px 8px rgba(0, 0, 0, 0.12);
}
.cv-ht__dot[data-v-718ad0b8] {
        width: 18px;
        height: 18px;
        border-radius: 50%;
        border: 2px solid transparent;
        background: var(--dot-color);
        cursor: pointer;
        padding: 0;
        outline: none;
        transition: transform 0.15s, box-shadow 0.15s;
}
.cv-ht__dot[data-v-718ad0b8]:hover {
        transform: scale(1.25);
        box-shadow: 0 0 0 2px rgba(0, 0, 0, 0.15);
}
.cv-ht__dot--active[data-v-718ad0b8] {
        border-color: rgba(0, 0, 0, 0.25);
        box-shadow: 0 0 0 2px var(--dot-color);
        transform: scale(1.15);
}
/**
 * Forest theme — overrides --cv-ui-* tokens for [data-theme="forest"].
 *
 * Palette : vert émeraude (oklch hue ~150) sur fonds crème chauds.
 * Inspiré de la nature : végétation dense, bois chaud, lumière tamisée.
 *
 * Applied when data-theme="forest".
 */

/* ============================================================
   FOREST LIGHT
   ============================================================ */
[data-theme='forest']:not([data-mode='dark']),
.cv-theme-forest {
    /* Primary — émeraude */
    --cv-ui-color-primary: oklch(0.52 0.18 152); /* ~#1a7a4a */
    --cv-ui-color-primary-hover: oklch(0.44 0.18 152); /* ~#136038 */
    --cv-ui-color-primary-light: oklch(0.94 0.05 152); /* ~#e8f7ee */
    --cv-ui-color-primary-dark: oklch(0.33 0.16 152); /* ~#0d4428 */

    /* Secondary — mousse/olive */
    --cv-ui-color-secondary: oklch(0.5 0.08 130);
    --cv-ui-color-secondary-hover: oklch(0.42 0.08 130);
    --cv-ui-color-secondary-light: oklch(0.93 0.03 130);
    --cv-ui-color-secondary-dark: oklch(0.3 0.08 130);

    /* Success — vert vif (cohérent avec le thème) */
    --cv-ui-color-success: oklch(0.56 0.2 145);
    --cv-ui-color-success-hover: oklch(0.48 0.2 145);
    --cv-ui-color-success-light: oklch(0.93 0.06 145);
    --cv-ui-color-success-dark: oklch(0.36 0.18 145);

    /* Warning — ambre chaud */
    --cv-ui-color-warning: oklch(0.72 0.18 65);
    --cv-ui-color-warning-hover: oklch(0.63 0.18 65);
    --cv-ui-color-warning-light: oklch(0.95 0.06 65);
    --cv-ui-color-warning-dark: oklch(0.5 0.16 65);

    /* Danger — brique terreuse */
    --cv-ui-color-danger: oklch(0.58 0.2 30);
    --cv-ui-color-danger-hover: oklch(0.5 0.2 30);
    --cv-ui-color-danger-light: oklch(0.94 0.05 30);
    --cv-ui-color-danger-dark: oklch(0.38 0.18 30);

    /* Info — ciel forêt */
    --cv-ui-color-info: oklch(0.6 0.14 220);
    --cv-ui-color-info-hover: oklch(0.52 0.14 220);
    --cv-ui-color-info-light: oklch(0.93 0.04 220);
    --cv-ui-color-info-dark: oklch(0.4 0.12 220);

    /* Backgrounds — crème chauds, légèrement verts */
    --cv-ui-bg-primary: oklch(0.99 0.01 100); /* ~#fdfcf8 blanc crème */
    --cv-ui-bg-secondary: oklch(0.96 0.02 120); /* ~#f3f7f0 vert très pâle */
    --cv-ui-bg-tertiary: oklch(0.92 0.03 130); /* ~#e8f0e2 */
    --cv-ui-bg-hover: oklch(0.95 0.02 125);
    --cv-ui-bg-active: oklch(0.9 0.04 135);

    /* Text — brun forestier */
    --cv-ui-text-primary: oklch(0.2 0.05 120); /* ~#1c2b18 */
    --cv-ui-text-secondary: oklch(0.42 0.07 135);
    --cv-ui-text-tertiary: oklch(0.58 0.06 135);
    --cv-ui-text-disabled: oklch(0.72 0.04 130);
    --cv-ui-text-inverse: #ffffff;

    /* Borders — vert sauge */
    --cv-ui-border-color: oklch(0.86 0.05 140); /* ~#c8ddc0 */
    --cv-ui-border-color-hover: oklch(0.76 0.08 140);
    --cv-ui-border-color-focus: oklch(0.52 0.18 152); /* = primary */
    --cv-ui-border-color-error: oklch(0.58 0.2 30);

    /* Border radius — organique, plus arrondi */
    --cv-ui-radius-sm: 6px;
    --cv-ui-radius-md: 10px;
    --cv-ui-radius-lg: 14px;
    --cv-ui-radius-xl: 20px;

    /* Shadows — chaudes et douces */
    --cv-ui-shadow-sm: 0 1px 2px 0 rgba(20, 50, 20, 0.07);
    --cv-ui-shadow-md: 0 4px 6px -1px rgba(20, 50, 20, 0.1), 0 2px 4px -1px rgba(20, 50, 20, 0.06);
    --cv-ui-shadow-lg: 0 10px 15px -3px rgba(20, 50, 20, 0.1), 0 4px 6px -2px rgba(20, 50, 20, 0.05);
    --cv-ui-shadow-xl: 0 20px 25px -5px rgba(20, 50, 20, 0.12), 0 10px 10px -5px rgba(20, 50, 20, 0.06);
}

/* ============================================================
   FOREST DARK
   ============================================================ */
[data-theme='forest'][data-mode='dark'] {
    /* Primary — émeraude clair sur fond sombre */
    --cv-ui-color-primary: oklch(0.68 0.16 152);
    --cv-ui-color-primary-hover: oklch(0.76 0.14 152);
    --cv-ui-color-primary-light: oklch(0.24 0.1 152);
    --cv-ui-color-primary-dark: oklch(0.82 0.1 152);

    /* Secondary */
    --cv-ui-color-secondary: oklch(0.58 0.06 130);
    --cv-ui-color-secondary-hover: oklch(0.66 0.05 130);
    --cv-ui-color-secondary-light: oklch(0.26 0.05 130);
    --cv-ui-color-secondary-dark: oklch(0.78 0.04 130);

    /* Success */
    --cv-ui-color-success: oklch(0.68 0.18 145);
    --cv-ui-color-success-hover: oklch(0.76 0.16 145);
    --cv-ui-color-success-light: oklch(0.22 0.1 145);
    --cv-ui-color-success-dark: oklch(0.82 0.12 145);

    /* Warning */
    --cv-ui-color-warning: oklch(0.78 0.16 65);
    --cv-ui-color-warning-hover: oklch(0.85 0.14 65);
    --cv-ui-color-warning-light: oklch(0.26 0.08 65);
    --cv-ui-color-warning-dark: oklch(0.9 0.1 65);

    /* Danger */
    --cv-ui-color-danger: oklch(0.68 0.18 30);
    --cv-ui-color-danger-hover: oklch(0.76 0.16 30);
    --cv-ui-color-danger-light: oklch(0.22 0.1 30);
    --cv-ui-color-danger-dark: oklch(0.84 0.12 30);

    /* Info */
    --cv-ui-color-info: oklch(0.68 0.12 220);
    --cv-ui-color-info-hover: oklch(0.76 0.1 220);
    --cv-ui-color-info-light: oklch(0.22 0.06 220);
    --cv-ui-color-info-dark: oklch(0.84 0.08 220);

    /* Backgrounds — sous-bois profond */
    --cv-ui-bg-primary: oklch(0.17 0.04 140); /* ~#0d2015 bois sombre */
    --cv-ui-bg-secondary: oklch(0.21 0.05 140); /* ~#142819 */
    --cv-ui-bg-tertiary: oklch(0.26 0.06 140); /* ~#1d3422 */
    --cv-ui-bg-hover: oklch(0.23 0.05 140);
    --cv-ui-bg-active: oklch(0.3 0.07 140);

    /* Text */
    --cv-ui-text-primary: oklch(0.93 0.03 130); /* ~#e8f0e2 */
    --cv-ui-text-secondary: oklch(0.76 0.05 135);
    --cv-ui-text-tertiary: oklch(0.6 0.05 135);
    --cv-ui-text-disabled: oklch(0.42 0.04 130);
    --cv-ui-text-inverse: oklch(0.17 0.04 140);

    /* Borders */
    --cv-ui-border-color: oklch(0.3 0.07 140);
    --cv-ui-border-color-hover: oklch(0.38 0.08 140);
    --cv-ui-border-color-focus: oklch(0.68 0.16 152);
    --cv-ui-border-color-error: oklch(0.68 0.18 30);

    /* Shadows — profondes sur fond sombre */
    --cv-ui-shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, 0.4);
    --cv-ui-shadow-md: 0 4px 6px -1px rgba(0, 0, 0, 0.4), 0 2px 4px -1px rgba(0, 0, 0, 0.3);
    --cv-ui-shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, 0.4), 0 4px 6px -2px rgba(0, 0, 0, 0.3);
    --cv-ui-shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, 0.5), 0 10px 10px -5px rgba(0, 0, 0, 0.3);

    /* Border radius */
    --cv-ui-radius-sm: 6px;
    --cv-ui-radius-md: 10px;
    --cv-ui-radius-lg: 14px;
    --cv-ui-radius-xl: 20px;
}
/**
 * Flat theme — overrides --cv-ui-* tokens for [data-theme="flat"].
 *
 * Principe : zéro ombre, zéro radius, bordures nettes, couleurs franches.
 * Inspiré du style Fluent/Material-flat/Nord.
 * Palette : cyan-sky vif (#0ea5e9) sur blanc pur.
 *
 * Applied when data-theme="flat".
 */

/* ============================================================
   FLAT LIGHT
   ============================================================ */
[data-theme='flat']:not([data-mode='dark']),
.cv-theme-flat {
    /* Primary — cyan-sky vif */
    --cv-ui-color-primary: #0ea5e9;
    --cv-ui-color-primary-hover: #0284c7;
    --cv-ui-color-primary-light: #e0f2fe;
    --cv-ui-color-primary-dark: #0369a1;

    /* Secondary — gris neutre */
    --cv-ui-color-secondary: #64748b;
    --cv-ui-color-secondary-hover: #475569;
    --cv-ui-color-secondary-light: #f1f5f9;
    --cv-ui-color-secondary-dark: #334155;

    /* Success */
    --cv-ui-color-success: #16a34a;
    --cv-ui-color-success-hover: #15803d;
    --cv-ui-color-success-light: #dcfce7;
    --cv-ui-color-success-dark: #166534;

    /* Warning */
    --cv-ui-color-warning: #d97706;
    --cv-ui-color-warning-hover: #b45309;
    --cv-ui-color-warning-light: #fef3c7;
    --cv-ui-color-warning-dark: #92400e;

    /* Danger */
    --cv-ui-color-danger: #dc2626;
    --cv-ui-color-danger-hover: #b91c1c;
    --cv-ui-color-danger-light: #fee2e2;
    --cv-ui-color-danger-dark: #991b1b;

    /* Info */
    --cv-ui-color-info: #0ea5e9;
    --cv-ui-color-info-hover: #0284c7;
    --cv-ui-color-info-light: #e0f2fe;
    --cv-ui-color-info-dark: #0369a1;

    /* Backgrounds — blanc pur, pas de teintes */
    --cv-ui-bg-primary: #ffffff;
    --cv-ui-bg-secondary: #f8fafc;
    --cv-ui-bg-tertiary: #f1f5f9;
    --cv-ui-bg-hover: #f1f5f9;
    --cv-ui-bg-active: #e2e8f0;

    /* Text — contraste maximal */
    --cv-ui-text-primary: #0f172a;
    --cv-ui-text-secondary: #475569;
    --cv-ui-text-tertiary: #94a3b8;
    --cv-ui-text-disabled: #cbd5e1;
    --cv-ui-text-inverse: #ffffff;

    /* Borders — nettes, sans adoucissement */
    --cv-ui-border-color: #cbd5e1;
    --cv-ui-border-color-hover: #94a3b8;
    --cv-ui-border-color-focus: #0ea5e9;
    --cv-ui-border-color-error: #dc2626;

    /* Radius — tout à zéro, look "flat" */
    --cv-ui-radius-sm: 0px;
    --cv-ui-radius-md: 0px;
    --cv-ui-radius-lg: 0px;
    --cv-ui-radius-xl: 0px;
    --cv-ui-radius-full: 0px;

    /* Shadows — toutes supprimées */
    --cv-ui-shadow-sm: none;
    --cv-ui-shadow-md: none;
    --cv-ui-shadow-lg: none;
    --cv-ui-shadow-xl: none;

    /* Focus rings — outline 2px plein au lieu d'un halo diffus */
    --cv-ui-shadow-focus: 0 0 0 2px #0ea5e9;
    --cv-ui-shadow-focus-error: 0 0 0 2px #dc2626;
    --cv-ui-shadow-focus-success: 0 0 0 2px #16a34a;
}

/* ============================================================
   FLAT DARK
   ============================================================ */
[data-theme='flat'][data-mode='dark'] {
    /* Primary */
    --cv-ui-color-primary: #38bdf8;
    --cv-ui-color-primary-hover: #7dd3fc;
    --cv-ui-color-primary-light: #0c4a6e;
    --cv-ui-color-primary-dark: #bae6fd;

    /* Secondary */
    --cv-ui-color-secondary: #94a3b8;
    --cv-ui-color-secondary-hover: #cbd5e1;
    --cv-ui-color-secondary-light: #334155;
    --cv-ui-color-secondary-dark: #e2e8f0;

    /* Success */
    --cv-ui-color-success: #4ade80;
    --cv-ui-color-success-hover: #86efac;
    --cv-ui-color-success-light: #14532d;
    --cv-ui-color-success-dark: #bbf7d0;

    /* Warning */
    --cv-ui-color-warning: #fbbf24;
    --cv-ui-color-warning-hover: #fcd34d;
    --cv-ui-color-warning-light: #451a03;
    --cv-ui-color-warning-dark: #fde68a;

    /* Danger */
    --cv-ui-color-danger: #f87171;
    --cv-ui-color-danger-hover: #fca5a5;
    --cv-ui-color-danger-light: #450a0a;
    --cv-ui-color-danger-dark: #fecaca;

    /* Info */
    --cv-ui-color-info: #38bdf8;
    --cv-ui-color-info-hover: #7dd3fc;
    --cv-ui-color-info-light: #0c4a6e;
    --cv-ui-color-info-dark: #bae6fd;

    /* Backgrounds — noir profond, sans nuance */
    --cv-ui-bg-primary: #0f172a;
    --cv-ui-bg-secondary: #1e293b;
    --cv-ui-bg-tertiary: #334155;
    --cv-ui-bg-hover: #1e293b;
    --cv-ui-bg-active: #334155;

    /* Text */
    --cv-ui-text-primary: #f8fafc;
    --cv-ui-text-secondary: #cbd5e1;
    --cv-ui-text-tertiary: #64748b;
    --cv-ui-text-disabled: #475569;
    --cv-ui-text-inverse: #0f172a;

    /* Borders */
    --cv-ui-border-color: #334155;
    --cv-ui-border-color-hover: #475569;
    --cv-ui-border-color-focus: #38bdf8;
    --cv-ui-border-color-error: #f87171;

    /* Radius — tout à zéro */
    --cv-ui-radius-sm: 0px;
    --cv-ui-radius-md: 0px;
    --cv-ui-radius-lg: 0px;
    --cv-ui-radius-xl: 0px;
    --cv-ui-radius-full: 0px;

    /* Shadows — supprimées */
    --cv-ui-shadow-sm: none;
    --cv-ui-shadow-md: none;
    --cv-ui-shadow-lg: none;
    --cv-ui-shadow-xl: none;

    /* Focus rings — outline 2px plein */
    --cv-ui-shadow-focus: 0 0 0 2px #38bdf8;
    --cv-ui-shadow-focus-error: 0 0 0 2px #f87171;
    --cv-ui-shadow-focus-success: 0 0 0 2px #4ade80;
}
*, ::before, ::after {--_histoire-color-primary-50: 236 253 245;--_histoire-color-primary-100: 209 250 229;--_histoire-color-primary-200: 167 243 208;--_histoire-color-primary-300: 110 231 183;--_histoire-color-primary-400: 52 211 153;--_histoire-color-primary-500: 16 185 129;--_histoire-color-primary-600: 5 150 105;--_histoire-color-primary-700: 4 120 87;--_histoire-color-primary-800: 6 95 70;--_histoire-color-primary-900: 6 78 59;--_histoire-color-gray-50: 250 250 250;--_histoire-color-gray-100: 244 244 245;--_histoire-color-gray-200: 228 228 231;--_histoire-color-gray-300: 212 212 216;--_histoire-color-gray-400: 161 161 170;--_histoire-color-gray-500: 113 113 122;--_histoire-color-gray-600: 82 82 91;--_histoire-color-gray-700: 63 63 70;--_histoire-color-gray-750: 50 50 56;--_histoire-color-gray-800: 39 39 42;--_histoire-color-gray-850: 31 31 33;--_histoire-color-gray-900: 24 24 27;--_histoire-color-gray-950: 16 16 18;}

@scope (:root) to (.__histoire-render-story:not(.__histoire-render-custom-controls)){

.resize-observer[data-v-b329ee4c]{
  position:absolute;
  top:0;
  left:0;
  z-index:-1;
  width:100%;
  height:100%;
  border:none;
  background-color:transparent;
  pointer-events:none;
  display:block;
  overflow:hidden;
  opacity:0
}

.resize-observer[data-v-b329ee4c] object{
  display:block;
  position:absolute;
  top:0;
  left:0;
  height:100%;
  width:100%;
  overflow:hidden;
  pointer-events:none;
  z-index:-1
}

.v-popper__popper{
  z-index:10000;
  top:0;
  left:0;
  outline:none
}

.v-popper__popper.v-popper__popper--hidden{
  visibility:hidden;
  opacity:0;
  transition:opacity .15s,visibility .15s;
  pointer-events:none
}

.v-popper__popper.v-popper__popper--shown{
  visibility:visible;
  opacity:1;
  transition:opacity .15s
}

.v-popper__popper.v-popper__popper--skip-transition,.v-popper__popper.v-popper__popper--skip-transition>.v-popper__wrapper{
  transition:none!important
}

.v-popper__backdrop{
  position:absolute;
  top:0;
  left:0;
  width:100%;
  height:100%;
  display:none
}

.v-popper__inner{
  position:relative;
  box-sizing:border-box;
  overflow-y:auto
}

.v-popper__inner>div{
  position:relative;
  z-index:1;
  max-width:inherit;
  max-height:inherit
}

.v-popper__arrow-container{
  position:absolute;
  width:10px;
  height:10px
}

.v-popper__popper--arrow-overflow .v-popper__arrow-container,.v-popper__popper--no-positioning .v-popper__arrow-container{
  display:none
}

.v-popper__arrow-inner,.v-popper__arrow-outer{
  border-style:solid;
  position:absolute;
  top:0;
  left:0;
  width:0;
  height:0
}

.v-popper__arrow-inner{
  visibility:hidden;
  border-width:7px
}

.v-popper__arrow-outer{
  border-width:6px
}

.v-popper__popper[data-popper-placement^=top] .v-popper__arrow-inner,.v-popper__popper[data-popper-placement^=bottom] .v-popper__arrow-inner{
  left:-2px
}

.v-popper__popper[data-popper-placement^=top] .v-popper__arrow-outer,.v-popper__popper[data-popper-placement^=bottom] .v-popper__arrow-outer{
  left:-1px
}

.v-popper__popper[data-popper-placement^=top] .v-popper__arrow-inner,.v-popper__popper[data-popper-placement^=top] .v-popper__arrow-outer{
  border-bottom-width:0;
  border-left-color:transparent!important;
  border-right-color:transparent!important;
  border-bottom-color:transparent!important
}

.v-popper__popper[data-popper-placement^=top] .v-popper__arrow-inner{
  top:-2px
}

.v-popper__popper[data-popper-placement^=bottom] .v-popper__arrow-container{
  top:0
}

.v-popper__popper[data-popper-placement^=bottom] .v-popper__arrow-inner,.v-popper__popper[data-popper-placement^=bottom] .v-popper__arrow-outer{
  border-top-width:0;
  border-left-color:transparent!important;
  border-right-color:transparent!important;
  border-top-color:transparent!important
}

.v-popper__popper[data-popper-placement^=bottom] .v-popper__arrow-inner{
  top:-4px
}

.v-popper__popper[data-popper-placement^=bottom] .v-popper__arrow-outer{
  top:-6px
}

.v-popper__popper[data-popper-placement^=left] .v-popper__arrow-inner,.v-popper__popper[data-popper-placement^=right] .v-popper__arrow-inner{
  top:-2px
}

.v-popper__popper[data-popper-placement^=left] .v-popper__arrow-outer,.v-popper__popper[data-popper-placement^=right] .v-popper__arrow-outer{
  top:-1px
}

.v-popper__popper[data-popper-placement^=right] .v-popper__arrow-inner,.v-popper__popper[data-popper-placement^=right] .v-popper__arrow-outer{
  border-left-width:0;
  border-left-color:transparent!important;
  border-top-color:transparent!important;
  border-bottom-color:transparent!important
}

.v-popper__popper[data-popper-placement^=right] .v-popper__arrow-inner{
  left:-4px
}

.v-popper__popper[data-popper-placement^=right] .v-popper__arrow-outer{
  left:-6px
}

.v-popper__popper[data-popper-placement^=left] .v-popper__arrow-container{
  right:-10px
}

.v-popper__popper[data-popper-placement^=left] .v-popper__arrow-inner,.v-popper__popper[data-popper-placement^=left] .v-popper__arrow-outer{
  border-right-width:0;
  border-top-color:transparent!important;
  border-right-color:transparent!important;
  border-bottom-color:transparent!important
}

.v-popper__popper[data-popper-placement^=left] .v-popper__arrow-inner{
  left:-2px
}

.v-popper--theme-tooltip .v-popper__inner{
  background:rgba(0,0,0,.8);
  color:#fff;
  border-radius:6px;
  padding:7px 12px 6px
}

.v-popper--theme-tooltip .v-popper__arrow-outer{
  border-color:#000c
}

.v-popper--theme-dropdown .v-popper__inner{
  background:#fff;
  color:#000;
  border-radius:6px;
  border:1px solid #ddd;
  box-shadow:0 6px 30px #0000001a
}

.v-popper--theme-dropdown .v-popper__arrow-inner{
  visibility:visible;
  border-color:#fff
}

.v-popper--theme-dropdown .v-popper__arrow-outer{
  border-color:#ddd
}

.htw-bind-col-size{
  grid-template-columns:repeat(auto-fill,minmax(var(--histoire-col-size),1fr))
}

.__histoire-json-code[data-v-d4369e5a] .cm-editor{
  height:100%;
  min-width:280px
}

.v-popper{
  line-height:0
}

.htw-dark .v-popper--theme-dropdown .v-popper__inner{
  --tw-border-opacity: 1;
  border-color:rgb(31 31 33 / var(--tw-border-opacity, 1));
  --tw-bg-opacity: 1;
  background-color:rgb(63 63 70 / var(--tw-bg-opacity, 1));
  --tw-text-opacity: 1;
  color:rgb(244 244 245 / var(--tw-text-opacity, 1))
}

.htw-dark .v-popper--theme-dropdown .v-popper__arrow-inner{
  --tw-border-opacity: 1;
  border-color:rgb(63 63 70 / var(--tw-border-opacity, 1))
}

.htw-dark .v-popper--theme-dropdown .v-popper__arrow-outer{
  --tw-border-opacity: 1;
  border-color:rgb(31 31 33 / var(--tw-border-opacity, 1))
}

.v-popper--theme-dropdown.v-popper__popper--show-from .v-popper__wrapper{
  transform:scale(.75)
}

.v-popper--theme-dropdown.v-popper__popper--show-to .v-popper__wrapper{
  transform:none;
  transition:transform .15s cubic-bezier(0,1,.5,1)
}

.v-popper__popper:focus-visible{
  outline:none
}

.htw-range-input::-webkit-slider-thumb{
  height:.75rem;
  width:.75rem;
  -webkit-appearance:none;
  appearance:none;
  border-radius:9999px;
  border-width:1px;
  border-style:solid;
  border-color:#00000040;
  --tw-bg-opacity: 1;
  background-color:rgb(255 255 255 / var(--tw-bg-opacity, 1))
}

.htw-range-input:is(.htw-dark *)::-webkit-slider-thumb{
  border-color:#ffffff40;
  --tw-bg-opacity: 1;
  background-color:rgb(63 63 70 / var(--tw-bg-opacity, 1))
}

.htw-range-input:hover::-webkit-slider-thumb{
  --tw-border-opacity: 1 !important;
  border-color:rgb(16 185 129 / var(--tw-border-opacity, 1))!important;
  --tw-bg-opacity: 1 !important;
  background-color:rgb(16 185 129 / var(--tw-bg-opacity, 1))!important
}

.htw-range-input::-moz-range-thumb{
  height:.75rem;
  width:.75rem;
  -moz-appearance:none;
  appearance:none;
  border-radius:9999px;
  border-width:1px;
  border-style:solid;
  border-color:#00000040;
  --tw-bg-opacity: 1;
  background-color:rgb(255 255 255 / var(--tw-bg-opacity, 1))
}

.htw-range-input:is(.htw-dark *)::-moz-range-thumb{
  border-color:#ffffff40;
  --tw-bg-opacity: 1;
  background-color:rgb(63 63 70 / var(--tw-bg-opacity, 1))
}

.htw-range-input:hover::-moz-range-thumb{
  --tw-border-opacity: 1 !important;
  border-color:rgb(16 185 129 / var(--tw-border-opacity, 1))!important;
  --tw-bg-opacity: 1 !important;
  background-color:rgb(16 185 129 / var(--tw-bg-opacity, 1))!important
}

/* @TODO custom themes */

.v-popper {
  line-height: 0;
}

.htw-dark .v-popper--theme-dropdown .v-popper__inner{
  --tw-border-opacity:1;
  border-color:rgb(var(--_histoire-color-gray-850) / var(--tw-border-opacity, 1));
  --tw-bg-opacity:1;
  background-color:rgb(var(--_histoire-color-gray-700) / var(--tw-bg-opacity, 1));
  --tw-text-opacity:1;
  color:rgb(var(--_histoire-color-gray-100) / var(--tw-text-opacity, 1))
}

.htw-dark .v-popper--theme-dropdown .v-popper__arrow-inner{
  --tw-border-opacity:1;
  border-color:rgb(var(--_histoire-color-gray-700) / var(--tw-border-opacity, 1))
}

.htw-dark .v-popper--theme-dropdown .v-popper__arrow-outer{
  --tw-border-opacity:1;
  border-color:rgb(var(--_histoire-color-gray-850) / var(--tw-border-opacity, 1))
}

.v-popper--theme-dropdown.v-popper__popper--show-from .v-popper__wrapper {
  transform: scale(.75);
}

.v-popper--theme-dropdown.v-popper__popper--show-to .v-popper__wrapper {
  transform: none;
  transition: transform .15s cubic-bezier(0, 1, .5, 1);
}

.v-popper__popper:focus-visible {
  outline: none;
}

.__histoire-scale-x-enter-active,
  .__histoire-scale-x-leave-active {
  transition: transform .15s, opacity .15s;
}

.__histoire-scale-x-enter-from,
  .__histoire-scale-x-leave-to {
  transform: scaleX(0);
  opacity: 0;
}

.__histoire-scale-y-enter-active,
  .__histoire-scale-y-leave-active {
  transition: transform .15s, opacity .15s;
}

.__histoire-scale-y-enter-from,
  .__histoire-scale-y-leave-to {
  transform: scaleY(0);
  opacity: 0;
}

.__histoire-fade-enter-active,
  .__histoire-fade-leave-active {
  transition: opacity .15s;
}

.__histoire-fade-enter-from,
  .__histoire-fade-leave-to {
  opacity: 0;
}

.__histoire-fade-bottom-enter-active,
  .__histoire-fade-bottom-leave-active {
  transition: transform .15s, opacity .15s;
  transform: translateY(0px);
}

.__histoire-fade-bottom-enter-from,
  .__histoire-fade-bottom-leave-to {
  transform: translateY(32px);
  opacity: 0;
}

*,
::before,
::after {
  box-sizing: border-box;
  border-width: 0;
  border-style: solid;
  border-color: #e5e7eb;
}

a,
input,
button {
  color: inherit;
}

a {
  text-decoration: inherit;
}

input, button {
  font-family: inherit;
}

a,
button {
  -webkit-user-select: none;
     -moz-user-select: none;
          user-select: none;
}

*, ::before, ::after{
  --tw-border-spacing-x:0;
  --tw-border-spacing-y:0;
  --tw-translate-x:0;
  --tw-translate-y:0;
  --tw-rotate:0;
  --tw-skew-x:0;
  --tw-skew-y:0;
  --tw-scale-x:1;
  --tw-scale-y:1;
  --tw-pan-x: ;
  --tw-pan-y: ;
  --tw-pinch-zoom: ;
  --tw-scroll-snap-strictness:proximity;
  --tw-gradient-from-position: ;
  --tw-gradient-via-position: ;
  --tw-gradient-to-position: ;
  --tw-ordinal: ;
  --tw-slashed-zero: ;
  --tw-numeric-figure: ;
  --tw-numeric-spacing: ;
  --tw-numeric-fraction: ;
  --tw-ring-inset: ;
  --tw-ring-offset-width:0px;
  --tw-ring-offset-color:#fff;
  --tw-ring-color:rgb(59 130 246 / 0.5);
  --tw-ring-offset-shadow:0 0 #0000;
  --tw-ring-shadow:0 0 #0000;
  --tw-shadow:0 0 #0000;
  --tw-shadow-colored:0 0 #0000;
  --tw-blur: ;
  --tw-brightness: ;
  --tw-contrast: ;
  --tw-grayscale: ;
  --tw-hue-rotate: ;
  --tw-invert: ;
  --tw-saturate: ;
  --tw-sepia: ;
  --tw-drop-shadow: ;
  --tw-backdrop-blur: ;
  --tw-backdrop-brightness: ;
  --tw-backdrop-contrast: ;
  --tw-backdrop-grayscale: ;
  --tw-backdrop-hue-rotate: ;
  --tw-backdrop-invert: ;
  --tw-backdrop-opacity: ;
  --tw-backdrop-saturate: ;
  --tw-backdrop-sepia: ;
  --tw-contain-size: ;
  --tw-contain-layout: ;
  --tw-contain-paint: ;
  --tw-contain-style: 
}

::backdrop{
  --tw-border-spacing-x:0;
  --tw-border-spacing-y:0;
  --tw-translate-x:0;
  --tw-translate-y:0;
  --tw-rotate:0;
  --tw-skew-x:0;
  --tw-skew-y:0;
  --tw-scale-x:1;
  --tw-scale-y:1;
  --tw-pan-x: ;
  --tw-pan-y: ;
  --tw-pinch-zoom: ;
  --tw-scroll-snap-strictness:proximity;
  --tw-gradient-from-position: ;
  --tw-gradient-via-position: ;
  --tw-gradient-to-position: ;
  --tw-ordinal: ;
  --tw-slashed-zero: ;
  --tw-numeric-figure: ;
  --tw-numeric-spacing: ;
  --tw-numeric-fraction: ;
  --tw-ring-inset: ;
  --tw-ring-offset-width:0px;
  --tw-ring-offset-color:#fff;
  --tw-ring-color:rgb(59 130 246 / 0.5);
  --tw-ring-offset-shadow:0 0 #0000;
  --tw-ring-shadow:0 0 #0000;
  --tw-shadow:0 0 #0000;
  --tw-shadow-colored:0 0 #0000;
  --tw-blur: ;
  --tw-brightness: ;
  --tw-contrast: ;
  --tw-grayscale: ;
  --tw-hue-rotate: ;
  --tw-invert: ;
  --tw-saturate: ;
  --tw-sepia: ;
  --tw-drop-shadow: ;
  --tw-backdrop-blur: ;
  --tw-backdrop-brightness: ;
  --tw-backdrop-contrast: ;
  --tw-backdrop-grayscale: ;
  --tw-backdrop-hue-rotate: ;
  --tw-backdrop-invert: ;
  --tw-backdrop-opacity: ;
  --tw-backdrop-saturate: ;
  --tw-backdrop-sepia: ;
  --tw-contain-size: ;
  --tw-contain-layout: ;
  --tw-contain-paint: ;
  --tw-contain-style: 
}

body,
  pre {
  margin: 0;
}

:scope,
  body,
  #app {
  height: 100%;
}

:scope {
  font-family: 'Noto Sans Display', system-ui, sans-serif;
  font-size: 1rem;
}

body {
  font-size: 1.125rem;
}

@media (min-width: 640px) {
  body {
    font-size: .875rem;
  }
}

.__histoire-render-story:not(.__histoire-render-custom-controls) {
  overflow: auto;
  min-height: 100%;
}

.__histoire-code .shiki {
  background: transparent !important;
}

.htw-prose h1:not(:hover) .header-anchor[aria-hidden="true"], .htw-prose h2:not(:hover) .header-anchor[aria-hidden="true"], .htw-prose h3:not(:hover) .header-anchor[aria-hidden="true"], .htw-prose h4:not(:hover) .header-anchor[aria-hidden="true"] {
  visibility: hidden;
}

.htw-prose hr {
  margin: 1rem 0;
}

.__histoire-pane-shadow-from-right {
  background-image: linear-gradient(to left, rgba(0, 0, 0, 0.02), rgba(0, 0, 0, 0));
  background-size: 24px;
  background-repeat: no-repeat;
  background-position: right;
}

.htw-dark .__histoire-pane-shadow-from-right {
  background-image: linear-gradient(to left, rgba(0, 0, 0, 0.1), rgba(0, 0, 0, 0));
}

.htw-prose{
  color:var(--tw-prose-body);
  max-width:65ch;
}

.htw-prose :where(p):not(:where([class~="htw-not-prose"],[class~="htw-not-prose"] *)){
  margin-top:1.25em;
  margin-bottom:1.25em
}

.htw-prose :where([class~="lead"]):not(:where([class~="htw-not-prose"],[class~="htw-not-prose"] *)){
  color:var(--tw-prose-lead);
  font-size:1.25em;
  line-height:1.6;
  margin-top:1.2em;
  margin-bottom:1.2em
}

.htw-prose :where(a):not(:where([class~="htw-not-prose"],[class~="htw-not-prose"] *)){
  color:rgb(var(--_histoire-color-primary-500));
  text-decoration:none;
  font-weight:500;
}

.htw-prose :where(a):not(:where([class~="htw-not-prose"],[class~="htw-not-prose"] *)):hover{
  text-decoration:underline
}

.htw-prose :where(strong):not(:where([class~="htw-not-prose"],[class~="htw-not-prose"] *)){
  color:var(--tw-prose-bold);
  font-weight:600
}

.htw-prose :where(a strong):not(:where([class~="htw-not-prose"],[class~="htw-not-prose"] *)){
  color:inherit
}

.htw-prose :where(blockquote strong):not(:where([class~="htw-not-prose"],[class~="htw-not-prose"] *)){
  color:inherit
}

.htw-prose :where(thead th strong):not(:where([class~="htw-not-prose"],[class~="htw-not-prose"] *)){
  color:inherit
}

.htw-prose :where(ol):not(:where([class~="htw-not-prose"],[class~="htw-not-prose"] *)){
  list-style-type:decimal;
  margin-top:1.25em;
  margin-bottom:1.25em;
  padding-inline-start:1.625em
}

.htw-prose :where(ol[type="A"]):not(:where([class~="htw-not-prose"],[class~="htw-not-prose"] *)){
  list-style-type:upper-alpha
}

.htw-prose :where(ol[type="a"]):not(:where([class~="htw-not-prose"],[class~="htw-not-prose"] *)){
  list-style-type:lower-alpha
}

.htw-prose :where(ol[type="A" s]):not(:where([class~="htw-not-prose"],[class~="htw-not-prose"] *)){
  list-style-type:upper-alpha
}

.htw-prose :where(ol[type="a" s]):not(:where([class~="htw-not-prose"],[class~="htw-not-prose"] *)){
  list-style-type:lower-alpha
}

.htw-prose :where(ol[type="I"]):not(:where([class~="htw-not-prose"],[class~="htw-not-prose"] *)){
  list-style-type:upper-roman
}

.htw-prose :where(ol[type="i"]):not(:where([class~="htw-not-prose"],[class~="htw-not-prose"] *)){
  list-style-type:lower-roman
}

.htw-prose :where(ol[type="I" s]):not(:where([class~="htw-not-prose"],[class~="htw-not-prose"] *)){
  list-style-type:upper-roman
}

.htw-prose :where(ol[type="i" s]):not(:where([class~="htw-not-prose"],[class~="htw-not-prose"] *)){
  list-style-type:lower-roman
}

.htw-prose :where(ol[type="1"]):not(:where([class~="htw-not-prose"],[class~="htw-not-prose"] *)){
  list-style-type:decimal
}

.htw-prose :where(ul):not(:where([class~="htw-not-prose"],[class~="htw-not-prose"] *)){
  list-style-type:disc;
  margin-top:1.25em;
  margin-bottom:1.25em;
  padding-inline-start:1.625em
}

.htw-prose :where(ol > li):not(:where([class~="htw-not-prose"],[class~="htw-not-prose"] *))::marker{
  font-weight:400;
  color:var(--tw-prose-counters)
}

.htw-prose :where(ul > li):not(:where([class~="htw-not-prose"],[class~="htw-not-prose"] *))::marker{
  color:var(--tw-prose-bullets)
}

.htw-prose :where(dt):not(:where([class~="htw-not-prose"],[class~="htw-not-prose"] *)){
  color:var(--tw-prose-headings);
  font-weight:600;
  margin-top:1.25em
}

.htw-prose :where(hr):not(:where([class~="htw-not-prose"],[class~="htw-not-prose"] *)){
  border-color:var(--tw-prose-hr);
  border-top-width:1px;
  margin-top:3em;
  margin-bottom:3em
}

.htw-prose :where(blockquote):not(:where([class~="htw-not-prose"],[class~="htw-not-prose"] *)){
  font-weight:500;
  font-style:italic;
  color:var(--tw-prose-quotes);
  border-inline-start-width:0.25rem;
  border-inline-start-color:var(--tw-prose-quote-borders);
  quotes:"\201C""\201D""\2018""\2019";
  margin-top:1.6em;
  margin-bottom:1.6em;
  padding-inline-start:1em;
  margin-left:0;
  margin-right:0;
  background-color:rgb(var(--_histoire-color-gray-100));
  padding:.25rem .375rem;
}

.htw-prose :where(blockquote):not(:where([class~="htw-not-prose"],[class~="htw-not-prose"] *)) p:first-child{
  margin-top:0
}

.htw-prose :where(blockquote):not(:where([class~="htw-not-prose"],[class~="htw-not-prose"] *)) p:last-child{
  margin-bottom:0
}

.htw-dark .htw-prose :where(blockquote):not(:where([class~="htw-not-prose"],[class~="htw-not-prose"] *)){
  background-color:rgb(var(--_histoire-color-gray-750))
}

.htw-prose :where(blockquote p:first-of-type):not(:where([class~="htw-not-prose"],[class~="htw-not-prose"] *))::before{
  content:open-quote
}

.htw-prose :where(blockquote p:last-of-type):not(:where([class~="htw-not-prose"],[class~="htw-not-prose"] *))::after{
  content:close-quote
}

.htw-prose :where(h1):not(:where([class~="htw-not-prose"],[class~="htw-not-prose"] *)){
  color:var(--tw-prose-headings);
  font-weight:800;
  font-size:2.25em;
  margin-top:0;
  margin-bottom:0.8888889em;
  line-height:1.1111111
}

.htw-prose :where(h1 strong):not(:where([class~="htw-not-prose"],[class~="htw-not-prose"] *)){
  font-weight:900;
  color:inherit
}

.htw-prose :where(h2):not(:where([class~="htw-not-prose"],[class~="htw-not-prose"] *)){
  color:var(--tw-prose-headings);
  font-weight:700;
  font-size:1.5em;
  margin-top:2em;
  margin-bottom:1em;
  line-height:1.3333333
}

.htw-prose :where(h2 strong):not(:where([class~="htw-not-prose"],[class~="htw-not-prose"] *)){
  font-weight:800;
  color:inherit
}

.htw-prose :where(h3):not(:where([class~="htw-not-prose"],[class~="htw-not-prose"] *)){
  color:var(--tw-prose-headings);
  font-weight:600;
  font-size:1.25em;
  margin-top:1.6em;
  margin-bottom:0.6em;
  line-height:1.6
}

.htw-prose :where(h3 strong):not(:where([class~="htw-not-prose"],[class~="htw-not-prose"] *)){
  font-weight:700;
  color:inherit
}

.htw-prose :where(h4):not(:where([class~="htw-not-prose"],[class~="htw-not-prose"] *)){
  color:var(--tw-prose-headings);
  font-weight:600;
  margin-top:1.5em;
  margin-bottom:0.5em;
  line-height:1.5
}

.htw-prose :where(h4 strong):not(:where([class~="htw-not-prose"],[class~="htw-not-prose"] *)){
  font-weight:700;
  color:inherit
}

.htw-prose :where(img):not(:where([class~="htw-not-prose"],[class~="htw-not-prose"] *)){
  margin-top:2em;
  margin-bottom:2em
}

.htw-prose :where(picture):not(:where([class~="htw-not-prose"],[class~="htw-not-prose"] *)){
  display:block;
  margin-top:2em;
  margin-bottom:2em
}

.htw-prose :where(video):not(:where([class~="htw-not-prose"],[class~="htw-not-prose"] *)){
  margin-top:2em;
  margin-bottom:2em
}

.htw-prose :where(kbd):not(:where([class~="htw-not-prose"],[class~="htw-not-prose"] *)){
  font-weight:500;
  font-family:inherit;
  color:var(--tw-prose-kbd);
  box-shadow:0 0 0 1px rgb(var(--tw-prose-kbd-shadows) / 10%), 0 3px 0 rgb(var(--tw-prose-kbd-shadows) / 10%);
  font-size:0.875em;
  border-radius:0.3125rem;
  padding-top:0.1875em;
  padding-inline-end:0.375em;
  padding-bottom:0.1875em;
  padding-inline-start:0.375em
}

.htw-prose :where(code):not(:where([class~="htw-not-prose"],[class~="htw-not-prose"] *)){
  color:var(--tw-prose-code);
  font-weight:normal;
  font-size:0.8rem;
  background-color:rgb(var(--_histoire-color-gray-500) / 20%);
  padding:0.05rem 0.5rem;
  border-radius:0.25rem;
}

.htw-prose :where(code):not(:where([class~="htw-not-prose"],[class~="htw-not-prose"] *))::before,.htw-prose :where(code):not(:where([class~="htw-not-prose"],[class~="htw-not-prose"] *))::after{
  display:none
}

.htw-prose :where(code):not(:where([class~="htw-not-prose"],[class~="htw-not-prose"] *))::before{
  content:"`"
}

.htw-prose :where(code):not(:where([class~="htw-not-prose"],[class~="htw-not-prose"] *))::after{
  content:"`"
}

.htw-prose :where(a code):not(:where([class~="htw-not-prose"],[class~="htw-not-prose"] *)){
  color:inherit
}

.htw-prose :where(h1 code):not(:where([class~="htw-not-prose"],[class~="htw-not-prose"] *)){
  color:inherit
}

.htw-prose :where(h2 code):not(:where([class~="htw-not-prose"],[class~="htw-not-prose"] *)){
  color:inherit;
  font-size:0.875em
}

.htw-prose :where(h3 code):not(:where([class~="htw-not-prose"],[class~="htw-not-prose"] *)){
  color:inherit;
  font-size:0.9em
}

.htw-prose :where(h4 code):not(:where([class~="htw-not-prose"],[class~="htw-not-prose"] *)){
  color:inherit
}

.htw-prose :where(blockquote code):not(:where([class~="htw-not-prose"],[class~="htw-not-prose"] *)){
  color:inherit
}

.htw-prose :where(thead th code):not(:where([class~="htw-not-prose"],[class~="htw-not-prose"] *)){
  color:inherit
}

.htw-prose :where(pre):not(:where([class~="htw-not-prose"],[class~="htw-not-prose"] *)){
  color:var(--tw-prose-pre-code);
  background-color:var(--tw-prose-pre-bg);
  overflow-x:auto;
  font-weight:400;
  font-size:0.875em;
  line-height:1.7142857;
  margin-top:1.7142857em;
  margin-bottom:1.7142857em;
  border-radius:0.375rem;
  padding-top:0.8571429em;
  padding-inline-end:1.1428571em;
  padding-bottom:0.8571429em;
  padding-inline-start:1.1428571em
}

.htw-prose :where(pre code):not(:where([class~="htw-not-prose"],[class~="htw-not-prose"] *)){
  background-color:transparent;
  border-width:0;
  border-radius:0;
  padding:0;
  font-weight:inherit;
  color:inherit;
  font-size:inherit;
  font-family:inherit;
  line-height:inherit
}

.htw-prose :where(pre code):not(:where([class~="htw-not-prose"],[class~="htw-not-prose"] *))::before{
  content:none
}

.htw-prose :where(pre code):not(:where([class~="htw-not-prose"],[class~="htw-not-prose"] *))::after{
  content:none
}

.htw-prose :where(table):not(:where([class~="htw-not-prose"],[class~="htw-not-prose"] *)){
  width:100%;
  table-layout:auto;
  margin-top:2em;
  margin-bottom:2em;
  font-size:0.875em;
  line-height:1.7142857
}

.htw-prose :where(thead):not(:where([class~="htw-not-prose"],[class~="htw-not-prose"] *)){
  border-bottom-width:1px;
  border-bottom-color:var(--tw-prose-th-borders)
}

.htw-prose :where(thead th):not(:where([class~="htw-not-prose"],[class~="htw-not-prose"] *)){
  color:var(--tw-prose-headings);
  font-weight:600;
  vertical-align:bottom;
  padding-inline-end:0.5714286em;
  padding-bottom:0.5714286em;
  padding-inline-start:0.5714286em
}

.htw-prose :where(tbody tr):not(:where([class~="htw-not-prose"],[class~="htw-not-prose"] *)){
  border-bottom-width:1px;
  border-bottom-color:var(--tw-prose-td-borders)
}

.htw-prose :where(tbody tr:last-child):not(:where([class~="htw-not-prose"],[class~="htw-not-prose"] *)){
  border-bottom-width:0
}

.htw-prose :where(tbody td):not(:where([class~="htw-not-prose"],[class~="htw-not-prose"] *)){
  vertical-align:baseline
}

.htw-prose :where(tfoot):not(:where([class~="htw-not-prose"],[class~="htw-not-prose"] *)){
  border-top-width:1px;
  border-top-color:var(--tw-prose-th-borders)
}

.htw-prose :where(tfoot td):not(:where([class~="htw-not-prose"],[class~="htw-not-prose"] *)){
  vertical-align:top
}

.htw-prose :where(th, td):not(:where([class~="htw-not-prose"],[class~="htw-not-prose"] *)){
  text-align:start
}

.htw-prose :where(figure > *):not(:where([class~="htw-not-prose"],[class~="htw-not-prose"] *)){
  margin-top:0;
  margin-bottom:0
}

.htw-prose :where(figcaption):not(:where([class~="htw-not-prose"],[class~="htw-not-prose"] *)){
  color:var(--tw-prose-captions);
  font-size:0.875em;
  line-height:1.4285714;
  margin-top:0.8571429em
}

.htw-prose{
  --tw-prose-body:#374151;
  --tw-prose-headings:#111827;
  --tw-prose-lead:#4b5563;
  --tw-prose-links:#111827;
  --tw-prose-bold:#111827;
  --tw-prose-counters:#6b7280;
  --tw-prose-bullets:#d1d5db;
  --tw-prose-hr:#e5e7eb;
  --tw-prose-quotes:#111827;
  --tw-prose-quote-borders:#e5e7eb;
  --tw-prose-captions:#6b7280;
  --tw-prose-kbd:#111827;
  --tw-prose-kbd-shadows:17 24 39;
  --tw-prose-code:#111827;
  --tw-prose-pre-code:#e5e7eb;
  --tw-prose-pre-bg:#1f2937;
  --tw-prose-th-borders:#d1d5db;
  --tw-prose-td-borders:#e5e7eb;
  --tw-prose-invert-body:#d1d5db;
  --tw-prose-invert-headings:#fff;
  --tw-prose-invert-lead:#9ca3af;
  --tw-prose-invert-links:#fff;
  --tw-prose-invert-bold:#fff;
  --tw-prose-invert-counters:#9ca3af;
  --tw-prose-invert-bullets:rgb(var(--_histoire-color-gray-500));
  --tw-prose-invert-hr:rgb(var(--_histoire-color-gray-800));
  --tw-prose-invert-quotes:#f3f4f6;
  --tw-prose-invert-quote-borders:rgb(var(--_histoire-color-gray-800));
  --tw-prose-invert-captions:#9ca3af;
  --tw-prose-invert-kbd:#fff;
  --tw-prose-invert-kbd-shadows:255 255 255;
  --tw-prose-invert-code:#fff;
  --tw-prose-invert-pre-code:#d1d5db;
  --tw-prose-invert-pre-bg:rgb(0 0 0 / 50%);
  --tw-prose-invert-th-borders:#4b5563;
  --tw-prose-invert-td-borders:#374151;
  font-size:1rem;
  line-height:1.75
}

.htw-prose :where(picture > img):not(:where([class~="htw-not-prose"],[class~="htw-not-prose"] *)){
  margin-top:0;
  margin-bottom:0
}

.htw-prose :where(li):not(:where([class~="htw-not-prose"],[class~="htw-not-prose"] *)){
  margin-top:0.1rem;
  margin-bottom:0.1rem
}

.htw-prose :where(ol > li):not(:where([class~="htw-not-prose"],[class~="htw-not-prose"] *)){
  padding-inline-start:0.375em
}

.htw-prose :where(ul > li):not(:where([class~="htw-not-prose"],[class~="htw-not-prose"] *)){
  padding-inline-start:0.375em
}

.htw-prose :where(.htw-prose > ul > li p):not(:where([class~="htw-not-prose"],[class~="htw-not-prose"] *)){
  margin-top:0.75em;
  margin-bottom:0.75em
}

.htw-prose :where(.htw-prose > ul > li > p:first-child):not(:where([class~="htw-not-prose"],[class~="htw-not-prose"] *)){
  margin-top:1.25em
}

.htw-prose :where(.htw-prose > ul > li > p:last-child):not(:where([class~="htw-not-prose"],[class~="htw-not-prose"] *)){
  margin-bottom:1.25em
}

.htw-prose :where(.htw-prose > ol > li > p:first-child):not(:where([class~="htw-not-prose"],[class~="htw-not-prose"] *)){
  margin-top:1.25em
}

.htw-prose :where(.htw-prose > ol > li > p:last-child):not(:where([class~="htw-not-prose"],[class~="htw-not-prose"] *)){
  margin-bottom:1.25em
}

.htw-prose :where(ul ul, ul ol, ol ul, ol ol):not(:where([class~="htw-not-prose"],[class~="htw-not-prose"] *)){
  margin-top:0.75em;
  margin-bottom:0.75em
}

.htw-prose :where(dl):not(:where([class~="htw-not-prose"],[class~="htw-not-prose"] *)){
  margin-top:1.25em;
  margin-bottom:1.25em
}

.htw-prose :where(dd):not(:where([class~="htw-not-prose"],[class~="htw-not-prose"] *)){
  margin-top:0.5em;
  padding-inline-start:1.625em
}

.htw-prose :where(hr + *):not(:where([class~="htw-not-prose"],[class~="htw-not-prose"] *)){
  margin-top:0
}

.htw-prose :where(h2 + *):not(:where([class~="htw-not-prose"],[class~="htw-not-prose"] *)){
  margin-top:0
}

.htw-prose :where(h3 + *):not(:where([class~="htw-not-prose"],[class~="htw-not-prose"] *)){
  margin-top:0
}

.htw-prose :where(h4 + *):not(:where([class~="htw-not-prose"],[class~="htw-not-prose"] *)){
  margin-top:0
}

.htw-prose :where(thead th:first-child):not(:where([class~="htw-not-prose"],[class~="htw-not-prose"] *)){
  padding-inline-start:0
}

.htw-prose :where(thead th:last-child):not(:where([class~="htw-not-prose"],[class~="htw-not-prose"] *)){
  padding-inline-end:0
}

.htw-prose :where(tbody td, tfoot td):not(:where([class~="htw-not-prose"],[class~="htw-not-prose"] *)){
  padding-top:0.5714286em;
  padding-inline-end:0.5714286em;
  padding-bottom:0.5714286em;
  padding-inline-start:0.5714286em
}

.htw-prose :where(tbody td:first-child, tfoot td:first-child):not(:where([class~="htw-not-prose"],[class~="htw-not-prose"] *)){
  padding-inline-start:0
}

.htw-prose :where(tbody td:last-child, tfoot td:last-child):not(:where([class~="htw-not-prose"],[class~="htw-not-prose"] *)){
  padding-inline-end:0
}

.htw-prose :where(figure):not(:where([class~="htw-not-prose"],[class~="htw-not-prose"] *)){
  margin-top:2em;
  margin-bottom:2em
}

.htw-prose :where(.htw-prose > :first-child):not(:where([class~="htw-not-prose"],[class~="htw-not-prose"] *)){
  margin-top:0
}

.htw-prose :where(.htw-prose > :last-child):not(:where([class~="htw-not-prose"],[class~="htw-not-prose"] *)){
  margin-bottom:0
}

.htw-prose :where(h1, h2, h3, h4, th):not(:where([class~="htw-not-prose"],[class~="htw-not-prose"] *)){
  margin-bottom:0.75rem;
}

.htw-prose :where(h1, h2, h3, h4, th):not(:where([class~="htw-not-prose"],[class~="htw-not-prose"] *)):not(:first-child){
  margin-top:1.25rem
}

.htw-pointer-events-none{
  pointer-events:none
}

.htw-invisible{
  visibility:hidden
}

.htw-fixed{
  position:fixed
}

.htw-absolute{
  position:absolute
}

.htw-relative{
  position:relative
}

.htw-inset-0{
  inset:0px
}

.htw-bottom-0{
  bottom:0px
}

.htw-bottom-4{
  bottom:1rem
}

.htw-bottom-5{
  bottom:1.25rem
}

.htw-bottom-8{
  bottom:2rem
}

.htw-left-0{
  left:0px
}

.htw-left-5{
  left:1.25rem
}

.htw-left-8{
  left:2rem
}

.htw-right-0{
  right:0px
}

.htw-right-4{
  right:1rem
}

.htw-right-5{
  right:1.25rem
}

.htw-right-8{
  right:2rem
}

.htw-top-0{
  top:0px
}

.htw-top-5{
  top:1.25rem
}

.htw-top-8{
  top:2rem
}

.htw-isolate{
  isolation:isolate
}

.htw-z-10{
  z-index:10
}

.htw-z-20{
  z-index:20
}

.htw-m-0{
  margin:0px
}

.htw-m-1{
  margin:0.25rem
}

.htw-m-4{
  margin:1rem
}

.htw-m-auto{
  margin:auto
}

.-htw-my-1{
  margin-top:-0.25rem;
  margin-bottom:-0.25rem
}

.htw-mx-1{
  margin-left:0.25rem;
  margin-right:0.25rem
}

.htw-mx-2{
  margin-left:0.5rem;
  margin-right:0.5rem
}

.htw-mx-4{
  margin-left:1rem;
  margin-right:1rem
}

.htw-mx-6{
  margin-left:1.5rem;
  margin-right:1.5rem
}

.htw-my-0{
  margin-top:0px;
  margin-bottom:0px
}

.htw-my-2{
  margin-top:0.5rem;
  margin-bottom:0.5rem
}

.htw-my-4{
  margin-top:1rem;
  margin-bottom:1rem
}

.htw-my-8{
  margin-top:2rem;
  margin-bottom:2rem
}

.-htw-mt-1{
  margin-top:-0.25rem
}

.htw-mb-2{
  margin-bottom:0.5rem
}

.htw-mb-6{
  margin-bottom:1.5rem
}

.htw-mb-8{
  margin-bottom:2rem
}

.htw-ml-4{
  margin-left:1rem
}

.htw-ml-auto{
  margin-left:auto
}

.htw-mr-2{
  margin-right:0.5rem
}

.htw-mr-auto{
  margin-right:auto
}

.htw-mt-0\.5{
  margin-top:0.125rem
}

.htw-mt-1{
  margin-top:0.25rem
}

.htw-mt-2{
  margin-top:0.5rem
}

.htw-box-border{
  box-sizing:border-box
}

.htw-block{
  display:block
}

.htw-flex{
  display:flex
}

.htw-inline-flex{
  display:inline-flex
}

.htw-grid{
  display:grid
}

.\!htw-hidden{
  display:none !important
}

.htw-hidden{
  display:none
}

.htw-h-1{
  height:0.25rem
}

.htw-h-10{
  height:2.5rem
}

.htw-h-12{
  height:3rem
}

.htw-h-16{
  height:4rem
}

.htw-h-2{
  height:0.5rem
}

.htw-h-20{
  height:5rem
}

.htw-h-3{
  height:0.75rem
}

.htw-h-32{
  height:8rem
}

.htw-h-4{
  height:1rem
}

.htw-h-48{
  height:12rem
}

.htw-h-5{
  height:1.25rem
}

.htw-h-6{
  height:1.5rem
}

.htw-h-64{
  height:16rem
}

.htw-h-8{
  height:2rem
}

.htw-h-9{
  height:2.25rem
}

.htw-h-\[100px\]{
  height:100px
}

.htw-h-\[16px\]{
  height:16px
}

.htw-h-\[1px\]{
  height:1px
}

.htw-h-\[22px\]{
  height:22px
}

.htw-h-\[27px\]{
  height:27px
}

.htw-h-\[2px\]{
  height:2px
}

.htw-h-\[51px\]{
  height:51px
}

.htw-h-fit{
  height:-moz-fit-content;
  height:fit-content
}

.htw-h-full{
  height:100%
}

.htw-h-px{
  height:1px
}

.htw-h-screen{
  height:100vh
}

.htw-max-h-\[400px\]{
  max-height:400px
}

.htw-max-h-\[80vh\]{
  max-height:80vh
}

.htw-max-h-full{
  max-height:100%
}

.htw-min-h-32{
  min-height:8rem
}

.htw-min-h-\[26px\]{
  min-height:26px
}

.htw-w-0{
  width:0px
}

.htw-w-16{
  width:4rem
}

.htw-w-2{
  width:0.5rem
}

.htw-w-20{
  width:5rem
}

.htw-w-28{
  width:7rem
}

.htw-w-3{
  width:0.75rem
}

.htw-w-32{
  width:8rem
}

.htw-w-4{
  width:1rem
}

.htw-w-5{
  width:1.25rem
}

.htw-w-6{
  width:1.5rem
}

.htw-w-64{
  width:16rem
}

.htw-w-8{
  width:2rem
}

.htw-w-\[16px\]{
  width:16px
}

.htw-w-\[2px\]{
  width:2px
}

.htw-w-fit{
  width:-moz-fit-content;
  width:fit-content
}

.htw-w-full{
  width:100%
}

.htw-w-max{
  width:-moz-max-content;
  width:max-content
}

.htw-w-px{
  width:1px
}

.htw-w-screen{
  width:100vw
}

.htw-min-w-0{
  min-width:0px
}

.htw-min-w-16{
  min-width:4rem
}

.htw-min-w-4{
  min-width:1rem
}

.htw-min-w-\[150px\]{
  min-width:150px
}

.htw-min-w-\[80px\]{
  min-width:80px
}

.htw-max-w-6{
  max-width:1.5rem
}

.htw-max-w-\[400px\]{
  max-width:400px
}

.htw-max-w-\[512px\]{
  max-width:512px
}

.htw-max-w-\[63px\]{
  max-width:63px
}

.htw-max-w-\[82px\]{
  max-width:82px
}

.htw-max-w-full{
  max-width:100%
}

.htw-max-w-none{
  max-width:none
}

.htw-flex-1{
  flex:1 1 0%
}

.htw-flex-none{
  flex:none
}

.htw-flex-shrink{
  flex-shrink:1
}

.htw-shrink{
  flex-shrink:1
}

.htw-shrink-0{
  flex-shrink:0
}

.htw-grow{
  flex-grow:1
}

.htw-rotate-90{
  --tw-rotate:90deg;
  transform:translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))
}

.htw-scale-0{
  --tw-scale-x:0;
  --tw-scale-y:0;
  transform:translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))
}

.htw-cursor-default{
  cursor:default
}

.htw-cursor-ew-resize{
  cursor:ew-resize
}

.htw-cursor-ns-resize{
  cursor:ns-resize
}

.htw-cursor-nwse-resize{
  cursor:nwse-resize
}

.htw-cursor-pointer{
  cursor:pointer
}

.htw-cursor-text{
  cursor:text
}

.htw-select-none{
  -webkit-user-select:none;
     -moz-user-select:none;
          user-select:none
}

.htw-resize-none{
  resize:none
}

.htw-resize-y{
  resize:vertical
}

.htw-appearance-none{
  -webkit-appearance:none;
     -moz-appearance:none;
          appearance:none
}

.htw-grid-cols-\[repeat\(auto-fill\,minmax\(200px\,1fr\)\)\]{
  grid-template-columns:repeat(auto-fill,minmax(200px,1fr))
}

.htw-flex-row{
  flex-direction:row
}

.htw-flex-col{
  flex-direction:column
}

.htw-flex-wrap{
  flex-wrap:wrap
}

.htw-flex-nowrap{
  flex-wrap:nowrap
}

.htw-place-content-between{
  place-content:space-between
}

.htw-items-start{
  align-items:flex-start
}

.htw-items-end{
  align-items:flex-end
}

.htw-items-center{
  align-items:center
}

.htw-items-baseline{
  align-items:baseline
}

.htw-items-stretch{
  align-items:stretch
}

.htw-justify-end{
  justify-content:flex-end
}

.htw-justify-center{
  justify-content:center
}

.htw-justify-evenly{
  justify-content:space-evenly
}

.htw-gap-0\.5{
  gap:0.125rem
}

.htw-gap-1{
  gap:0.25rem
}

.htw-gap-12{
  gap:3rem
}

.htw-gap-2{
  gap:0.5rem
}

.htw-gap-4{
  gap:1rem
}

.htw-gap-6{
  gap:1.5rem
}

.htw-gap-px{
  gap:1px
}

.htw-gap-x-2{
  -moz-column-gap:0.5rem;
       column-gap:0.5rem
}

.htw-gap-y-1{
  row-gap:0.25rem
}

.htw-space-y-4 > :not([hidden]) ~ :not([hidden]){
  --tw-space-y-reverse:0;
  margin-top:calc(1rem * calc(1 - var(--tw-space-y-reverse)));
  margin-bottom:calc(1rem * var(--tw-space-y-reverse))
}

.htw-divide-y > :not([hidden]) ~ :not([hidden]){
  --tw-divide-y-reverse:0;
  border-top-width:calc(1px * calc(1 - var(--tw-divide-y-reverse)));
  border-bottom-width:calc(1px * var(--tw-divide-y-reverse))
}

.htw-divide-gray-100 > :not([hidden]) ~ :not([hidden]){
  --tw-divide-opacity:1;
  border-color:rgb(var(--_histoire-color-gray-100) / var(--tw-divide-opacity, 1))
}

.htw-divide-gray-200 > :not([hidden]) ~ :not([hidden]){
  --tw-divide-opacity:1;
  border-color:rgb(var(--_histoire-color-gray-200) / var(--tw-divide-opacity, 1))
}

.htw-overflow-auto{
  overflow:auto
}

.htw-overflow-hidden{
  overflow:hidden
}

.htw-overflow-y-auto{
  overflow-y:auto
}

.htw-overflow-y-scroll{
  overflow-y:scroll
}

.htw-scroll-smooth{
  scroll-behavior:smooth
}

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

.htw-text-ellipsis{
  text-overflow:ellipsis
}

.htw-whitespace-nowrap{
  white-space:nowrap
}

.\!htw-rounded-\[3px\]{
  border-radius:3px !important
}

.htw-rounded{
  border-radius:0.375rem
}

.htw-rounded-full{
  border-radius:9999px
}

.htw-rounded-lg{
  border-radius:0.75rem
}

.htw-rounded-sm{
  border-radius:0.25rem
}

.htw-rounded-b-lg{
  border-bottom-right-radius:0.75rem;
  border-bottom-left-radius:0.75rem
}

.htw-rounded-l{
  border-top-left-radius:0.375rem;
  border-bottom-left-radius:0.375rem
}

.htw-rounded-r{
  border-top-right-radius:0.375rem;
  border-bottom-right-radius:0.375rem
}

.htw-rounded-r-lg{
  border-top-right-radius:0.75rem;
  border-bottom-right-radius:0.75rem
}

.htw-border{
  border-width:1px
}

.htw-border-0{
  border-width:0px
}

.htw-border-2{
  border-width:2px
}

.htw-border-8{
  border-width:8px
}

.htw-border-b{
  border-bottom-width:1px
}

.htw-border-l-2{
  border-left-width:2px
}

.htw-border-r{
  border-right-width:1px
}

.htw-border-t{
  border-top-width:1px
}

.htw-border-solid{
  border-style:solid
}

.htw-border-none{
  border-style:none
}

.htw-border-black\/20{
  border-color:rgb(0 0 0 / 0.2)
}

.htw-border-black\/25{
  border-color:rgb(0 0 0 / 0.25)
}

.htw-border-black\/50{
  border-color:rgb(0 0 0 / 0.5)
}

.htw-border-current{
  border-color:currentColor
}

.htw-border-gray-100{
  --tw-border-opacity:1;
  border-color:rgb(var(--_histoire-color-gray-100) / var(--tw-border-opacity, 1))
}

.htw-border-gray-200{
  --tw-border-opacity:1;
  border-color:rgb(var(--_histoire-color-gray-200) / var(--tw-border-opacity, 1))
}

.htw-border-gray-300\/30{
  border-color:rgb(var(--_histoire-color-gray-300) / 0.3)
}

.htw-border-gray-500\/10{
  border-color:rgb(var(--_histoire-color-gray-500) / 0.1)
}

.htw-border-gray-500\/30{
  border-color:rgb(var(--_histoire-color-gray-500) / 0.3)
}

.htw-border-gray-500\/40{
  border-color:rgb(var(--_histoire-color-gray-500) / 0.4)
}

.htw-border-gray-500\/5{
  border-color:rgb(var(--_histoire-color-gray-500) / 0.05)
}

.htw-border-gray-500\/50{
  border-color:rgb(var(--_histoire-color-gray-500) / 0.5)
}

.htw-border-gray-600{
  --tw-border-opacity:1;
  border-color:rgb(var(--_histoire-color-gray-600) / var(--tw-border-opacity, 1))
}

.htw-border-gray-800{
  --tw-border-opacity:1;
  border-color:rgb(var(--_histoire-color-gray-800) / var(--tw-border-opacity, 1))
}

.htw-border-gray-850{
  --tw-border-opacity:1;
  border-color:rgb(var(--_histoire-color-gray-850) / var(--tw-border-opacity, 1))
}

.htw-border-primary-200{
  --tw-border-opacity:1;
  border-color:rgb(var(--_histoire-color-primary-200) / var(--tw-border-opacity, 1))
}

.htw-border-primary-500{
  --tw-border-opacity:1;
  border-color:rgb(var(--_histoire-color-primary-500) / var(--tw-border-opacity, 1))
}

.htw-border-primary-900{
  --tw-border-opacity:1;
  border-color:rgb(var(--_histoire-color-primary-900) / var(--tw-border-opacity, 1))
}

.htw-border-transparent{
  border-color:transparent
}

.\!htw-bg-primary-500{
  --tw-bg-opacity:1 !important;
  background-color:rgb(var(--_histoire-color-primary-500) / var(--tw-bg-opacity, 1)) !important
}

.htw-bg-gray-100{
  --tw-bg-opacity:1;
  background-color:rgb(var(--_histoire-color-gray-100) / var(--tw-bg-opacity, 1))
}

.htw-bg-gray-200{
  --tw-bg-opacity:1;
  background-color:rgb(var(--_histoire-color-gray-200) / var(--tw-bg-opacity, 1))
}

.htw-bg-gray-400\/25{
  background-color:rgb(var(--_histoire-color-gray-400) / 0.25)
}

.htw-bg-gray-50{
  --tw-bg-opacity:1;
  background-color:rgb(var(--_histoire-color-gray-50) / var(--tw-bg-opacity, 1))
}

.htw-bg-gray-500\/10{
  background-color:rgb(var(--_histoire-color-gray-500) / 0.1)
}

.htw-bg-gray-500\/50{
  background-color:rgb(var(--_histoire-color-gray-500) / 0.5)
}

.htw-bg-gray-700{
  --tw-bg-opacity:1;
  background-color:rgb(var(--_histoire-color-gray-700) / var(--tw-bg-opacity, 1))
}

.htw-bg-gray-800{
  --tw-bg-opacity:1;
  background-color:rgb(var(--_histoire-color-gray-800) / var(--tw-bg-opacity, 1))
}

.htw-bg-primary-200{
  --tw-bg-opacity:1;
  background-color:rgb(var(--_histoire-color-primary-200) / var(--tw-bg-opacity, 1))
}

.htw-bg-primary-50{
  --tw-bg-opacity:1;
  background-color:rgb(var(--_histoire-color-primary-50) / var(--tw-bg-opacity, 1))
}

.htw-bg-primary-500{
  --tw-bg-opacity:1;
  background-color:rgb(var(--_histoire-color-primary-500) / var(--tw-bg-opacity, 1))
}

.htw-bg-primary-500\/10{
  background-color:rgb(var(--_histoire-color-primary-500) / 0.1)
}

.htw-bg-primary-500\/20{
  background-color:rgb(var(--_histoire-color-primary-500) / 0.2)
}

.htw-bg-primary-500\/25{
  background-color:rgb(var(--_histoire-color-primary-500) / 0.25)
}

.htw-bg-primary-700{
  --tw-bg-opacity:1;
  background-color:rgb(var(--_histoire-color-primary-700) / var(--tw-bg-opacity, 1))
}

.htw-bg-primary-800{
  --tw-bg-opacity:1;
  background-color:rgb(var(--_histoire-color-primary-800) / var(--tw-bg-opacity, 1))
}

.htw-bg-transparent{
  background-color:transparent
}

.htw-bg-white{
  --tw-bg-opacity:1;
  background-color:rgb(255 255 255 / var(--tw-bg-opacity, 1))
}

.htw-bg-white\/80{
  background-color:rgb(255 255 255 / 0.8)
}

.htw-fill-primary-500{
  fill:rgb(var(--_histoire-color-primary-500))
}

.htw-fill-transparent{
  fill:transparent
}

.htw-stroke-white{
  stroke:#fff
}

.htw-stroke-2{
  stroke-width:2
}

.htw-p-1{
  padding:0.25rem
}

.htw-p-2{
  padding:0.5rem
}

.htw-p-4{
  padding:1rem
}

.htw-p-8{
  padding:2rem
}

.htw-p-px{
  padding:1px
}

.htw-px-0\.5{
  padding-left:0.125rem;
  padding-right:0.125rem
}

.htw-px-1{
  padding-left:0.25rem;
  padding-right:0.25rem
}

.htw-px-2{
  padding-left:0.5rem;
  padding-right:0.5rem
}

.htw-px-4{
  padding-left:1rem;
  padding-right:1rem
}

.htw-px-6{
  padding-left:1.5rem;
  padding-right:1.5rem
}

.htw-py-0\.5{
  padding-top:0.125rem;
  padding-bottom:0.125rem
}

.htw-py-1{
  padding-top:0.25rem;
  padding-bottom:0.25rem
}

.htw-py-12{
  padding-top:3rem;
  padding-bottom:3rem
}

.htw-py-2{
  padding-top:0.5rem;
  padding-bottom:0.5rem
}

.htw-py-3{
  padding-top:0.75rem;
  padding-bottom:0.75rem
}

.htw-py-4{
  padding-top:1rem;
  padding-bottom:1rem
}

.htw-pl-0{
  padding-left:0px
}

.htw-pl-0\.5{
  padding-left:0.125rem
}

.htw-pl-2{
  padding-left:0.5rem
}

.htw-pl-4{
  padding-left:1rem
}

.htw-pl-6{
  padding-left:1.5rem
}

.htw-pr-2{
  padding-right:0.5rem
}

.htw-pr-6{
  padding-right:1.5rem
}

.htw-pt-4{
  padding-top:1rem
}

.htw-text-left{
  text-align:left
}

.htw-text-center{
  text-align:center
}

.htw-font-mono{
  font-family:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace
}

.htw-text-2xl{
  font-size:1.5rem;
  line-height:2rem
}

.htw-text-5xl{
  font-size:3rem;
  line-height:1
}

.htw-text-lg{
  font-size:1.125rem;
  line-height:1.75rem
}

.htw-text-sm{
  font-size:0.875rem;
  line-height:1.25rem
}

.htw-text-xs{
  font-size:0.75rem;
  line-height:1rem
}

.htw-font-bold{
  font-weight:700
}

.htw-uppercase{
  text-transform:uppercase
}

.htw-leading-none{
  line-height:1
}

.htw-leading-normal{
  line-height:1.5
}

.htw-text-black\/\[1\%\]{
  color:rgb(0 0 0 / 1%)
}

.htw-text-gray-400{
  --tw-text-opacity:1;
  color:rgb(var(--_histoire-color-gray-400) / var(--tw-text-opacity, 1))
}

.htw-text-gray-500{
  --tw-text-opacity:1;
  color:rgb(var(--_histoire-color-gray-500) / var(--tw-text-opacity, 1))
}

.htw-text-gray-500\/20{
  color:rgb(var(--_histoire-color-gray-500) / 0.2)
}

.htw-text-gray-700{
  --tw-text-opacity:1;
  color:rgb(var(--_histoire-color-gray-700) / var(--tw-text-opacity, 1))
}

.htw-text-gray-900{
  --tw-text-opacity:1;
  color:rgb(var(--_histoire-color-gray-900) / var(--tw-text-opacity, 1))
}

.htw-text-inherit{
  color:inherit
}

.htw-text-orange-500{
  --tw-text-opacity:1;
  color:rgb(249 115 22 / var(--tw-text-opacity, 1))
}

.htw-text-primary-200{
  --tw-text-opacity:1;
  color:rgb(var(--_histoire-color-primary-200) / var(--tw-text-opacity, 1))
}

.htw-text-primary-400{
  --tw-text-opacity:1;
  color:rgb(var(--_histoire-color-primary-400) / var(--tw-text-opacity, 1))
}

.htw-text-primary-500{
  --tw-text-opacity:1;
  color:rgb(var(--_histoire-color-primary-500) / var(--tw-text-opacity, 1))
}

.htw-text-primary-600{
  --tw-text-opacity:1;
  color:rgb(var(--_histoire-color-primary-600) / var(--tw-text-opacity, 1))
}

.htw-text-primary-800{
  --tw-text-opacity:1;
  color:rgb(var(--_histoire-color-primary-800) / var(--tw-text-opacity, 1))
}

.htw-text-red-500{
  --tw-text-opacity:1;
  color:rgb(239 68 68 / var(--tw-text-opacity, 1))
}

.htw-text-white{
  --tw-text-opacity:1;
  color:rgb(255 255 255 / var(--tw-text-opacity, 1))
}

.htw-opacity-0{
  opacity:0
}

.htw-opacity-20{
  opacity:0.2
}

.htw-opacity-25{
  opacity:0.25
}

.htw-opacity-30{
  opacity:0.3
}

.htw-opacity-40{
  opacity:0.4
}

.htw-opacity-50{
  opacity:0.5
}

.htw-opacity-60{
  opacity:0.6
}

.htw-opacity-70{
  opacity:0.7
}

.htw-shadow-xl{
  --tw-shadow:0 20px 25px -5px rgb(0 0 0 / 0.1), 0 8px 10px -6px rgb(0 0 0 / 0.1);
  --tw-shadow-colored:0 20px 25px -5px var(--tw-shadow-color), 0 8px 10px -6px var(--tw-shadow-color);
  box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow)
}

.htw-outline-none{
  outline:2px solid transparent;
  outline-offset:2px
}

.htw-transition-all{
  transition-property:all;
  transition-timing-function:cubic-bezier(0.4, 0, 0.2, 1);
  transition-duration:150ms
}

.htw-transition-border{
  transition-property:border;
  transition-timing-function:cubic-bezier(0.4, 0, 0.2, 1);
  transition-duration:150ms
}

.htw-transition-colors{
  transition-property:color, background-color, border-color, text-decoration-color, fill, stroke;
  transition-timing-function:cubic-bezier(0.4, 0, 0.2, 1);
  transition-duration:150ms
}

.htw-transition-none{
  transition-property:none
}

.htw-transition-transform{
  transition-property:transform;
  transition-timing-function:cubic-bezier(0.4, 0, 0.2, 1);
  transition-duration:150ms
}

.htw-delay-150{
  transition-delay:150ms
}

.htw-duration-150{
  transition-duration:150ms
}

.htw-duration-200{
  transition-duration:200ms
}

.htw-duration-300{
  transition-duration:300ms
}

.htw-ease-\[cubic-bezier\(0\,1\,\.6\,1\)\]{
  transition-timing-function:cubic-bezier(0,1,.6,1)
}

.htw-ease-in-out{
  transition-timing-function:cubic-bezier(0.4, 0, 0.2, 1)
}

.htw-ease-out{
  transition-timing-function:cubic-bezier(0, 0, 0.2, 1)
}

.htw-will-change-transform{
  will-change:transform
}

.dark\:htw-prose-invert:is(.htw-dark *){
  --tw-prose-body:var(--tw-prose-invert-body);
  --tw-prose-headings:var(--tw-prose-invert-headings);
  --tw-prose-lead:var(--tw-prose-invert-lead);
  --tw-prose-links:var(--tw-prose-invert-links);
  --tw-prose-bold:var(--tw-prose-invert-bold);
  --tw-prose-counters:var(--tw-prose-invert-counters);
  --tw-prose-bullets:var(--tw-prose-invert-bullets);
  --tw-prose-hr:var(--tw-prose-invert-hr);
  --tw-prose-quotes:var(--tw-prose-invert-quotes);
  --tw-prose-quote-borders:var(--tw-prose-invert-quote-borders);
  --tw-prose-captions:var(--tw-prose-invert-captions);
  --tw-prose-kbd:var(--tw-prose-invert-kbd);
  --tw-prose-kbd-shadows:var(--tw-prose-invert-kbd-shadows);
  --tw-prose-code:var(--tw-prose-invert-code);
  --tw-prose-pre-code:var(--tw-prose-invert-pre-code);
  --tw-prose-pre-bg:var(--tw-prose-invert-pre-bg);
  --tw-prose-th-borders:var(--tw-prose-invert-th-borders);
  --tw-prose-td-borders:var(--tw-prose-invert-td-borders)
}

.first\:htw-mt-0:first-child{
  margin-top:0px
}

.last\:htw-mb-0:last-child{
  margin-bottom:0px
}

.focus-within\:htw-border-primary-500:focus-within{
  --tw-border-opacity:1;
  border-color:rgb(var(--_histoire-color-primary-500) / var(--tw-border-opacity, 1))
}

.focus-within\:htw-bg-gray-500\/5:focus-within{
  background-color:rgb(var(--_histoire-color-gray-500) / 0.05)
}

.hover\:htw-border-primary-500:hover{
  --tw-border-opacity:1;
  border-color:rgb(var(--_histoire-color-primary-500) / var(--tw-border-opacity, 1))
}

.hover\:htw-bg-gray-200:hover{
  --tw-bg-opacity:1;
  background-color:rgb(var(--_histoire-color-gray-200) / var(--tw-bg-opacity, 1))
}

.hover\:htw-bg-gray-500\/10:hover{
  background-color:rgb(var(--_histoire-color-gray-500) / 0.1)
}

.hover\:htw-bg-gray-500\/20:hover{
  background-color:rgb(var(--_histoire-color-gray-500) / 0.2)
}

.hover\:htw-bg-gray-500\/30:hover{
  background-color:rgb(var(--_histoire-color-gray-500) / 0.3)
}

.hover\:htw-bg-primary-100:hover{
  --tw-bg-opacity:1;
  background-color:rgb(var(--_histoire-color-primary-100) / var(--tw-bg-opacity, 1))
}

.hover\:htw-bg-primary-200:hover{
  --tw-bg-opacity:1;
  background-color:rgb(var(--_histoire-color-primary-200) / var(--tw-bg-opacity, 1))
}

.hover\:htw-bg-primary-300:hover{
  --tw-bg-opacity:1;
  background-color:rgb(var(--_histoire-color-primary-300) / var(--tw-bg-opacity, 1))
}

.hover\:htw-bg-primary-50:hover{
  --tw-bg-opacity:1;
  background-color:rgb(var(--_histoire-color-primary-50) / var(--tw-bg-opacity, 1))
}

.hover\:htw-bg-primary-500\/10:hover{
  background-color:rgb(var(--_histoire-color-primary-500) / 0.1)
}

.hover\:htw-bg-primary-500\/30:hover{
  background-color:rgb(var(--_histoire-color-primary-500) / 0.3)
}

.hover\:htw-bg-primary-500\/50:hover{
  background-color:rgb(var(--_histoire-color-primary-500) / 0.5)
}

.hover\:htw-bg-primary-600:hover{
  --tw-bg-opacity:1;
  background-color:rgb(var(--_histoire-color-primary-600) / var(--tw-bg-opacity, 1))
}

.hover\:htw-text-primary-500:hover{
  --tw-text-opacity:1;
  color:rgb(var(--_histoire-color-primary-500) / var(--tw-text-opacity, 1))
}

.hover\:htw-opacity-100:hover{
  opacity:1
}

.focus\:htw-border-primary-500:focus{
  --tw-border-opacity:1;
  border-color:rgb(var(--_histoire-color-primary-500) / var(--tw-border-opacity, 1))
}

.focus\:htw-border-primary-500\/50:focus{
  border-color:rgb(var(--_histoire-color-primary-500) / 0.5)
}

.focus\:htw-opacity-100:focus{
  opacity:1
}

.focus-visible\:htw-border-primary-500:focus-visible{
  --tw-border-opacity:1;
  border-color:rgb(var(--_histoire-color-primary-500) / var(--tw-border-opacity, 1))
}

.active\:htw-bg-gray-600\/50:active{
  background-color:rgb(var(--_histoire-color-gray-600) / 0.5)
}

.htw-group:first-child .group-first\:htw-hidden{
  display:none
}

.htw-group:nth-child(odd) .group-odd\:htw-bg-gray-100\/50{
  background-color:rgb(var(--_histoire-color-gray-100) / 0.5)
}

.htw-group:focus-within .group-focus-within\:htw-visible{
  visibility:visible
}

.htw-group:hover .group-hover\:htw-flex{
  display:flex
}

.htw-group:hover .group-hover\:htw-border-primary-500{
  --tw-border-opacity:1;
  border-color:rgb(var(--_histoire-color-primary-500) / var(--tw-border-opacity, 1))
}

.htw-group:hover .group-hover\:htw-bg-primary-100{
  --tw-bg-opacity:1;
  background-color:rgb(var(--_histoire-color-primary-100) / var(--tw-bg-opacity, 1))
}

.htw-group:hover .group-hover\:htw-opacity-100{
  opacity:1
}

.htw-group:hover .group-hover\:htw-opacity-90{
  opacity:0.9
}

.htw-group:active .group-active\:htw-bg-gray-500\/20{
  background-color:rgb(var(--_histoire-color-gray-500) / 0.2)
}

.dark\:htw-divide-gray-750:is(.htw-dark *) > :not([hidden]) ~ :not([hidden]){
  --tw-divide-opacity:1;
  border-color:rgb(var(--_histoire-color-gray-750) / var(--tw-divide-opacity, 1))
}

.dark\:htw-divide-gray-800:is(.htw-dark *) > :not([hidden]) ~ :not([hidden]){
  --tw-divide-opacity:1;
  border-color:rgb(var(--_histoire-color-gray-800) / var(--tw-divide-opacity, 1))
}

.dark\:htw-divide-gray-850:is(.htw-dark *) > :not([hidden]) ~ :not([hidden]){
  --tw-divide-opacity:1;
  border-color:rgb(var(--_histoire-color-gray-850) / var(--tw-divide-opacity, 1))
}

.dark\:htw-border-gray-700\/30:is(.htw-dark *){
  border-color:rgb(var(--_histoire-color-gray-700) / 0.3)
}

.dark\:htw-border-gray-750:is(.htw-dark *){
  --tw-border-opacity:1;
  border-color:rgb(var(--_histoire-color-gray-750) / var(--tw-border-opacity, 1))
}

.dark\:htw-border-gray-800:is(.htw-dark *){
  --tw-border-opacity:1;
  border-color:rgb(var(--_histoire-color-gray-800) / var(--tw-border-opacity, 1))
}

.dark\:htw-border-gray-850:is(.htw-dark *){
  --tw-border-opacity:1;
  border-color:rgb(var(--_histoire-color-gray-850) / var(--tw-border-opacity, 1))
}

.dark\:htw-border-primary-900:is(.htw-dark *){
  --tw-border-opacity:1;
  border-color:rgb(var(--_histoire-color-primary-900) / var(--tw-border-opacity, 1))
}

.dark\:htw-border-white\/20:is(.htw-dark *){
  border-color:rgb(255 255 255 / 0.2)
}

.dark\:htw-border-white\/25:is(.htw-dark *){
  border-color:rgb(255 255 255 / 0.25)
}

.dark\:htw-border-white\/50:is(.htw-dark *){
  border-color:rgb(255 255 255 / 0.5)
}

.dark\:htw-bg-black:is(.htw-dark *){
  --tw-bg-opacity:1;
  background-color:rgb(0 0 0 / var(--tw-bg-opacity, 1))
}

.dark\:htw-bg-gray-600:is(.htw-dark *){
  --tw-bg-opacity:1;
  background-color:rgb(var(--_histoire-color-gray-600) / var(--tw-bg-opacity, 1))
}

.dark\:htw-bg-gray-700:is(.htw-dark *){
  --tw-bg-opacity:1;
  background-color:rgb(var(--_histoire-color-gray-700) / var(--tw-bg-opacity, 1))
}

.dark\:htw-bg-gray-750:is(.htw-dark *){
  --tw-bg-opacity:1;
  background-color:rgb(var(--_histoire-color-gray-750) / var(--tw-bg-opacity, 1))
}

.dark\:htw-bg-gray-900:is(.htw-dark *){
  --tw-bg-opacity:1;
  background-color:rgb(var(--_histoire-color-gray-900) / var(--tw-bg-opacity, 1))
}

.dark\:htw-bg-gray-900\/80:is(.htw-dark *){
  background-color:rgb(var(--_histoire-color-gray-900) / 0.8)
}

.dark\:htw-bg-primary-400:is(.htw-dark *){
  --tw-bg-opacity:1;
  background-color:rgb(var(--_histoire-color-primary-400) / var(--tw-bg-opacity, 1))
}

.dark\:htw-bg-primary-600:is(.htw-dark *){
  --tw-bg-opacity:1;
  background-color:rgb(var(--_histoire-color-primary-600) / var(--tw-bg-opacity, 1))
}

.dark\:htw-bg-primary-700:is(.htw-dark *){
  --tw-bg-opacity:1;
  background-color:rgb(var(--_histoire-color-primary-700) / var(--tw-bg-opacity, 1))
}

.dark\:htw-bg-primary-800:is(.htw-dark *){
  --tw-bg-opacity:1;
  background-color:rgb(var(--_histoire-color-primary-800) / var(--tw-bg-opacity, 1))
}

.dark\:htw-text-black:is(.htw-dark *){
  --tw-text-opacity:1;
  color:rgb(0 0 0 / var(--tw-text-opacity, 1))
}

.dark\:htw-text-gray-100:is(.htw-dark *){
  --tw-text-opacity:1;
  color:rgb(var(--_histoire-color-gray-100) / var(--tw-text-opacity, 1))
}

.dark\:htw-text-gray-300:is(.htw-dark *){
  --tw-text-opacity:1;
  color:rgb(var(--_histoire-color-gray-300) / var(--tw-text-opacity, 1))
}

.dark\:htw-text-primary-200:is(.htw-dark *){
  --tw-text-opacity:1;
  color:rgb(var(--_histoire-color-primary-200) / var(--tw-text-opacity, 1))
}

.dark\:htw-text-primary-400:is(.htw-dark *){
  --tw-text-opacity:1;
  color:rgb(var(--_histoire-color-primary-400) / var(--tw-text-opacity, 1))
}

.dark\:htw-text-white\/\[1\%\]:is(.htw-dark *){
  color:rgb(255 255 255 / 1%)
}

.dark\:focus-within\:htw-border-primary-500:focus-within:is(.htw-dark *){
  --tw-border-opacity:1;
  border-color:rgb(var(--_histoire-color-primary-500) / var(--tw-border-opacity, 1))
}

.dark\:hover\:htw-border-primary-500:hover:is(.htw-dark *){
  --tw-border-opacity:1;
  border-color:rgb(var(--_histoire-color-primary-500) / var(--tw-border-opacity, 1))
}

.dark\:hover\:htw-bg-gray-800:hover:is(.htw-dark *){
  --tw-bg-opacity:1;
  background-color:rgb(var(--_histoire-color-gray-800) / var(--tw-bg-opacity, 1))
}

.dark\:hover\:htw-bg-primary-700:hover:is(.htw-dark *){
  --tw-bg-opacity:1;
  background-color:rgb(var(--_histoire-color-primary-700) / var(--tw-bg-opacity, 1))
}

.dark\:hover\:htw-bg-primary-800:hover:is(.htw-dark *){
  --tw-bg-opacity:1;
  background-color:rgb(var(--_histoire-color-primary-800) / var(--tw-bg-opacity, 1))
}

.dark\:hover\:htw-bg-primary-900:hover:is(.htw-dark *){
  --tw-bg-opacity:1;
  background-color:rgb(var(--_histoire-color-primary-900) / var(--tw-bg-opacity, 1))
}

.dark\:hover\:htw-text-primary-400:hover:is(.htw-dark *){
  --tw-text-opacity:1;
  color:rgb(var(--_histoire-color-primary-400) / var(--tw-text-opacity, 1))
}

.dark\:focus\:htw-border-primary-500:focus:is(.htw-dark *){
  --tw-border-opacity:1;
  border-color:rgb(var(--_histoire-color-primary-500) / var(--tw-border-opacity, 1))
}

.htw-group:nth-child(odd) .dark\:group-odd\:htw-bg-gray-750\/40:is(.htw-dark *){
  background-color:rgb(var(--_histoire-color-gray-750) / 0.4)
}

.htw-group:hover .group-hover\:dark\:htw-border-primary-500:is(.htw-dark *){
  --tw-border-opacity:1;
  border-color:rgb(var(--_histoire-color-primary-500) / var(--tw-border-opacity, 1))
}

.htw-group:hover .dark\:group-hover\:htw-bg-primary-700:is(.htw-dark *){
  --tw-bg-opacity:1;
  background-color:rgb(var(--_histoire-color-primary-700) / var(--tw-bg-opacity, 1))
}

@media (min-width: 640px){
  .sm\:htw-h-4{
    height:1rem
  }

  .sm\:htw-w-4{
    width:1rem
  }

  .sm\:htw-p-1{
    padding:0.25rem
  }

  .sm\:htw-py-4{
    padding-top:1rem;
    padding-bottom:1rem
  }
}

@media (min-width: 768px){
  .md\:htw-mx-auto{
    margin-left:auto;
    margin-right:auto
  }

  .md\:htw-mt-16{
    margin-top:4rem
  }

  .md\:htw-block{
    display:block
  }

  .md\:htw-max-w-\[600px\]{
    max-width:600px
  }

  .md\:htw-flex-col{
    flex-direction:column
  }

  .md\:htw-p-12{
    padding:3rem
  }

  .md\:htw-py-1\.5{
    padding-top:0.375rem;
    padding-bottom:0.375rem
  }
}

@media (min-width: 1024px){
  .lg\:htw-max-w-\[800px\]{
    max-width:800px
  }
}

@media (min-width: 1280px){
  .xl\:htw-max-w-\[900px\]{
    max-width:900px
  }
}

@media (max-width: 767px){
  .\!md\:htw-flex-col{
    flex-direction:column
  }
}

.histoire-story-list-folder-button:hover .\[\.histoire-story-list-folder-button\:hover_\&\]\:htw-opacity-100{
  opacity:1
}
}
@scope (:root) to (.__histoire-render-story:not(.__histoire-render-custom-controls)) {
.bind-tree-margin[data-v-64c2458f] {
  margin-left: var(--2562213a);
}
.bind-icon-color[data-v-64c2458f] {
  color: var(--1eff521f);
}
}
@scope (:root) to (.__histoire-render-story:not(.__histoire-render-custom-controls)) {
.bind-tree-padding[data-v-ee932a0c] {
  padding-left: var(--5352bb71);
}
}
@scope (:root) to (.__histoire-render-story:not(.__histoire-render-custom-controls)) {
.bind-icon-color[data-v-d15ecb89] {
  color: var(--a3f02f4e);
}
}
@scope (:root) to (.__histoire-render-story:not(.__histoire-render-custom-controls)) {
.landscape > div > .dragger[data-v-4f40a1bb] {
  width: .625rem;
}
.portrait > div > .dragger[data-v-4f40a1bb] {
  height: .625rem;
}
.landscape > div > .dragger.dragger-offset-before[data-v-4f40a1bb] {
  right: 0;
}
.portrait > div > .dragger.dragger-offset-before[data-v-4f40a1bb] {
  bottom: 0;
}
.landscape > div > .dragger.dragger-offset-center[data-v-4f40a1bb] {
  right: -.3125rem;
}
.portrait > div > .dragger.dragger-offset-center[data-v-4f40a1bb] {
  bottom: -.3125rem;
}
.landscape > div > .dragger.dragger-offset-after[data-v-4f40a1bb] {
  right: -.625rem;
}
.portrait > div > .dragger.dragger-offset-after[data-v-4f40a1bb] {
  bottom: -.625rem;
}
}
@scope (:root) to (.__histoire-render-story:not(.__histoire-render-custom-controls)) {
.htw-base-empty[data-v-c5ecfead]:not(.no-animation) {
  animation: htw-base-empty-c5ecfead .15s .2s both;
}
@keyframes htw-base-empty-c5ecfead {
0% {
    opacity: 0;
}
100% {
    opacity: 1;
}
}
}
@scope (:root) to (.__histoire-render-story:not(.__histoire-render-custom-controls)) {
.__histoire-code-placeholder[data-v-96af7f40] {
  color: inherit;
  font-size: inherit;
}
}
@scope (:root) to (.__histoire-render-story:not(.__histoire-render-custom-controls)) {
.bind-preview-bg[data-v-c48fb2b2] {
  background-color: var(--627bec82);
  color: var(--35068428);
}
}
@scope (:root) to (.__histoire-render-story:not(.__histoire-render-custom-controls)) {
.bind-icon-color[data-v-feff9239] {
  color: var(--60afaf4d);
}
.bind-preview-bg[data-v-feff9239] {
  background-color: var(--3bd99e7e);
}
}
@scope (:root) to (.__histoire-render-story:not(.__histoire-render-custom-controls)) {
.bind-icon-color[data-v-1b279b85] {
  color: var(--ab2181a2);
}
}
@scope (:root) to (.__histoire-render-story:not(.__histoire-render-custom-controls)) {
.__histoire-hatched-pattern[data-v-91561117] {
  background: repeating-linear-gradient(135deg,
  transparent 0px,
  transparent 32px,
  currentColor 32px,
  currentColor 64px);
}
}
@scope (:root) to (.__histoire-render-story:not(.__histoire-render-custom-controls)) {
.bind-preview-bg[data-v-18122333] {
  background-color: var(--5f6f4ee9);
}
}
@scope (:root) to (.__histoire-render-story:not(.__histoire-render-custom-controls)) {
.bind-icon-color[data-v-c2a43485] {
  color: var(--41c4d268);
}
}
@scope (:root) to (.__histoire-render-story:not(.__histoire-render-custom-controls)) {
.bind-icon-color[data-v-096f6d6e] {
  color: var(--0f021d3c);
}
}
@scope (:root) to (.__histoire-render-story:not(.__histoire-render-custom-controls)) {
img.colorize-black[data-v-2114f510] {
  filter: grayscale(100) brightness(0);
}
}
@scope (:root) to (.__histoire-render-story:not(.__histoire-render-custom-controls)) {
.bind-icon-color[data-v-9f94ad2b] {
  color: var(--1f9aa6ca);
}
}
.htw-bind-col-size{grid-template-columns:repeat(auto-fill,minmax(var(--histoire-col-size),1fr))}.__histoire-json-code[data-v-d4369e5a] .cm-editor{height:100%;min-width:280px}.v-popper{line-height:0}.htw-dark .v-popper--theme-dropdown .v-popper__inner{--tw-border-opacity: 1;border-color:rgb(31 31 33 / var(--tw-border-opacity, 1));--tw-bg-opacity: 1;background-color:rgb(63 63 70 / var(--tw-bg-opacity, 1));--tw-text-opacity: 1;color:rgb(244 244 245 / var(--tw-text-opacity, 1))}.htw-dark .v-popper--theme-dropdown .v-popper__arrow-inner{--tw-border-opacity: 1;border-color:rgb(63 63 70 / var(--tw-border-opacity, 1))}.htw-dark .v-popper--theme-dropdown .v-popper__arrow-outer{--tw-border-opacity: 1;border-color:rgb(31 31 33 / var(--tw-border-opacity, 1))}.v-popper--theme-dropdown.v-popper__popper--show-from .v-popper__wrapper{transform:scale(.75)}.v-popper--theme-dropdown.v-popper__popper--show-to .v-popper__wrapper{transform:none;transition:transform .15s cubic-bezier(0,1,.5,1)}.v-popper__popper:focus-visible{outline:none}.htw-range-input::-webkit-slider-thumb{height:.75rem;width:.75rem;-webkit-appearance:none;appearance:none;border-radius:9999px;border-width:1px;border-style:solid;border-color:#00000040;--tw-bg-opacity: 1;background-color:rgb(255 255 255 / var(--tw-bg-opacity, 1))}.htw-range-input:is(.htw-dark *)::-webkit-slider-thumb{border-color:#ffffff40;--tw-bg-opacity: 1;background-color:rgb(63 63 70 / var(--tw-bg-opacity, 1))}.htw-range-input:hover::-webkit-slider-thumb{--tw-border-opacity: 1 !important;border-color:rgb(16 185 129 / var(--tw-border-opacity, 1))!important;--tw-bg-opacity: 1 !important;background-color:rgb(16 185 129 / var(--tw-bg-opacity, 1))!important}.htw-range-input::-moz-range-thumb{height:.75rem;width:.75rem;-moz-appearance:none;appearance:none;border-radius:9999px;border-width:1px;border-style:solid;border-color:#00000040;--tw-bg-opacity: 1;background-color:rgb(255 255 255 / var(--tw-bg-opacity, 1))}.htw-range-input:is(.htw-dark *)::-moz-range-thumb{border-color:#ffffff40;--tw-bg-opacity: 1;background-color:rgb(63 63 70 / var(--tw-bg-opacity, 1))}.htw-range-input:hover::-moz-range-thumb{--tw-border-opacity: 1 !important;border-color:rgb(16 185 129 / var(--tw-border-opacity, 1))!important;--tw-bg-opacity: 1 !important;background-color:rgb(16 185 129 / var(--tw-bg-opacity, 1))!important}html,
body {
  background: transparent !important;
}body {
  margin: 0;
}html {
  font-size: 1rem;
  font-family: 'Noto Sans Display', system-ui, sans-serif;
}.htw-sandbox-hidden {
  display: none;
}.__histoire-render-story:not(.__histoire-render-custom-controls) {
  overflow: auto;
  min-height: 100%;
}

.cr-page[data-v-32cc8395] {
    font-family: var(--cv-ui-font-family);
    color: var(--cv-ui-text-primary);
    background: var(--cv-ui-bg-secondary);
    min-height: 100vh;
    padding: 2rem;
    box-sizing: border-box;
}

/* ── Header */
.cr-header[data-v-32cc8395] {
    margin-bottom: 2rem;
    padding-bottom: 1.5rem;
    border-bottom: 2px solid var(--cv-ui-border-color);
}
.cr-header__title[data-v-32cc8395] {
    font-size: var(--cv-ui-font-size-xl);
    font-weight: var(--cv-ui-font-weight-bold);
    margin: 0 0 0.5rem;
}
.cr-header__sub[data-v-32cc8395] {
    font-size: var(--cv-ui-font-size-sm);
    color: var(--cv-ui-text-secondary);
    margin: 0;
    line-height: 1.6;
}

/* ── Component accordion */
.cr-comp[data-v-32cc8395] {
    margin-bottom: 0.5rem;
    border: 1px solid var(--cv-ui-border-color);
    border-radius: var(--cv-ui-radius-lg);
    overflow: hidden;
    background: var(--cv-ui-bg-primary);
}
.cr-comp__header[data-v-32cc8395] {
    display: flex;
    align-items: baseline;
    gap: 0.75rem;
    width: 100%;
    padding: 0.875rem 1rem;
    background: transparent;
    border: none;
    cursor: pointer;
    text-align: left;
    transition: background-color var(--cv-ui-transition-fast) var(--cv-ui-transition-timing);
}
.cr-comp__header[data-v-32cc8395]:hover {
    background: var(--cv-ui-bg-hover);
}
.cr-comp__arrow[data-v-32cc8395] {
    font-size: 10px;
    color: var(--cv-ui-text-tertiary);
    transition: transform var(--cv-ui-transition-fast) var(--cv-ui-transition-timing);
    flex-shrink: 0;
}
.cr-comp__arrow--open[data-v-32cc8395] {
    transform: rotate(90deg);
}
.cr-comp__name[data-v-32cc8395] {
    font-family: 'SFMono-Regular', Consolas, monospace;
    font-size: var(--cv-ui-font-size-sm);
    font-weight: var(--cv-ui-font-weight-semibold);
    color: var(--cv-ui-color-primary-dark);
    flex-shrink: 0;
    min-width: 140px;
}
.cr-comp__desc[data-v-32cc8395] {
    font-size: var(--cv-ui-font-size-xs);
    color: var(--cv-ui-text-secondary);
    line-height: 1.4;
}

/* ── Accordion body */
.cr-comp__body[data-v-32cc8395] {
    padding: 1rem;
    border-top: 1px solid var(--cv-ui-border-color);
    display: flex;
    flex-direction: column;
    gap: 1.25rem;
}

/* ── Blocks */
.cr-block__title[data-v-32cc8395] {
    font-size: var(--cv-ui-font-size-xs);
    font-weight: var(--cv-ui-font-weight-semibold);
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--cv-ui-text-secondary);
    margin: 0 0 0.5rem;
}

/* ── Pre / code blocks */
.cr-pre[data-v-32cc8395] {
    margin: 0;
    padding: 0.875rem 1rem;
    background: #1e293b;
    color: #94a3b8;
    font-family: 'SFMono-Regular', Consolas, 'Liberation Mono', Menlo, monospace;
    font-size: 12px;
    line-height: 1.7;
    border-radius: var(--cv-ui-radius-md);
    overflow-x: auto;
    white-space: pre;
}
.cr-pre--css[data-v-32cc8395] {
    color: #7dd3fc;
}
.cr-code[data-v-32cc8395] {
    font-family: 'SFMono-Regular', Consolas, monospace;
    font-size: 0.8em;
    background: var(--cv-ui-bg-tertiary);
    border: 1px solid var(--cv-ui-border-color);
    border-radius: var(--cv-ui-radius-sm);
    padding: 1px 5px;
    color: var(--cv-ui-color-primary-dark);
}

/* ── Table */
.cr-table[data-v-32cc8395] {
    width: 100%;
    border-collapse: collapse;
    font-size: var(--cv-ui-font-size-sm);
}
.cr-table th[data-v-32cc8395] {
    text-align: left;
    padding: 0.4rem 0.75rem;
    font-size: var(--cv-ui-font-size-xs);
    font-weight: var(--cv-ui-font-weight-semibold);
    color: var(--cv-ui-text-secondary);
    text-transform: uppercase;
    letter-spacing: 0.04em;
    background: var(--cv-ui-bg-tertiary);
    border-bottom: 1px solid var(--cv-ui-border-color);
}
.cr-table td[data-v-32cc8395] {
    padding: 0.45rem 0.75rem;
    border-bottom: 1px solid var(--cv-ui-border-color);
    vertical-align: top;
}
.cr-table tr:last-child td[data-v-32cc8395] { border-bottom: none;
}
.cr-table tr:hover td[data-v-32cc8395] { background: var(--cv-ui-bg-hover);
}
.cr-badge[data-v-32cc8395] {
    font-family: 'SFMono-Regular', Consolas, monospace;
    font-size: 11px;
    background: var(--cv-ui-color-primary-light);
    color: var(--cv-ui-color-primary-dark);
    border-radius: var(--cv-ui-radius-sm);
    padding: 1px 5px;
    white-space: nowrap;
}
.cr-prop[data-v-32cc8395] {
    font-family: 'SFMono-Regular', Consolas, monospace;
    font-size: 11px;
    color: var(--cv-ui-text-secondary);
}
.cr-desc[data-v-32cc8395] {
    font-size: var(--cv-ui-font-size-xs);
    color: var(--cv-ui-text-secondary);
    line-height: 1.5;
}

/* ── Footer */
.cr-footer[data-v-32cc8395] {
    margin-top: 2rem;
    padding-top: 1rem;
    border-top: 1px solid var(--cv-ui-border-color);
    font-size: var(--cv-ui-font-size-xs);
    color: var(--cv-ui-text-tertiary);
    line-height: 1.6;
}

.cv-doc[data-v-7bbc4512] {
        max-width: 860px;
        margin: 0 auto;
        padding: 48px 32px;
        font-family: var(--cv-ui-font-family, system-ui, sans-serif);
        color: var(--cv-ui-text-primary, #1e293b);
}
.cv-doc__page-header[data-v-7bbc4512] {
        padding-bottom: 40px;
        border-bottom: 1px solid var(--cv-ui-border-color, #e2e8f0);
        margin-bottom: 48px;
}
.cv-doc__page-title[data-v-7bbc4512] {
        font-size: 36px;
        font-weight: 700;
        letter-spacing: -0.02em;
        margin: 0 0 10px;
}
.cv-doc__page-subtitle[data-v-7bbc4512] {
        font-size: 16px;
        color: var(--cv-ui-text-secondary, #64748b);
        margin: 0;
}
.cv-doc__section[data-v-7bbc4512] {
        margin-bottom: 52px;
}
.cv-doc__h2[data-v-7bbc4512] {
        font-size: 20px;
        font-weight: 700;
        margin: 0 0 16px;
        display: flex;
        align-items: center;
        gap: 12px;
}
.cv-doc__step[data-v-7bbc4512] {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        width: 28px;
        height: 28px;
        background: var(--cv-ui-color-primary, #3b82f6);
        color: #fff;
        border-radius: 50%;
        font-size: 13px;
        font-weight: 700;
        flex-shrink: 0;
}
.cv-doc__p[data-v-7bbc4512] {
        font-size: 15px;
        line-height: 1.75;
        color: var(--cv-ui-text-secondary, #64748b);
        margin: 0 0 14px;
}
.cv-doc__inline-code[data-v-7bbc4512] {
        font-family: 'Fira Code', 'Cascadia Code', monospace;
        font-size: 13px;
        background: var(--cv-ui-bg-tertiary, #f1f5f9);
        border: 1px solid var(--cv-ui-border-color, #e2e8f0);
        border-radius: var(--cv-ui-radius-sm, 4px);
        padding: 1px 6px;
        color: var(--cv-ui-color-primary, #3b82f6);
}

    /* Code blocks */
.cv-doc__codeblock[data-v-7bbc4512] {
        border: 1px solid var(--cv-ui-border-color, #e2e8f0);
        border-radius: var(--cv-ui-radius-md, 6px);
        overflow: hidden;
        background: var(--cv-ui-bg-primary, #fff);
}
.cv-doc__codeblock-bar[data-v-7bbc4512] {
        background: var(--cv-ui-bg-tertiary, #f1f5f9);
        border-bottom: 1px solid var(--cv-ui-border-color, #e2e8f0);
        padding: 6px 14px;
        display: flex;
        align-items: center;
        gap: 8px;
}
.cv-doc__codeblock-label[data-v-7bbc4512] {
        font-size: 12px;
        font-family: 'Fira Code', monospace;
        color: var(--cv-ui-text-tertiary, #94a3b8);
}
.cv-doc__pre[data-v-7bbc4512] {
        margin: 0;
        padding: 20px;
        overflow-x: auto;
        font-family: 'Fira Code', 'Cascadia Code', 'Consolas', monospace;
        font-size: 13px;
        line-height: 1.7;
        background: var(--cv-ui-bg-secondary, #f8fafc);
        color: var(--cv-ui-text-primary, #1e293b);
}
.cv-doc__pre code[data-v-7bbc4512] {
        font-family: inherit;
}

    /* Syntax tokens */
.cv-doc__token-keyword[data-v-7bbc4512] {
        color: #7c3aed;
        font-weight: 500;
}
.cv-doc__token-string[data-v-7bbc4512] {
        color: #059669;
}
.cv-doc__token-comment[data-v-7bbc4512] {
        color: var(--cv-ui-text-tertiary, #94a3b8);
        font-style: italic;
}
.cv-doc__token-tag[data-v-7bbc4512] {
        color: #0369a1;
}
.cv-doc__token-attr[data-v-7bbc4512] {
        color: #7c3aed;
}
.cv-doc__token-fn[data-v-7bbc4512] {
        color: #d97706;
}
.cv-doc__token-prop[data-v-7bbc4512] {
        color: #0369a1;
}
.cv-doc__token-selector[data-v-7bbc4512] {
        color: #7c3aed;
}

.cv-doc[data-v-285a8839] {
        max-width: 900px;
        margin: 0 auto;
        padding: 48px 32px;
        font-family: var(--cv-ui-font-family, system-ui, sans-serif);
        color: var(--cv-ui-text-primary, #1e293b);
}

    /* Hero */
.cv-doc__hero[data-v-285a8839] {
        text-align: center;
        padding: 48px 0 64px;
        border-bottom: 1px solid var(--cv-ui-border-color, #e2e8f0);
        margin-bottom: 56px;
}
.cv-doc__hero-badge[data-v-285a8839] {
        display: inline-block;
        background: var(--cv-ui-color-primary-light, #dbeafe);
        color: var(--cv-ui-color-primary, #3b82f6);
        font-size: 12px;
        font-weight: 600;
        letter-spacing: 0.08em;
        text-transform: uppercase;
        padding: 4px 12px;
        border-radius: var(--cv-ui-radius-full, 9999px);
        margin-bottom: 20px;
}
.cv-doc__hero-title[data-v-285a8839] {
        font-size: 48px;
        font-weight: 700;
        letter-spacing: -0.02em;
        margin: 0 0 16px;
        background: linear-gradient(
            135deg,
            var(--cv-ui-color-primary, #3b82f6),
            var(--cv-ui-color-primary-dark, #1e40af)
        );
        -webkit-background-clip: text;
        -webkit-text-fill-color: transparent;
        background-clip: text;
}
.cv-doc__hero-subtitle[data-v-285a8839] {
        font-size: 18px;
        color: var(--cv-ui-text-secondary, #64748b);
        line-height: 1.7;
        margin: 0 0 28px;
}
.cv-doc__hero-chips[data-v-285a8839] {
        display: flex;
        flex-wrap: wrap;
        gap: 8px;
        justify-content: center;
}
.cv-doc__chip[data-v-285a8839] {
        background: var(--cv-ui-bg-secondary, #f8fafc);
        border: 1px solid var(--cv-ui-border-color, #e2e8f0);
        border-radius: var(--cv-ui-radius-full, 9999px);
        padding: 4px 14px;
        font-size: 13px;
        color: var(--cv-ui-text-secondary, #64748b);
}

    /* Sections */
.cv-doc__section[data-v-285a8839] {
        margin-bottom: 56px;
}
.cv-doc__h2[data-v-285a8839] {
        font-size: 24px;
        font-weight: 700;
        margin: 0 0 16px;
        color: var(--cv-ui-text-primary, #1e293b);
}
.cv-doc__h3[data-v-285a8839] {
        font-size: 13px;
        font-weight: 600;
        text-transform: uppercase;
        letter-spacing: 0.06em;
        color: var(--cv-ui-text-tertiary, #94a3b8);
        margin: 0 0 8px;
}
.cv-doc__p[data-v-285a8839] {
        font-size: 15px;
        line-height: 1.75;
        color: var(--cv-ui-text-secondary, #64748b);
        margin: 0 0 12px;
}
.cv-doc__code[data-v-285a8839] {
        font-family: 'Fira Code', 'Cascadia Code', monospace;
        font-size: 13px;
        background: var(--cv-ui-bg-tertiary, #f1f5f9);
        border: 1px solid var(--cv-ui-border-color, #e2e8f0);
        border-radius: var(--cv-ui-radius-sm, 4px);
        padding: 1px 6px;
        color: var(--cv-ui-color-primary, #3b82f6);
}

    /* Component grid */
.cv-doc__grid[data-v-285a8839] {
        display: grid;
        grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
        gap: 16px;
        margin-top: 24px;
}
.cv-doc__category-card[data-v-285a8839] {
        background: var(--cv-ui-bg-secondary, #f8fafc);
        border: 1px solid var(--cv-ui-border-color, #e2e8f0);
        border-radius: var(--cv-ui-radius-lg, 8px);
        padding: 20px;
}
.cv-doc__category-icon[data-v-285a8839] {
        font-size: 24px;
        margin-bottom: 10px;
}
.cv-doc__list[data-v-285a8839] {
        list-style: none;
        margin: 0;
        padding: 0;
}
.cv-doc__list li[data-v-285a8839] {
        font-size: 13px;
        color: var(--cv-ui-text-secondary, #64748b);
        padding: 3px 0;
        font-family: 'Fira Code', monospace;
}
.cv-doc__list li[data-v-285a8839]::before {
        content: '·  ';
        color: var(--cv-ui-color-primary, #3b82f6);
        font-weight: 700;
}

    /* Themes */
.cv-doc__themes[data-v-285a8839] {
        display: grid;
        grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
        gap: 12px;
        margin-top: 24px;
}
.cv-doc__theme-swatch[data-v-285a8839] {
        border-radius: var(--cv-ui-radius-md, 6px);
        padding: 16px;
        display: flex;
        flex-direction: column;
        gap: 4px;
        border: 1px solid rgba(0, 0, 0, 0.08);
}
.cv-doc__theme-swatch--default[data-v-285a8839] {
        background: #f8fafc;
        color: #1e293b;
}
.cv-doc__theme-swatch--dark[data-v-285a8839] {
        background: #1e293b;
        color: #f1f5f9;
}
.cv-doc__theme-swatch--brand[data-v-285a8839] {
        background: #eef0fd;
        color: #1a2340;
}
.cv-doc__theme-swatch--forest[data-v-285a8839] {
        background: #f3f7f0;
        color: #1c2b18;
}
.cv-doc__theme-dot[data-v-285a8839] {
        width: 28px;
        height: 28px;
        border-radius: 50%;
        margin-bottom: 8px;
}
.cv-doc__theme-swatch--default .cv-doc__theme-dot[data-v-285a8839] {
        background: #3b82f6;
}
.cv-doc__theme-swatch--dark .cv-doc__theme-dot[data-v-285a8839] {
        background: #60a5fa;
}
.cv-doc__theme-swatch--brand .cv-doc__theme-dot[data-v-285a8839] {
        background: #4c6cf5;
}
.cv-doc__theme-swatch--forest .cv-doc__theme-dot[data-v-285a8839] {
        background: #1a7a4a;
}
.cv-doc__theme-swatch span[data-v-285a8839] {
        font-weight: 600;
        font-size: 14px;
}
.cv-doc__theme-swatch small[data-v-285a8839] {
        font-size: 12px;
        opacity: 0.7;
}

    /* Tokens */
.cv-doc__token-groups[data-v-285a8839] {
        display: flex;
        flex-direction: column;
        gap: 8px;
        margin-top: 20px;
}
.cv-doc__token-group[data-v-285a8839] {
        display: flex;
        align-items: center;
        gap: 16px;
        padding: 10px 16px;
        background: var(--cv-ui-bg-secondary, #f8fafc);
        border: 1px solid var(--cv-ui-border-color, #e2e8f0);
        border-radius: var(--cv-ui-radius-md, 6px);
}
.cv-doc__token-prefix[data-v-285a8839] {
        font-family: 'Fira Code', monospace;
        font-size: 13px;
        color: var(--cv-ui-color-primary, #3b82f6);
        min-width: 220px;
        flex-shrink: 0;
}
.cv-doc__token-desc[data-v-285a8839] {
        font-size: 13px;
        color: var(--cv-ui-text-secondary, #64748b);
}

.tk-page[data-v-086e8199] {
    font-family: var(--cv-ui-font-family);
    color: var(--cv-ui-text-primary);
    background: var(--cv-ui-bg-secondary);
    min-height: 100vh;
    padding: 2rem;
    box-sizing: border-box;
}

/* ── Header */
.tk-header[data-v-086e8199] {
    margin-bottom: 2.5rem;
    padding-bottom: 1.5rem;
    border-bottom: 2px solid var(--cv-ui-border-color);
}
.tk-header__title[data-v-086e8199] {
    font-size: var(--cv-ui-font-size-xl);
    font-weight: var(--cv-ui-font-weight-bold);
    margin: 0 0 0.5rem;
}
.tk-header__sub[data-v-086e8199] {
    font-size: var(--cv-ui-font-size-sm);
    color: var(--cv-ui-text-secondary);
    margin: 0 0 0.5rem;
    line-height: 1.6;
}
.tk-header__override[data-v-086e8199] {
    font-size: var(--cv-ui-font-size-xs);
    color: var(--cv-ui-text-tertiary);
    margin: 0;
}

/* ── Sections */
.tk-section[data-v-086e8199] {
    margin-bottom: 2.5rem;
}
.tk-section__title[data-v-086e8199] {
    font-size: var(--cv-ui-font-size-md);
    font-weight: var(--cv-ui-font-weight-semibold);
    margin: 0 0 0.25rem;
    padding-bottom: 0.5rem;
    border-bottom: 1px solid var(--cv-ui-border-color);
}
.tk-section__sub[data-v-086e8199] {
    font-size: var(--cv-ui-font-size-sm);
    font-weight: var(--cv-ui-font-weight-semibold);
    color: var(--cv-ui-text-secondary);
    margin: 1rem 0 0.5rem;
}
.tk-section__desc[data-v-086e8199] {
    font-size: var(--cv-ui-font-size-sm);
    color: var(--cv-ui-text-secondary);
    margin: 0.25rem 0 1rem;
    line-height: 1.5;
}

/* ── Code inline */
.tk-code[data-v-086e8199] {
    font-family: 'SFMono-Regular', Consolas, 'Liberation Mono', Menlo, monospace;
    font-size: 0.8em;
    background: var(--cv-ui-bg-tertiary);
    border: 1px solid var(--cv-ui-border-color);
    border-radius: var(--cv-ui-radius-sm);
    padding: 1px 5px;
    color: var(--cv-ui-color-primary-dark);
}

/* ── Shared swatch labels */
.tk-swatch__token[data-v-086e8199] {
    display: block;
    font-family: 'SFMono-Regular', Consolas, monospace;
    font-size: 10px;
    color: var(--cv-ui-text-secondary);
    margin-top: 4px;
    line-height: 1.4;
    white-space: nowrap;
}
.tk-swatch__value[data-v-086e8199] {
    display: block;
    font-size: 10px;
    color: var(--cv-ui-text-tertiary);
    line-height: 1.3;
    white-space: nowrap;
}

/* ── Color rows */
.tk-color-row[data-v-086e8199] {
    display: flex;
    align-items: flex-start;
    gap: 1rem;
    margin-bottom: 1rem;
}
.tk-color-row__label[data-v-086e8199] {
    width: 72px;
    font-size: var(--cv-ui-font-size-sm);
    font-weight: var(--cv-ui-font-weight-medium);
    padding-top: 10px;
    flex-shrink: 0;
    color: var(--cv-ui-text-secondary);
}
.tk-color-swatches[data-v-086e8199] {
    display: flex;
    gap: 0.5rem;
    flex-wrap: wrap;
}
.tk-swatch-col[data-v-086e8199] {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    min-width: 68px;
}
.tk-swatch[data-v-086e8199] {
    width: 60px;
    height: 40px;
    border-radius: var(--cv-ui-radius-md);
    border: 1px solid rgba(0,0,0,0.08);
    cursor: default;
}

/* ── Surface grid */
.tk-surface-grid[data-v-086e8199] {
    display: flex;
    gap: 0.75rem;
    flex-wrap: wrap;
    margin-top: 0.75rem;
}
.tk-surface-item[data-v-086e8199] {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    min-width: 80px;
}
.tk-surface-swatch[data-v-086e8199] {
    width: 80px;
    height: 40px;
    border-radius: var(--cv-ui-radius-md);
    border: 1px solid var(--cv-ui-border-color);
}
.tk-surface-desc[data-v-086e8199] {
    font-size: 10px;
    color: var(--cv-ui-text-tertiary);
    line-height: 1.3;
    margin-top: 2px;
}

/* ── Text list */
.tk-text-list[data-v-086e8199] {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
    margin-top: 0.75rem;
}
.tk-text-item[data-v-086e8199] {
    display: flex;
    align-items: center;
    gap: 1.5rem;
    padding: 0.5rem 0.75rem;
    background: var(--cv-ui-bg-primary);
    border: 1px solid var(--cv-ui-border-color);
    border-radius: var(--cv-ui-radius-md);
}
.tk-text-preview[data-v-086e8199] {
    font-size: var(--cv-ui-font-size-sm);
    min-width: 280px;
    font-weight: var(--cv-ui-font-weight-medium);
}
.tk-text-meta[data-v-086e8199] {
    display: flex;
    gap: 0.75rem;
    align-items: center;
    flex-wrap: wrap;
}

/* ── Border swatches */
.tk-border-swatch[data-v-086e8199] {
    width: 80px;
    height: 40px;
    border-radius: var(--cv-ui-radius-md);
    border: 3px solid;
    background: var(--cv-ui-bg-primary);
}

/* ── Spacing */
.tk-spacing-list[data-v-086e8199] {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
    margin-top: 0.75rem;
}
.tk-spacing-row[data-v-086e8199] {
    display: flex;
    align-items: center;
    gap: 1rem;
}
.tk-spacing-row__label[data-v-086e8199] {
    font-family: 'SFMono-Regular', Consolas, monospace;
    font-size: 11px;
    color: var(--cv-ui-text-secondary);
    width: 180px;
    flex-shrink: 0;
}
.tk-spacing-bar-wrap[data-v-086e8199] {
    flex: 1;
    max-width: 300px;
    display: flex;
    align-items: center;
    height: 20px;
    background: var(--cv-ui-bg-tertiary);
    border-radius: var(--cv-ui-radius-sm);
    overflow: hidden;
}
.tk-spacing-bar[data-v-086e8199] {
    height: 100%;
    background: var(--cv-ui-color-primary-light);
    border-right: 2px solid var(--cv-ui-color-primary);
    min-width: 2px;
}
.tk-spacing-row__value[data-v-086e8199] {
    font-size: 11px;
    font-family: 'SFMono-Regular', Consolas, monospace;
    color: var(--cv-ui-text-tertiary);
    width: 36px;
}

/* ── Radius */
.tk-radius-grid[data-v-086e8199] {
    display: flex;
    gap: 1rem;
    flex-wrap: wrap;
    margin-top: 0.75rem;
}
.tk-radius-item[data-v-086e8199] {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
}
.tk-radius-box[data-v-086e8199] {
    width: 64px;
    height: 40px;
    background: var(--cv-ui-color-primary-light);
    border: 2px solid var(--cv-ui-color-primary);
}

/* ── Shadows */
.tk-shadow-grid[data-v-086e8199] {
    display: flex;
    gap: 1.5rem;
    flex-wrap: wrap;
    margin-top: 1rem;
    padding: 1rem 0;
}
.tk-shadow-item[data-v-086e8199] {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 0.5rem;
}
.tk-shadow-box[data-v-086e8199] {
    width: 72px;
    height: 48px;
    background: var(--cv-ui-bg-primary);
    border-radius: var(--cv-ui-radius-md);
}

/* ── Typography */
.tk-type-list[data-v-086e8199] {
    display: flex;
    flex-direction: column;
    gap: 0.25rem;
}
.tk-type-row[data-v-086e8199] {
    display: flex;
    align-items: baseline;
    gap: 1.5rem;
    padding: 0.4rem 0;
    border-bottom: 1px dashed var(--cv-ui-border-color);
}
.tk-type-preview[data-v-086e8199] {
    font-family: var(--cv-ui-font-family);
    color: var(--cv-ui-text-primary);
    min-width: 300px;
}
.tk-type-meta[data-v-086e8199] {
    display: flex;
    gap: 0.75rem;
    align-items: center;
}
.tk-font-family[data-v-086e8199] {
    display: flex;
    gap: 1rem;
    align-items: center;
    padding: 0.5rem 0.75rem;
    background: var(--cv-ui-bg-primary);
    border: 1px solid var(--cv-ui-border-color);
    border-radius: var(--cv-ui-radius-md);
    margin-top: 0.5rem;
}
.tk-font-family__value[data-v-086e8199] {
    font-size: 11px;
    color: var(--cv-ui-text-tertiary);
    font-family: 'SFMono-Regular', Consolas, monospace;
}

/* ── Transitions */
.tk-transition-list[data-v-086e8199] {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
    margin-top: 0.75rem;
}
.tk-transition-item[data-v-086e8199] {
    display: flex;
    align-items: center;
    gap: 1rem;
    cursor: default;
}
.tk-transition-bar[data-v-086e8199] {
    width: 200px;
    height: 20px;
    border-radius: var(--cv-ui-radius-sm);
    transform-origin: left center;
    transition-property: transform;
}
.tk-transition-meta[data-v-086e8199] {
    display: flex;
    gap: 0.75rem;
    align-items: center;
}
.tk-transition-timing[data-v-086e8199] {
    display: flex;
    gap: 1rem;
    align-items: center;
    margin-top: 0.75rem;
    padding: 0.5rem 0.75rem;
    background: var(--cv-ui-bg-primary);
    border: 1px solid var(--cv-ui-border-color);
    border-radius: var(--cv-ui-radius-md);
}

/* ── Table */
.tk-table[data-v-086e8199] {
    width: 100%;
    border-collapse: collapse;
    font-size: var(--cv-ui-font-size-sm);
    margin-top: 0.75rem;
}
.tk-table th[data-v-086e8199] {
    text-align: left;
    padding: 0.5rem 0.75rem;
    font-size: var(--cv-ui-font-size-xs);
    font-weight: var(--cv-ui-font-weight-semibold);
    color: var(--cv-ui-text-secondary);
    text-transform: uppercase;
    letter-spacing: 0.04em;
    background: var(--cv-ui-bg-tertiary);
    border-bottom: 1px solid var(--cv-ui-border-color);
}
.tk-table td[data-v-086e8199] {
    padding: 0.5rem 0.75rem;
    border-bottom: 1px solid var(--cv-ui-border-color);
    vertical-align: middle;
}
.tk-table tr:last-child td[data-v-086e8199] { border-bottom: none;
}
.tk-table tr:hover td[data-v-086e8199] { background: var(--cv-ui-bg-hover);
}
.tk-table__val[data-v-086e8199] {
    font-family: 'SFMono-Regular', Consolas, monospace;
    font-size: var(--cv-ui-font-size-xs);
    font-weight: var(--cv-ui-font-weight-semibold);
    color: var(--cv-ui-color-primary-dark);
}
.tk-table__usage[data-v-086e8199] {
    color: var(--cv-ui-text-secondary);
    font-size: var(--cv-ui-font-size-xs);
}

.cv-input-wrapper[data-v-4f420426] {
        width: 100%;
}
.cv-input-wrapper[data-v-4f420426]:has(.cv-input__leading),
    .cv-input-wrapper[data-v-4f420426]:has(.cv-input__trailing) {
        display: flex;
        align-items: stretch;
        gap: var(--cv-ui-spacing-sm);
}
.cv-input__field-wrap[data-v-4f420426] {
        position: relative;
        flex: 1;
        min-width: 0;
        display: flex;
        align-items: center;
}
.cv-input__field-wrap .cv-input[data-v-4f420426] {
        flex: 1;
}
.cv-input__leading[data-v-4f420426],
    .cv-input__trailing[data-v-4f420426] {
        display: inline-flex;
        align-items: center;
        color: var(--cv-ui-text-tertiary);
}
.cv-input__trailing[data-v-4f420426] {
        position: absolute;
        right: var(--cv-ui-spacing-md);
        pointer-events: none;
}

    /* When only trailing slot is present (no stepper) */
.cv-input__field-wrap:has(.cv-input__trailing):not(:has(.cv-input__stepper)) .cv-input[data-v-4f420426] {
        padding-right: 2.25rem;
}

    /* When stepper is present (with or without trailing slot) */
.cv-input__field-wrap:has(.cv-input__stepper) .cv-input[data-v-4f420426] {
        padding-right: 2.25rem;
}

    /* When both trailing and stepper are present, push trailing left of the stepper */
.cv-input__field-wrap:has(.cv-input__trailing):has(.cv-input__stepper) .cv-input[data-v-4f420426] {
        padding-right: 4rem;
}
.cv-input__field-wrap:has(.cv-input__trailing):has(.cv-input__stepper) .cv-input__trailing[data-v-4f420426] {
        right: calc(var(--cv-ui-spacing-xs) + 1.25rem + var(--cv-ui-spacing-xs));
}
.cv-input__stepper[data-v-4f420426] {
        position: absolute;
        right: var(--cv-ui-spacing-xs);
        top: 50%;
        transform: translateY(-50%);
        display: flex;
        flex-direction: column;
        gap: 1px;
        pointer-events: auto;
}
.cv-input__stepper-btn[data-v-4f420426] {
        display: flex;
        align-items: center;
        justify-content: center;
        width: 1.25rem;
        height: 0.875rem;
        padding: 0;
        font-size: 0.75rem;
        line-height: 1;
        font-weight: 600;
        color: var(--cv-ui-text-secondary);
        background: var(--cv-ui-bg-tertiary);
        border: none;
        border-radius: var(--cv-ui-radius-sm);
        cursor: pointer;
        transition: background-color var(--cv-ui-transition-fast) var(--cv-ui-transition-timing);
}
.cv-input__stepper-btn[data-v-4f420426]:hover:not(:disabled) {
        background: var(--cv-ui-border-color-hover);
        color: var(--cv-ui-text-primary);
}
.cv-input__stepper-btn[data-v-4f420426]:disabled {
        opacity: 0.5;
        cursor: not-allowed;
}
.cv-input[data-v-4f420426] {
        width: 100%;
        padding: var(--cv-ui-spacing-sm) var(--cv-ui-spacing-md);
        font-family: var(--cv-ui-font-family);
        font-size: var(--cv-ui-font-size-sm);
        font-weight: var(--cv-ui-font-weight-normal);
        color: var(--cv-ui-text-primary);
        background-color: var(--cv-ui-bg-primary);
        border: 1px solid var(--cv-ui-border-color);
        border-radius: var(--cv-ui-radius-md);
        box-shadow: var(--cv-ui-shadow-sm);
        transition:
            border-color var(--cv-ui-transition-fast) var(--cv-ui-transition-timing),
            box-shadow var(--cv-ui-transition-fast) var(--cv-ui-transition-timing);
        outline: none;
}
.cv-input[data-v-4f420426]::placeholder {
        color: var(--cv-ui-text-tertiary);
}
.cv-input[data-v-4f420426]:hover:not(.cv-input--disabled) {
        border-color: var(--cv-ui-border-color-hover);
}
.cv-input[data-v-4f420426]:focus {
        border-color: var(--cv-ui-border-color-focus);
        box-shadow: var(--cv-ui-shadow-focus);
}
.cv-input--disabled[data-v-4f420426] {
        opacity: 0.7;
        cursor: not-allowed;
        background-color: var(--cv-ui-bg-tertiary);
        color: var(--cv-ui-text-disabled);
}
.cv-input--error[data-v-4f420426] {
        border-color: var(--cv-ui-border-color-error);
}
.cv-input--error[data-v-4f420426]:focus {
        box-shadow: var(--cv-ui-shadow-focus-error);
}
.cv-input--success[data-v-4f420426] {
        border-color: var(--cv-ui-color-success);
}
.cv-input--textarea[data-v-4f420426] {
        min-height: 80px;
        resize: vertical;
}
.cv-input--sm[data-v-4f420426] {
        padding: var(--cv-ui-spacing-xs) var(--cv-ui-spacing-sm);
        font-size: var(--cv-ui-font-size-xs);
}
.cv-input--lg[data-v-4f420426] {
        padding: var(--cv-ui-spacing-md) var(--cv-ui-spacing-lg);
        font-size: var(--cv-ui-font-size-md);
}
.cv-input-feedback[data-v-4f420426] {
        margin-top: var(--cv-ui-spacing-xs);
        font-size: var(--cv-ui-font-size-xs);
}
.cv-input-feedback--error[data-v-4f420426] {
        color: var(--cv-ui-color-danger);
}
.cv-input-feedback--success[data-v-4f420426] {
        color: var(--cv-ui-color-success);
}

.cv-select-wrapper[data-v-cbb41418] {
        position: relative;
        width: 100%;
}
.cv-select-wrapper[data-v-cbb41418]:has(.cv-select__leading) {
        display: flex;
        align-items: stretch;
        gap: var(--cv-ui-spacing-sm);
}
.cv-select__field-wrap[data-v-cbb41418] {
        position: relative;
        flex: 1;
        min-width: 0;
}
.cv-select__leading[data-v-cbb41418],
    .cv-select__trailing[data-v-cbb41418] {
        display: inline-flex;
        align-items: center;
        color: var(--cv-ui-text-tertiary);
}
.cv-select__trailing[data-v-cbb41418] {
        position: absolute;
        right: var(--cv-ui-spacing-md);
        top: 50%;
        transform: translateY(-50%);
        pointer-events: none;
}
.cv-select__field-wrap:has(.cv-select__trailing) .cv-select[data-v-cbb41418],
    .cv-select__field-wrap:has(.cv-select__loader) .cv-select--trigger[data-v-cbb41418] {
        padding-right: 2.5rem;
}
.cv-select__value[data-v-cbb41418] {
        flex: 1;
        min-width: 0;
        text-align: left;
}
.cv-select__chevron[data-v-cbb41418] {
        flex-shrink: 0;
        width: 1rem;
        height: 1rem;
        margin-left: var(--cv-ui-spacing-xs);
        opacity: 0.7;
        transition: transform var(--cv-ui-transition-fast) var(--cv-ui-transition-timing);
        background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 16 16' fill='none'%3E%3Cpath d='M4 6l4 4 4-4' stroke='%2394a3b8' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") no-repeat center;
        background-size: 1rem 1rem;
}
.cv-select--trigger[data-v-cbb41418] {
        display: flex;
        align-items: center;
        justify-content: space-between;
        width: 100%;
        min-height: 2.25rem;
        padding: var(--cv-ui-spacing-sm) var(--cv-ui-spacing-md);
        font-family: var(--cv-ui-font-family);
        font-size: var(--cv-ui-font-size-sm);
        font-weight: var(--cv-ui-font-weight-normal);
        color: var(--cv-ui-text-primary);
        background-color: var(--cv-ui-bg-primary);
        border: 1px solid var(--cv-ui-border-color);
        border-radius: var(--cv-ui-radius-md);
        box-shadow: var(--cv-ui-shadow-sm);
        transition:
            border-color var(--cv-ui-transition-fast) var(--cv-ui-transition-timing),
            box-shadow var(--cv-ui-transition-fast) var(--cv-ui-transition-timing),
            background-color var(--cv-ui-transition-fast) var(--cv-ui-transition-timing);
        outline: none;
        cursor: pointer;
}
.cv-select--trigger.cv-select--open .cv-select__chevron[data-v-cbb41418] {
        transform: rotate(180deg);
}

    /* Native select (multiple only) */
.cv-select[data-v-cbb41418]:not(.cv-select--trigger) {
        --cv-select-chevron: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 16 16' fill='none'%3E%3Cpath d='M4 6l4 4 4-4' stroke='%2394a3b8' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
        width: 100%;
        min-height: 2.25rem;
        padding: var(--cv-ui-spacing-sm) 2.5rem var(--cv-ui-spacing-sm) var(--cv-ui-spacing-md);
        font-family: var(--cv-ui-font-family);
        font-size: var(--cv-ui-font-size-sm);
        font-weight: var(--cv-ui-font-weight-normal);
        color: var(--cv-ui-text-primary);
        background-color: var(--cv-ui-bg-primary);
        border: 1px solid var(--cv-ui-border-color);
        border-radius: var(--cv-ui-radius-md);
        box-shadow: var(--cv-ui-shadow-sm);
        transition:
            border-color var(--cv-ui-transition-fast) var(--cv-ui-transition-timing),
            box-shadow var(--cv-ui-transition-fast) var(--cv-ui-transition-timing),
            background-color var(--cv-ui-transition-fast) var(--cv-ui-transition-timing);
        outline: none;
        appearance: none;
        background-image: var(--cv-select-chevron);
        background-repeat: no-repeat;
        background-position: right var(--cv-ui-spacing-sm) center;
        background-size: 1rem 1rem;
        cursor: pointer;
}
.cv-select[data-v-cbb41418]:hover:not(.cv-select--disabled) {
        border-color: var(--cv-ui-border-color-hover);
        background-color: var(--cv-ui-bg-hover);
}
.cv-select[data-v-cbb41418]:focus {
        border-color: var(--cv-ui-border-color-focus);
        box-shadow: var(--cv-ui-shadow-focus);
}
.cv-select--disabled[data-v-cbb41418] {
        opacity: 0.7;
        cursor: not-allowed;
        background-color: var(--cv-ui-bg-tertiary);
        color: var(--cv-ui-text-disabled);
}
.cv-select--error[data-v-cbb41418] {
        border-color: var(--cv-ui-border-color-error);
}
.cv-select--error[data-v-cbb41418]:focus {
        box-shadow: var(--cv-ui-shadow-focus-error);
}
.cv-select--success[data-v-cbb41418] {
        border-color: var(--cv-ui-color-success);
}
.cv-select--sm[data-v-cbb41418] {
        min-height: 1.875rem;
        padding: var(--cv-ui-spacing-xs) 2rem var(--cv-ui-spacing-xs) var(--cv-ui-spacing-sm);
        font-size: var(--cv-ui-font-size-xs);
}
.cv-select--trigger.cv-select--sm[data-v-cbb41418] {
        padding: var(--cv-ui-spacing-xs) var(--cv-ui-spacing-sm);
}
.cv-select--lg[data-v-cbb41418] {
        min-height: 2.75rem;
        padding: var(--cv-ui-spacing-md) 2.75rem var(--cv-ui-spacing-md) var(--cv-ui-spacing-lg);
        font-size: var(--cv-ui-font-size-md);
}
.cv-select--trigger.cv-select--lg[data-v-cbb41418] {
        padding: var(--cv-ui-spacing-md) var(--cv-ui-spacing-lg);
}

    /* Custom dropdown panel (single select) */
.cv-select__dropdown[data-v-cbb41418] {
        position: fixed;
        z-index: var(--cv-ui-z-dropdown);
        max-height: 16rem;
        overflow-y: auto;
        padding: var(--cv-ui-spacing-xs);
        background: var(--cv-ui-bg-primary);
        border: 1px solid var(--cv-ui-border-color);
        border-radius: var(--cv-ui-radius-lg);
        box-shadow: var(--cv-ui-shadow-lg);
}
.cv-select__option[data-v-cbb41418] {
        display: flex;
        align-items: center;
        gap: var(--cv-ui-spacing-sm);
        width: 100%;
        padding: var(--cv-ui-spacing-sm) var(--cv-ui-spacing-md);
        font-family: var(--cv-ui-font-family);
        font-size: var(--cv-ui-font-size-sm);
        font-weight: var(--cv-ui-font-weight-normal);
        color: var(--cv-ui-text-primary);
        text-align: left;
        background: transparent;
        border: none;
        border-radius: var(--cv-ui-radius-md);
        cursor: pointer;
        transition: background-color var(--cv-ui-transition-fast) var(--cv-ui-transition-timing);
}
.cv-select__option-check[data-v-cbb41418] {
        flex-shrink: 0;
        display: inline-flex;
        align-items: center;
        justify-content: center;
        width: 1rem;
        height: 1rem;
        border: 1px solid var(--cv-ui-border-color);
        border-radius: var(--cv-ui-radius-sm);
        background: var(--cv-ui-bg-primary);
}
.cv-select__option--selected .cv-select__option-check[data-v-cbb41418] {
        background: var(--cv-ui-color-primary);
        border-color: var(--cv-ui-color-primary);
        color: var(--cv-ui-text-inverse);
}
.cv-select__option-check-icon[data-v-cbb41418] {
        font-size: 0.75rem;
        font-weight: bold;
        line-height: 1;
}
.cv-select__option[data-v-cbb41418]:hover {
        background-color: var(--cv-ui-bg-hover);
}
.cv-select__option--focused[data-v-cbb41418]:not(.cv-select__option--selected) {
        background-color: var(--cv-ui-bg-hover);
}
.cv-select__search[data-v-cbb41418] {
        padding: var(--cv-ui-spacing-xs);
        border-bottom: 1px solid var(--cv-ui-border-color);
        margin-bottom: var(--cv-ui-spacing-xs);
}
.cv-select__search-input[data-v-cbb41418] {
        width: 100%;
        padding: var(--cv-ui-spacing-xs) var(--cv-ui-spacing-sm);
        font-family: var(--cv-ui-font-family);
        font-size: var(--cv-ui-font-size-sm);
        color: var(--cv-ui-text-primary);
        background-color: var(--cv-ui-bg-secondary);
        border: 1px solid var(--cv-ui-border-color);
        border-radius: var(--cv-ui-radius-sm);
        outline: none;
        box-sizing: border-box;
        transition: border-color var(--cv-ui-transition-fast) var(--cv-ui-transition-timing);
}
.cv-select__search-input[data-v-cbb41418]:focus {
        border-color: var(--cv-ui-border-color-focus);
        box-shadow: var(--cv-ui-shadow-focus);
}
.cv-select__no-result[data-v-cbb41418] {
        padding: var(--cv-ui-spacing-sm) var(--cv-ui-spacing-md);
        font-size: var(--cv-ui-font-size-sm);
        color: var(--cv-ui-text-tertiary);
        text-align: center;
        margin: 0;
}
.cv-select__option--placeholder[data-v-cbb41418] {
        color: var(--cv-ui-text-tertiary);
}
.cv-select__option--selected[data-v-cbb41418],
    .cv-select__option--selected[data-v-cbb41418]:hover {
        background-color: var(--cv-ui-color-primary-light);
        color: var(--cv-ui-color-primary-dark);
        font-weight: var(--cv-ui-font-weight-medium);
}
.cv-select__option[data-v-cbb41418]:focus-visible {
        outline: none;
        background-color: var(--cv-ui-bg-hover);
        box-shadow: 0 0 0 2px var(--cv-ui-border-color-focus) inset;
}
.cv-select__loader[data-v-cbb41418] {
        position: absolute;
        right: var(--cv-ui-spacing-md);
        top: 50%;
        transform: translateY(-50%);
        display: inline-flex;
        align-items: center;
        justify-content: center;
        color: var(--cv-ui-text-tertiary);
        pointer-events: none;
}
.cv-select__spinner[data-v-cbb41418] {
        width: 1em;
        height: 1em;
        border: 2px solid currentColor;
        border-right-color: transparent;
        border-radius: 50%;
        animation: cv-select-spin-cbb41418 0.6s linear infinite;
}
@keyframes cv-select-spin-cbb41418 {
to {
            transform: rotate(360deg);
}
}
.cv-select__ellipsis[data-v-cbb41418] {
        font-size: 1.2em;
}
.cv-select-feedback[data-v-cbb41418] {
        margin-top: var(--cv-ui-spacing-xs);
        font-size: var(--cv-ui-font-size-xs);
}
.cv-select-feedback--error[data-v-cbb41418] {
        color: var(--cv-ui-color-danger);
}
.cv-select-feedback--success[data-v-cbb41418] {
        color: var(--cv-ui-color-success);
}

.cv-button[data-v-75f9db49] {
        position: relative;
        overflow: visible;
        display: inline-flex;
        align-items: center;
        justify-content: center;
        gap: var(--cv-ui-spacing-sm);
        font-family: var(--cv-ui-font-family);
        font-weight: var(--cv-ui-font-weight-medium);
        border-radius: var(--cv-ui-radius-md);
        border: 1px solid transparent;
        cursor: pointer;
        transition:
            background-color var(--cv-ui-transition-fast) var(--cv-ui-transition-timing),
            border-color var(--cv-ui-transition-fast) var(--cv-ui-transition-timing),
            color var(--cv-ui-transition-fast) var(--cv-ui-transition-timing),
            box-shadow var(--cv-ui-transition-fast) var(--cv-ui-transition-timing),
            transform 0.12s var(--cv-ui-transition-timing);
        outline: none;
}

    /* Onde en bordure au clic : anneau qui s'échappe du contour */
.cv-button[data-v-75f9db49]::after {
        content: '';
        position: absolute;
        inset: -2px;
        border-radius: inherit;
        border: 2px solid rgba(255, 255, 255, 0.7);
        background: transparent;
        transform: scale(1);
        opacity: 0;
        pointer-events: none;
}
.cv-button[data-v-75f9db49]:active:not(.cv-button--disabled):not(.cv-button--loading)::after {
        animation: cv-button-ring-75f9db49 0.5s ease-out forwards;
}
.cv-button[data-v-75f9db49]:active:not(.cv-button--disabled):not(.cv-button--loading) {
        transform: scale(0.97);
}
@keyframes cv-button-ring-75f9db49 {
0% {
            transform: scale(1);
            opacity: 0.9;
}
100% {
            transform: scale(1.12);
            opacity: 0;
}
}

    /* Bordure visible sur outline/subtle (couleur du bouton) */
.cv-button--outline.cv-button--primary[data-v-75f9db49]::after,
    .cv-button--subtle.cv-button--primary[data-v-75f9db49]::after {
        border-color: rgba(59, 130, 246, 0.6);
}
.cv-button--outline.cv-button--secondary[data-v-75f9db49]::after,
    .cv-button--subtle.cv-button--secondary[data-v-75f9db49]::after {
        border-color: rgba(107, 114, 128, 0.6);
}
.cv-button--outline.cv-button--danger[data-v-75f9db49]::after,
    .cv-button--subtle.cv-button--danger[data-v-75f9db49]::after {
        border-color: rgba(239, 68, 68, 0.6);
}
.cv-button--outline.cv-button--success[data-v-75f9db49]::after,
    .cv-button--subtle.cv-button--success[data-v-75f9db49]::after {
        border-color: rgba(16, 185, 129, 0.6);
}
.cv-button[data-v-75f9db49]:focus-visible {
        box-shadow: var(--cv-ui-shadow-focus);
}

    /* Sizes */
.cv-button--sm[data-v-75f9db49] {
        padding: var(--cv-ui-spacing-xs) var(--cv-ui-spacing-sm);
        font-size: var(--cv-ui-font-size-xs);
}
.cv-button--md[data-v-75f9db49] {
        padding: var(--cv-ui-spacing-sm) var(--cv-ui-spacing-md);
        font-size: var(--cv-ui-font-size-sm);
}
.cv-button--lg[data-v-75f9db49] {
        padding: var(--cv-ui-spacing-md) var(--cv-ui-spacing-lg);
        font-size: var(--cv-ui-font-size-md);
}

    /* Icon-only: override padding to be equal on all sides */
.cv-button--icon-only.cv-button--sm[data-v-75f9db49] {
        padding: var(--cv-ui-spacing-xs);
}
.cv-button--icon-only.cv-button--md[data-v-75f9db49] {
        padding: var(--cv-ui-spacing-sm);
}
.cv-button--icon-only.cv-button--lg[data-v-75f9db49] {
        padding: var(--cv-ui-spacing-md);
}

    /* Icon slot wrappers */
.cv-button__icon-leading[data-v-75f9db49],
    .cv-button__icon-trailing[data-v-75f9db49] {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        flex-shrink: 0;
        width: 1em;
        height: 1em;
}

    /* Solid + Primary */
.cv-button--solid.cv-button--primary[data-v-75f9db49] {
        background-color: var(--cv-ui-color-primary);
        color: var(--cv-ui-text-inverse);
        border-color: var(--cv-ui-color-primary);
}
.cv-button--solid.cv-button--primary[data-v-75f9db49]:hover:not(.cv-button--disabled) {
        background-color: var(--cv-ui-color-primary-hover);
        border-color: var(--cv-ui-color-primary-hover);
}

    /* Solid + Secondary */
.cv-button--solid.cv-button--secondary[data-v-75f9db49] {
        background-color: var(--cv-ui-color-secondary);
        color: var(--cv-ui-text-inverse);
        border-color: var(--cv-ui-color-secondary);
}
.cv-button--solid.cv-button--secondary[data-v-75f9db49]:hover:not(.cv-button--disabled) {
        background-color: var(--cv-ui-color-secondary-hover);
        border-color: var(--cv-ui-color-secondary-hover);
}

    /* Solid + Danger */
.cv-button--solid.cv-button--danger[data-v-75f9db49] {
        background-color: var(--cv-ui-color-danger);
        color: var(--cv-ui-text-inverse);
        border-color: var(--cv-ui-color-danger);
}
.cv-button--solid.cv-button--danger[data-v-75f9db49]:hover:not(.cv-button--disabled) {
        background-color: var(--cv-ui-color-danger-hover);
        border-color: var(--cv-ui-color-danger-hover);
}

    /* Solid + Success */
.cv-button--solid.cv-button--success[data-v-75f9db49] {
        background-color: var(--cv-ui-color-success);
        color: var(--cv-ui-text-inverse);
        border-color: var(--cv-ui-color-success);
}
.cv-button--solid.cv-button--success[data-v-75f9db49]:hover:not(.cv-button--disabled) {
        background-color: var(--cv-ui-color-success-hover);
        border-color: var(--cv-ui-color-success-hover);
}

    /* Outline + Primary */
.cv-button--outline.cv-button--primary[data-v-75f9db49] {
        background-color: transparent;
        color: var(--cv-ui-color-primary);
        border-color: var(--cv-ui-color-primary);
}
.cv-button--outline.cv-button--primary[data-v-75f9db49]:hover:not(.cv-button--disabled) {
        background-color: var(--cv-ui-color-primary-light);
}

    /* Outline + Secondary */
.cv-button--outline.cv-button--secondary[data-v-75f9db49] {
        background-color: transparent;
        color: var(--cv-ui-color-secondary);
        border-color: var(--cv-ui-border-color);
}
.cv-button--outline.cv-button--secondary[data-v-75f9db49]:hover:not(.cv-button--disabled) {
        background-color: var(--cv-ui-bg-hover);
        border-color: var(--cv-ui-border-color-hover);
}

    /* Outline + Danger */
.cv-button--outline.cv-button--danger[data-v-75f9db49] {
        background-color: transparent;
        color: var(--cv-ui-color-danger);
        border-color: var(--cv-ui-color-danger);
}
.cv-button--outline.cv-button--danger[data-v-75f9db49]:hover:not(.cv-button--disabled) {
        background-color: var(--cv-ui-color-danger-light);
}

    /* Outline + Success */
.cv-button--outline.cv-button--success[data-v-75f9db49] {
        background-color: transparent;
        color: var(--cv-ui-color-success);
        border-color: var(--cv-ui-color-success);
}
.cv-button--outline.cv-button--success[data-v-75f9db49]:hover:not(.cv-button--disabled) {
        background-color: var(--cv-ui-color-success-light);
}

    /* Subtle + Primary */
.cv-button--subtle.cv-button--primary[data-v-75f9db49] {
        background-color: var(--cv-ui-color-primary-light);
        color: var(--cv-ui-color-primary-dark);
        border-color: transparent;
}
.cv-button--subtle.cv-button--primary[data-v-75f9db49]:hover:not(.cv-button--disabled) {
        background-color: var(--cv-ui-color-primary);
        color: var(--cv-ui-text-inverse);
}

    /* Subtle + Secondary */
.cv-button--subtle.cv-button--secondary[data-v-75f9db49] {
        background-color: var(--cv-ui-bg-tertiary);
        color: var(--cv-ui-text-primary);
        border-color: transparent;
}
.cv-button--subtle.cv-button--secondary[data-v-75f9db49]:hover:not(.cv-button--disabled) {
        background-color: var(--cv-ui-bg-active);
}

    /* Subtle + Danger */
.cv-button--subtle.cv-button--danger[data-v-75f9db49] {
        background-color: var(--cv-ui-color-danger-light);
        color: var(--cv-ui-color-danger-dark);
        border-color: transparent;
}
.cv-button--subtle.cv-button--danger[data-v-75f9db49]:hover:not(.cv-button--disabled) {
        background-color: var(--cv-ui-color-danger);
        color: var(--cv-ui-text-inverse);
}

    /* Subtle + Success */
.cv-button--subtle.cv-button--success[data-v-75f9db49] {
        background-color: var(--cv-ui-color-success-light);
        color: var(--cv-ui-color-success-dark);
        border-color: transparent;
}
.cv-button--subtle.cv-button--success[data-v-75f9db49]:hover:not(.cv-button--disabled) {
        background-color: var(--cv-ui-color-success);
        color: var(--cv-ui-text-inverse);
}
.cv-button--disabled[data-v-75f9db49],
    .cv-button--loading[data-v-75f9db49] {
        opacity: 0.6;
        cursor: not-allowed;
}
.cv-button__loader[data-v-75f9db49] {
        display: inline-flex;
        align-items: center;
        justify-content: center;
}
.cv-button__spinner[data-v-75f9db49] {
        width: 1em;
        height: 1em;
        border: 2px solid currentColor;
        border-right-color: transparent;
        border-radius: 50%;
        animation: cv-button-spin-75f9db49 0.6s linear infinite;
}
@keyframes cv-button-spin-75f9db49 {
to {
            transform: rotate(360deg);
}
}
.cv-button__ellipsis[data-v-75f9db49] {
        font-size: 1.2em;
}
.cv-button__status-icon[data-v-75f9db49] {
        margin-right: var(--cv-ui-spacing-xs);
        font-size: 1em;
        line-height: 1;
}
.cv-button__status-icon--success[data-v-75f9db49] {
        color: inherit;
}
.cv-button__status-icon--error[data-v-75f9db49] {
        color: inherit;
}

    /* Status overrides: reflect success/error visually while keeping variant */
.cv-button--status-success.cv-button--solid[data-v-75f9db49] {
        background-color: var(--cv-ui-color-success);
        color: var(--cv-ui-text-inverse);
        border-color: var(--cv-ui-color-success);
}
.cv-button--status-success.cv-button--outline[data-v-75f9db49],
    .cv-button--status-success.cv-button--subtle[data-v-75f9db49] {
        color: var(--cv-ui-color-success);
        border-color: var(--cv-ui-color-success);
}
.cv-button--status-success.cv-button--subtle[data-v-75f9db49] {
        background-color: var(--cv-ui-color-success-light);
}
.cv-button--status-error.cv-button--solid[data-v-75f9db49] {
        background-color: var(--cv-ui-color-danger);
        color: var(--cv-ui-text-inverse);
        border-color: var(--cv-ui-color-danger);
}
.cv-button--status-error.cv-button--outline[data-v-75f9db49],
    .cv-button--status-error.cv-button--subtle[data-v-75f9db49] {
        color: var(--cv-ui-color-danger);
        border-color: var(--cv-ui-color-danger);
}
.cv-button--status-error.cv-button--subtle[data-v-75f9db49] {
        background-color: var(--cv-ui-color-danger-light);
}

.cv-checkbox[data-v-04d469db] {
        display: inline-flex;
        align-items: center;
        gap: var(--cv-ui-spacing-sm);
        font-family: var(--cv-ui-font-family);
        font-size: var(--cv-ui-font-size-sm);
        color: var(--cv-ui-text-primary);
        cursor: pointer;
        user-select: none;
}
.cv-checkbox--disabled[data-v-04d469db] {
        opacity: 0.6;
        cursor: not-allowed;
}
.cv-checkbox__input[data-v-04d469db] {
        position: absolute;
        width: 0;
        height: 0;
        opacity: 0;
        pointer-events: none;
}
.cv-checkbox__box[data-v-04d469db] {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        width: 18px;
        height: 18px;
        flex-shrink: 0;
        border: 2px solid var(--cv-ui-border-color);
        border-radius: var(--cv-ui-radius-sm);
        background-color: var(--cv-ui-bg-primary);
        transition:
            border-color var(--cv-ui-transition-fast) var(--cv-ui-transition-timing),
            background-color var(--cv-ui-transition-fast) var(--cv-ui-transition-timing),
            box-shadow var(--cv-ui-transition-fast) var(--cv-ui-transition-timing);
}
.cv-checkbox:hover:not(.cv-checkbox--disabled) .cv-checkbox__box[data-v-04d469db] {
        border-color: var(--cv-ui-border-color-hover);
}
.cv-checkbox__input:focus-visible + .cv-checkbox__box[data-v-04d469db] {
        border-color: var(--cv-ui-border-color-focus);
        box-shadow: var(--cv-ui-shadow-focus);
}
.cv-checkbox__input:checked + .cv-checkbox__box[data-v-04d469db],
    .cv-checkbox__input:indeterminate + .cv-checkbox__box[data-v-04d469db] {
        background-color: var(--cv-ui-color-primary);
        border-color: var(--cv-ui-color-primary);
}
.cv-checkbox__check[data-v-04d469db],
    .cv-checkbox__indeterminate[data-v-04d469db] {
        color: var(--cv-ui-text-inverse);
        font-size: 12px;
        font-weight: bold;
        line-height: 1;
}
.cv-checkbox--error .cv-checkbox__box[data-v-04d469db] {
        border-color: var(--cv-ui-border-color-error);
}
.cv-checkbox--success .cv-checkbox__box[data-v-04d469db] {
        border-color: var(--cv-ui-color-success);
}
.cv-checkbox__label[data-v-04d469db] {
        flex: 1;
        min-width: 0;
}
.cv-checkbox-feedback[data-v-04d469db] {
        margin-top: var(--cv-ui-spacing-xs);
        margin-left: 0;
        font-size: var(--cv-ui-font-size-xs);
}
.cv-checkbox-feedback--error[data-v-04d469db] {
        color: var(--cv-ui-color-danger);
}
.cv-checkbox-feedback--success[data-v-04d469db] {
        color: var(--cv-ui-color-success);
}
.cv-checkbox--sm[data-v-04d469db] {
        font-size: var(--cv-ui-font-size-xs);
}
.cv-checkbox--sm .cv-checkbox__box[data-v-04d469db] {
        width: 16px;
        height: 16px;
}
.cv-checkbox--lg[data-v-04d469db] {
        font-size: var(--cv-ui-font-size-md);
}
.cv-checkbox--lg .cv-checkbox__box[data-v-04d469db] {
        width: 20px;
        height: 20px;
}
.cv-checkbox--lg .cv-checkbox__check[data-v-04d469db],
    .cv-checkbox--lg .cv-checkbox__indeterminate[data-v-04d469db] {
        font-size: 14px;
}

.cv-switch[data-v-09e5313a] {
        display: inline-flex;
        align-items: center;
        gap: var(--cv-ui-spacing-sm);
        font-family: var(--cv-ui-font-family);
        font-size: var(--cv-ui-font-size-sm);
        color: var(--cv-ui-text-primary);
        cursor: pointer;
        user-select: none;
}
.cv-switch--disabled[data-v-09e5313a] {
        opacity: 0.6;
        cursor: not-allowed;
}
.cv-switch__input[data-v-09e5313a] {
        position: absolute;
        width: 0;
        height: 0;
        opacity: 0;
        pointer-events: none;
}
.cv-switch__track[data-v-09e5313a] {
        position: relative;
        width: 40px;
        height: 22px;
        flex-shrink: 0;
        border-radius: var(--cv-ui-radius-full);
        background-color: var(--cv-ui-border-color);
        transition: background-color var(--cv-ui-transition-fast) var(--cv-ui-transition-timing);
}
.cv-switch:hover:not(.cv-switch--disabled) .cv-switch__track[data-v-09e5313a] {
        background-color: var(--cv-ui-border-color-hover);
}
.cv-switch__input:focus-visible + .cv-switch__track[data-v-09e5313a] {
        box-shadow: var(--cv-ui-shadow-focus);
}
.cv-switch--checked .cv-switch__track[data-v-09e5313a] {
        background-color: var(--cv-ui-color-primary);
}
.cv-switch--checked:hover:not(.cv-switch--disabled) .cv-switch__track[data-v-09e5313a] {
        background-color: var(--cv-ui-color-primary-hover);
}
.cv-switch__thumb[data-v-09e5313a] {
        position: absolute;
        top: 2px;
        left: 2px;
        width: 18px;
        height: 18px;
        border-radius: var(--cv-ui-radius-full);
        background-color: var(--cv-ui-bg-primary);
        box-shadow: var(--cv-ui-shadow-sm);
        transition: transform var(--cv-ui-transition-fast) var(--cv-ui-transition-timing);
}
.cv-switch--checked .cv-switch__thumb[data-v-09e5313a] {
        transform: translateX(18px);
}
.cv-switch--error .cv-switch__track[data-v-09e5313a] {
        box-shadow: 0 0 0 2px var(--cv-ui-color-danger);
}
.cv-switch--success .cv-switch__track[data-v-09e5313a] {
        box-shadow: 0 0 0 2px var(--cv-ui-color-success);
}
.cv-switch__label[data-v-09e5313a] {
        flex: 1;
        min-width: 0;
}
.cv-switch-feedback[data-v-09e5313a] {
        margin-top: var(--cv-ui-spacing-xs);
        margin-left: 0;
        font-size: var(--cv-ui-font-size-xs);
}
.cv-switch-feedback--error[data-v-09e5313a] {
        color: var(--cv-ui-color-danger);
}
.cv-switch-feedback--success[data-v-09e5313a] {
        color: var(--cv-ui-color-success);
}
.cv-switch--sm[data-v-09e5313a] {
        font-size: var(--cv-ui-font-size-xs);
}
.cv-switch--sm .cv-switch__track[data-v-09e5313a] {
        width: 32px;
        height: 18px;
}
.cv-switch--sm .cv-switch__thumb[data-v-09e5313a] {
        width: 14px;
        height: 14px;
}
.cv-switch--sm.cv-switch--checked .cv-switch__thumb[data-v-09e5313a] {
        transform: translateX(14px);
}
.cv-switch--lg[data-v-09e5313a] {
        font-size: var(--cv-ui-font-size-md);
}
.cv-switch--lg .cv-switch__track[data-v-09e5313a] {
        width: 48px;
        height: 26px;
}
.cv-switch--lg .cv-switch__thumb[data-v-09e5313a] {
        width: 22px;
        height: 22px;
        top: 2px;
        left: 2px;
}
.cv-switch--lg.cv-switch--checked .cv-switch__thumb[data-v-09e5313a] {
        transform: translateX(22px);
}

.cv-radio[data-v-ff520bc5] {
        display: inline-flex;
        align-items: center;
        gap: var(--cv-ui-spacing-sm);
        font-family: var(--cv-ui-font-family);
        font-size: var(--cv-ui-font-size-sm);
        color: var(--cv-ui-text-primary);
        cursor: pointer;
        user-select: none;
}
.cv-radio--disabled[data-v-ff520bc5] {
        opacity: 0.6;
        cursor: not-allowed;
}
.cv-radio__input[data-v-ff520bc5] {
        position: absolute;
        width: 0;
        height: 0;
        opacity: 0;
        pointer-events: none;
}
.cv-radio__circle[data-v-ff520bc5] {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        width: 18px;
        height: 18px;
        flex-shrink: 0;
        border: 2px solid var(--cv-ui-border-color);
        border-radius: var(--cv-ui-radius-full);
        background-color: var(--cv-ui-bg-primary);
        transition:
            border-color var(--cv-ui-transition-fast) var(--cv-ui-transition-timing),
            box-shadow var(--cv-ui-transition-fast) var(--cv-ui-transition-timing);
}
.cv-radio:not(.cv-radio--disabled):hover .cv-radio__circle[data-v-ff520bc5] {
        border-color: var(--cv-ui-border-color-hover);
}
.cv-radio__input:focus-visible + .cv-radio__circle[data-v-ff520bc5] {
        border-color: var(--cv-ui-border-color-focus);
        box-shadow: var(--cv-ui-shadow-focus);
}
.cv-radio--checked .cv-radio__circle[data-v-ff520bc5] {
        border-color: var(--cv-ui-color-primary);
        background-color: var(--cv-ui-bg-primary);
}
.cv-radio__dot[data-v-ff520bc5] {
        width: 8px;
        height: 8px;
        border-radius: var(--cv-ui-radius-full);
        background-color: var(--cv-ui-color-primary);
}
.cv-radio__label[data-v-ff520bc5] {
        flex: 1;
        min-width: 0;
}
.cv-radio--sm[data-v-ff520bc5] {
        font-size: var(--cv-ui-font-size-xs);
}
.cv-radio--sm .cv-radio__circle[data-v-ff520bc5] {
        width: 16px;
        height: 16px;
}
.cv-radio--sm .cv-radio__dot[data-v-ff520bc5] {
        width: 6px;
        height: 6px;
}
.cv-radio--lg[data-v-ff520bc5] {
        font-size: var(--cv-ui-font-size-md);
}
.cv-radio--lg .cv-radio__circle[data-v-ff520bc5] {
        width: 20px;
        height: 20px;
}
.cv-radio--lg .cv-radio__dot[data-v-ff520bc5] {
        width: 10px;
        height: 10px;
}

.cv-radio-group[data-v-29bbb346] {
        display: flex;
        flex-direction: column;
        gap: var(--cv-ui-spacing-sm);
}
.cv-radio-group__feedback[data-v-29bbb346] {
        margin-top: var(--cv-ui-spacing-xs);
        font-size: var(--cv-ui-font-size-xs);
}
.cv-radio-group__feedback--error[data-v-29bbb346] {
        color: var(--cv-ui-color-danger);
}
.cv-radio-group__feedback--success[data-v-29bbb346] {
        color: var(--cv-ui-color-success);
}

.cv-tag[data-v-f5c31d0c] {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        font-family: var(--cv-ui-font-family);
        font-weight: var(--cv-ui-font-weight-medium);
        white-space: nowrap;
}
.cv-tag--tag[data-v-f5c31d0c] {
        padding: var(--cv-ui-spacing-xs) var(--cv-ui-spacing-sm);
        border-radius: var(--cv-ui-radius-md);
}
.cv-tag--badge[data-v-f5c31d0c] {
        padding: var(--cv-ui-spacing-xs) var(--cv-ui-spacing-sm);
        border-radius: var(--cv-ui-radius-full);
}
.cv-tag--sm[data-v-f5c31d0c] {
        font-size: var(--cv-ui-font-size-xs);
}
.cv-tag--sm.cv-tag--tag[data-v-f5c31d0c] {
        padding: 2px var(--cv-ui-spacing-xs);
}
.cv-tag--sm.cv-tag--badge[data-v-f5c31d0c] {
        padding: 2px var(--cv-ui-spacing-sm);
}
.cv-tag--md[data-v-f5c31d0c] {
        font-size: var(--cv-ui-font-size-sm);
}
.cv-tag--lg[data-v-f5c31d0c] {
        font-size: var(--cv-ui-font-size-md);
}
.cv-tag--primary[data-v-f5c31d0c] {
        background-color: var(--cv-ui-color-primary-light);
        color: var(--cv-ui-color-primary-dark);
}
.cv-tag--success[data-v-f5c31d0c] {
        background-color: var(--cv-ui-color-success-light);
        color: var(--cv-ui-color-success-dark);
}
.cv-tag--warning[data-v-f5c31d0c] {
        background-color: var(--cv-ui-color-warning-light);
        color: var(--cv-ui-color-warning-dark);
}
.cv-tag--danger[data-v-f5c31d0c] {
        background-color: var(--cv-ui-color-danger-light);
        color: var(--cv-ui-color-danger-dark);
}
.cv-tag--neutral[data-v-f5c31d0c] {
        background-color: var(--cv-ui-bg-tertiary);
        color: var(--cv-ui-text-secondary);
}

    /* Icon slots */
.cv-tag__icon[data-v-f5c31d0c] {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        flex-shrink: 0;
        width: 1em;
        height: 1em;
}
.cv-tag__icon--leading[data-v-f5c31d0c] {
        margin-right: var(--cv-ui-spacing-xs);
}
.cv-tag__icon--trailing[data-v-f5c31d0c] {
        margin-left: var(--cv-ui-spacing-xs);
}

    /* Close button */
.cv-tag__close[data-v-f5c31d0c] {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        margin-left: var(--cv-ui-spacing-xs);
        padding: 0;
        width: 1em;
        height: 1em;
        border: none;
        border-radius: var(--cv-ui-radius-sm);
        background: transparent;
        color: inherit;
        cursor: pointer;
        opacity: 0.7;
        line-height: 1;
        flex-shrink: 0;
        transition: opacity var(--cv-ui-transition-fast) var(--cv-ui-transition-timing);
}
.cv-tag__close[data-v-f5c31d0c]:hover {
        opacity: 1;
}
.cv-tag__close[data-v-f5c31d0c]:focus-visible {
        outline: 2px solid currentColor;
        outline-offset: 2px;
}
.cv-tag__close-icon[data-v-f5c31d0c] {
        width: 0.75em;
        height: 0.75em;
        display: block;
}

.cv-modal-backdrop[data-v-25e025a4] {
        position: fixed;
        inset: 0;
        z-index: var(--cv-ui-z-modal-backdrop);
        display: flex;
        align-items: center;
        justify-content: center;
        padding: var(--cv-ui-spacing-lg);
        background-color: rgba(0, 0, 0, 0.5);
        overflow-y: auto;
}
.cv-modal-panel[data-v-25e025a4] {
        z-index: var(--cv-ui-z-modal);
        width: 100%;
        max-width: 28rem;
        max-height: calc(100vh - 2 * var(--cv-ui-spacing-lg));
        display: flex;
        flex-direction: column;
        background-color: var(--cv-ui-bg-primary);
        border-radius: var(--cv-ui-radius-lg);
        box-shadow: var(--cv-ui-shadow-xl);
        margin: auto;
}
.cv-modal-header[data-v-25e025a4] {
        flex-shrink: 0;
        display: flex;
        align-items: center;
        gap: var(--cv-ui-spacing-sm);
        padding: var(--cv-ui-spacing-md) var(--cv-ui-spacing-lg);
        border-bottom: 1px solid var(--cv-ui-border-color);
}
.cv-modal-close[data-v-25e025a4] {
        flex-shrink: 0;
        display: inline-flex;
        align-items: center;
        justify-content: center;
        width: 1.75rem;
        height: 1.75rem;
        padding: 0;
        margin-left: auto;
        border: none;
        border-radius: var(--cv-ui-radius-sm);
        background: transparent;
        cursor: pointer;
        color: var(--cv-ui-text-secondary);
        transition: background-color var(--cv-ui-transition-fast) var(--cv-ui-transition-timing),
            color var(--cv-ui-transition-fast) var(--cv-ui-transition-timing);
}
.cv-modal-close[data-v-25e025a4]:hover {
        background-color: var(--cv-ui-bg-secondary);
        color: var(--cv-ui-text-primary);
}
.cv-modal-close[data-v-25e025a4]:focus-visible {
        outline: none;
        box-shadow: var(--cv-ui-shadow-focus);
}
.cv-modal-close-icon[data-v-25e025a4] {
        width: 1rem;
        height: 1rem;
        pointer-events: none;
}
.cv-modal-title[data-v-25e025a4] {
        font-family: var(--cv-ui-font-family);
        font-size: var(--cv-ui-font-size-md);
        font-weight: var(--cv-ui-font-weight-semibold);
        color: var(--cv-ui-text-primary);
}
.cv-modal-body[data-v-25e025a4] {
        flex: 1;
        padding: var(--cv-ui-spacing-lg);
        overflow-y: auto;
        font-family: var(--cv-ui-font-family);
        font-size: var(--cv-ui-font-size-sm);
        color: var(--cv-ui-text-primary);
}
.cv-modal-footer[data-v-25e025a4] {
        flex-shrink: 0;
        padding: var(--cv-ui-spacing-md) var(--cv-ui-spacing-lg);
        border-top: 1px solid var(--cv-ui-border-color);
        display: flex;
        justify-content: flex-end;
        gap: var(--cv-ui-spacing-sm);
}
.cv-modal-fade-enter-active[data-v-25e025a4],
    .cv-modal-fade-leave-active[data-v-25e025a4] {
        transition: opacity var(--cv-ui-transition-base) var(--cv-ui-transition-timing);
}
.cv-modal-fade-enter-from[data-v-25e025a4],
    .cv-modal-fade-leave-to[data-v-25e025a4] {
        opacity: 0;
}
.cv-modal-fade-enter-active .cv-modal-panel[data-v-25e025a4],
    .cv-modal-fade-leave-active .cv-modal-panel[data-v-25e025a4] {
        transition: transform var(--cv-ui-transition-base) var(--cv-ui-transition-timing);
}
.cv-modal-fade-enter-from .cv-modal-panel[data-v-25e025a4],
    .cv-modal-fade-leave-to .cv-modal-panel[data-v-25e025a4] {
        transform: scale(0.96);
}

.cv-dialog-host__content[data-v-a79064ce] {
        margin: 0;
        white-space: pre-wrap;
}

.cv-toast[data-v-1d773c77] {
        position: relative;
        display: inline-flex;
        align-items: center;
        gap: var(--cv-ui-spacing-sm);
        padding: var(--cv-ui-spacing-sm) var(--cv-ui-spacing-md);
        border-radius: var(--cv-ui-radius-md);
        font-family: var(--cv-ui-font-family);
        font-size: var(--cv-ui-font-size-sm);
        font-weight: var(--cv-ui-font-weight-medium);
        box-shadow: var(--cv-ui-shadow-md);
        min-width: 200px;
        max-width: 420px;
        overflow: hidden;
}

    /* Extra bottom padding when progress bar is shown */
.cv-toast--has-progress[data-v-1d773c77] {
        padding-bottom: calc(var(--cv-ui-spacing-sm) + 3px);
}

    /* Generous box so vue3-icons circle SVGs (and inner glyphs i / !) are never clipped */
.cv-toast__icon[data-v-1d773c77] {
        flex-shrink: 0;
        width: 32px;
        height: 32px;
        min-width: 32px;
        min-height: 32px;
        display: inline-flex;
        align-items: center;
        justify-content: center;
        overflow: visible;
        line-height: 0;
}

    /* Let SVG fill container so viewBox scales fully; no fixed 24px to avoid clipping inner paths */
.cv-toast__icon-svg[data-v-1d773c77],
    .cv-toast__icon[data-v-1d773c77] svg {
        display: block;
        width: 100%;
        height: 100%;
        flex-shrink: 0;
        overflow: visible;
}
.cv-toast__close-icon[data-v-1d773c77] {
        width: 1rem;
        height: 1rem;
}
.cv-toast__message[data-v-1d773c77] {
        flex: 1;
        min-width: 0;
}

    /* Action button */
.cv-toast__action[data-v-1d773c77] {
        flex-shrink: 0;
        display: inline-flex;
        align-items: center;
        justify-content: center;
        padding: 2px var(--cv-ui-spacing-sm);
        border: 1px solid currentColor;
        border-radius: var(--cv-ui-radius-sm);
        background: transparent;
        color: inherit;
        font-family: inherit;
        font-size: var(--cv-ui-font-size-xs);
        font-weight: var(--cv-ui-font-weight-medium);
        cursor: pointer;
        opacity: 0.85;
        white-space: nowrap;
        transition: opacity var(--cv-ui-transition-fast) var(--cv-ui-transition-timing);
}
.cv-toast__action[data-v-1d773c77]:hover {
        opacity: 1;
}
.cv-toast__action[data-v-1d773c77]:focus-visible {
        outline: 2px solid currentColor;
        outline-offset: 2px;
}
.cv-toast__close[data-v-1d773c77] {
        flex-shrink: 0;
        display: inline-flex;
        align-items: center;
        justify-content: center;
        width: 1.5rem;
        height: 1.5rem;
        padding: 0;
        border: none;
        border-radius: var(--cv-ui-radius-sm);
        background: transparent;
        cursor: pointer;
        opacity: 0.8;
        transition: opacity var(--cv-ui-transition-fast) var(--cv-ui-transition-timing);
}
.cv-toast__close[data-v-1d773c77]:hover {
        opacity: 1;
}
.cv-toast__close[data-v-1d773c77]:focus-visible {
        outline: 2px solid currentColor;
        outline-offset: 2px;
}

    /* Progress bar */
.cv-toast__progress[data-v-1d773c77] {
        position: absolute;
        bottom: 0;
        left: 0;
        height: 3px;
        width: 100%;
        background-color: currentColor;
        opacity: 0.35;
        transform-origin: left center;
        animation: cv-toast-progress-1d773c77 linear forwards;
}
@keyframes cv-toast-progress-1d773c77 {
from {
            width: 100%;
}
to {
            width: 0%;
}
}

    /* Severity styles */
.cv-toast--neutral[data-v-1d773c77] {
        background-color: var(--cv-ui-bg-primary);
        color: var(--cv-ui-text-primary);
        border: 1px solid var(--cv-ui-border-color);
}
.cv-toast--neutral .cv-toast__close[data-v-1d773c77]:hover {
        background-color: var(--cv-ui-bg-hover);
}
.cv-toast--success[data-v-1d773c77] {
        background-color: var(--cv-ui-color-success-light);
        color: var(--cv-ui-color-success-dark);
}
.cv-toast--success .cv-toast__icon-svg[data-v-1d773c77] {
        color: var(--cv-ui-color-success-dark);
}
.cv-toast--warning[data-v-1d773c77] {
        background-color: var(--cv-ui-color-warning-light);
        color: var(--cv-ui-color-warning-dark);
}
.cv-toast--warning .cv-toast__icon-svg[data-v-1d773c77] {
        color: var(--cv-ui-color-warning-dark);
}
.cv-toast--danger[data-v-1d773c77] {
        background-color: var(--cv-ui-color-danger-light);
        color: var(--cv-ui-color-danger-dark);
}
.cv-toast--danger .cv-toast__icon-svg[data-v-1d773c77] {
        color: var(--cv-ui-color-danger-dark);
}
.cv-toast--info[data-v-1d773c77] {
        background-color: var(--cv-ui-color-info-light);
        color: var(--cv-ui-color-info-dark);
}
.cv-toast--info .cv-toast__icon-svg[data-v-1d773c77] {
        color: var(--cv-ui-color-info-dark);
}

.cv-toast-host[data-v-e1658faf] {
        position: fixed;
        z-index: var(--cv-ui-z-toast);
        display: flex;
        flex-direction: column;
        gap: var(--cv-ui-spacing-sm);
        pointer-events: none;
}
.cv-toast-host--top-right[data-v-e1658faf] {
        top: var(--cv-ui-spacing-md);
        right: var(--cv-ui-spacing-md);
        align-items: flex-end;
}
.cv-toast-host--top-left[data-v-e1658faf] {
        top: var(--cv-ui-spacing-md);
        left: var(--cv-ui-spacing-md);
        align-items: flex-start;
}
.cv-toast-host--top-center[data-v-e1658faf] {
        top: var(--cv-ui-spacing-md);
        left: 50%;
        transform: translateX(-50%);
        align-items: center;
}
.cv-toast-host--bottom-right[data-v-e1658faf] {
        bottom: var(--cv-ui-spacing-md);
        right: var(--cv-ui-spacing-md);
        align-items: flex-end;
}
.cv-toast-host--bottom-left[data-v-e1658faf] {
        bottom: var(--cv-ui-spacing-md);
        left: var(--cv-ui-spacing-md);
        align-items: flex-start;
}
.cv-toast-host--bottom-center[data-v-e1658faf] {
        bottom: var(--cv-ui-spacing-md);
        left: 50%;
        transform: translateX(-50%);
        align-items: center;
}
.cv-toast-host__list[data-v-e1658faf] {
        display: flex;
        flex-direction: column;
        align-items: inherit;
        gap: var(--cv-ui-spacing-sm);
        pointer-events: auto;
}
.cv-toast-enter-active[data-v-e1658faf],
    .cv-toast-leave-active[data-v-e1658faf] {
        transition:
            transform var(--cv-ui-transition-base) var(--cv-ui-transition-timing),
            opacity var(--cv-ui-transition-base) var(--cv-ui-transition-timing);
}
.cv-toast-enter-from[data-v-e1658faf],
    .cv-toast-leave-to[data-v-e1658faf] {
        opacity: 0;
}
.cv-toast-host--top-right .cv-toast-enter-from[data-v-e1658faf],
    .cv-toast-host--top-right .cv-toast-leave-to[data-v-e1658faf],
    .cv-toast-host--bottom-right .cv-toast-enter-from[data-v-e1658faf],
    .cv-toast-host--bottom-right .cv-toast-leave-to[data-v-e1658faf] {
        transform: translateX(100%);
}
.cv-toast-host--top-left .cv-toast-enter-from[data-v-e1658faf],
    .cv-toast-host--top-left .cv-toast-leave-to[data-v-e1658faf],
    .cv-toast-host--bottom-left .cv-toast-enter-from[data-v-e1658faf],
    .cv-toast-host--bottom-left .cv-toast-leave-to[data-v-e1658faf] {
        transform: translateX(-100%);
}
.cv-toast-host--top-center .cv-toast-enter-from[data-v-e1658faf],
    .cv-toast-host--top-center .cv-toast-leave-to[data-v-e1658faf] {
        transform: translateY(-100%);
}
.cv-toast-host--bottom-center .cv-toast-enter-from[data-v-e1658faf],
    .cv-toast-host--bottom-center .cv-toast-leave-to[data-v-e1658faf] {
        transform: translateY(100%);
}
.cv-toast-move[data-v-e1658faf] {
        transition: transform var(--cv-ui-transition-base) var(--cv-ui-transition-timing);
}

.cv-spinner--wrapper[data-v-57ef680e] {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: var(--cv-spinner-size, 1.5rem);
    height: var(--cv-spinner-size, 1.5rem);
    --cv-spinner-color: var(--cv-ui-color-primary);
}
.cv-spinner--sm[data-v-57ef680e] {
    --cv-spinner-size: var(--cv-ui-spacing-md);
}
.cv-spinner--md[data-v-57ef680e] {
    --cv-spinner-size: var(--cv-ui-spacing-lg);
}
.cv-spinner--lg[data-v-57ef680e] {
    --cv-spinner-size: var(--cv-ui-spacing-xl);
}
.cv-spinner--primary[data-v-57ef680e] {
    --cv-spinner-color: var(--cv-ui-color-primary);
}
.cv-spinner--secondary[data-v-57ef680e] {
    --cv-spinner-color: var(--cv-ui-color-secondary);
}
.cv-spinner--success[data-v-57ef680e] {
    --cv-spinner-color: var(--cv-ui-color-success);
}
.cv-spinner--warning[data-v-57ef680e] {
    --cv-spinner-color: var(--cv-ui-color-warning);
}
.cv-spinner--danger[data-v-57ef680e] {
    --cv-spinner-color: var(--cv-ui-color-danger);
}
.cv-spinner--info[data-v-57ef680e] {
    --cv-spinner-color: var(--cv-ui-color-info);
}

/* ----- Ring ----- */
.cv-spinner__ring[data-v-57ef680e] {
    width: 100%;
    height: 100%;
    border: 2px solid transparent;
    border-right-color: var(--cv-spinner-color);
    border-radius: var(--cv-ui-radius-full);
    animation: cv-spinner-spin-57ef680e 0.6s linear infinite;
}

/* ----- Dots ----- */
.cv-spinner--dots[data-v-57ef680e] {
    gap: 20%;
}
.cv-spinner__dot[data-v-57ef680e] {
    width: 25%;
    height: 25%;
    min-width: 4px;
    min-height: 4px;
    background: var(--cv-spinner-color);
    border-radius: var(--cv-ui-radius-full);
    animation: cv-spinner-bounce-57ef680e 0.6s ease-in-out infinite;
}

/* ----- Pulse ----- */
.cv-spinner__pulse[data-v-57ef680e] {
    width: 70%;
    height: 70%;
    background: var(--cv-spinner-color);
    border-radius: var(--cv-ui-radius-full);
    animation: cv-spinner-pulse-57ef680e 1s ease-in-out infinite;
}

/* ----- Bars ----- */
.cv-spinner--bars[data-v-57ef680e] {
    gap: 15%;
}
.cv-spinner__bar[data-v-57ef680e] {
    width: 22%;
    min-width: 3px;
    height: 70%;
    background: var(--cv-spinner-color);
    border-radius: 2px;
    animation: cv-spinner-bar-57ef680e 0.8s ease-in-out infinite;
}

/* ----- Circle dots (orbital) ----- */
.cv-spinner__orbit[data-v-57ef680e] {
    position: relative;
    width: 100%;
    height: 100%;
    animation: cv-spinner-spin-57ef680e 1s linear infinite;
}
.cv-spinner__orb[data-v-57ef680e] {
    position: absolute;
    width: 28%;
    height: 28%;
    min-width: 4px;
    min-height: 4px;
    background: var(--cv-spinner-color);
    border-radius: var(--cv-ui-radius-full);
    top: 0;
    left: 50%;
    transform: translate(-50%, -50%);
}
.cv-spinner__orb[data-v-57ef680e]:nth-child(1) {
    top: 0;
    left: 50%;
}
.cv-spinner__orb[data-v-57ef680e]:nth-child(2) {
    top: 50%;
    right: 0;
    left: auto;
    transform: translate(50%, -50%);
}
.cv-spinner__orb[data-v-57ef680e]:nth-child(3) {
    top: 100%;
    left: 50%;
    transform: translate(-50%, -50%);
}
.cv-spinner__orb[data-v-57ef680e]:nth-child(4) {
    top: 50%;
    left: 0;
    transform: translate(-50%, -50%);
}
@keyframes cv-spinner-spin-57ef680e {
to {
        transform: rotate(360deg);
}
}
@keyframes cv-spinner-bounce-57ef680e {
0%,
    100% {
        transform: scale(0.6);
        opacity: 0.6;
}
50% {
        transform: scale(1);
        opacity: 1;
}
}
@keyframes cv-spinner-pulse-57ef680e {
0%,
    100% {
        transform: scale(0.7);
        opacity: 0.5;
}
50% {
        transform: scale(1);
        opacity: 1;
}
}
@keyframes cv-spinner-bar-57ef680e {
0%,
    100% {
        transform: scaleY(0.5);
}
50% {
        transform: scaleY(1);
}
}


.cv-popover[data-v-5e638730] {
    display: inline-block;
}
.cv-popover__trigger[data-v-5e638730] {
    display: inline-flex;
    cursor: pointer;
}
.cv-popover__panel[data-v-5e638730] {
    position: fixed;
    z-index: var(--cv-ui-z-popover);
    min-width: 8rem;
    max-width: 20rem;
    padding: var(--cv-ui-spacing-sm);
    background-color: var(--cv-ui-bg-primary);
    border: 1px solid var(--cv-ui-border-color);
    border-radius: var(--cv-ui-radius-md);
    box-shadow: var(--cv-ui-shadow-lg);
    font-family: var(--cv-ui-font-family);
    font-size: var(--cv-ui-font-size-sm);
    color: var(--cv-ui-text-primary);
}
.cv-popover__header[data-v-5e638730] {
    padding-bottom: var(--cv-ui-spacing-xs);
    margin-bottom: var(--cv-ui-spacing-xs);
    border-bottom: 1px solid var(--cv-ui-border-color);
}
.cv-popover__title[data-v-5e638730] {
    font-weight: var(--cv-ui-font-weight-semibold);
    color: var(--cv-ui-text-primary);
}
.cv-popover__body[data-v-5e638730] {
    color: var(--cv-ui-text-secondary);
}
.cv-popover-fade-enter-active[data-v-5e638730],
.cv-popover-fade-leave-active[data-v-5e638730] {
    transition: opacity var(--cv-ui-transition-fast) var(--cv-ui-transition-timing);
}
.cv-popover-fade-enter-from[data-v-5e638730],
.cv-popover-fade-leave-to[data-v-5e638730] {
    opacity: 0;
}

.cv-popconfirm__message[data-v-f2dbf27a] {
    margin: 0 0 var(--cv-ui-spacing-md) 0;
    font-size: var(--cv-ui-font-size-sm);
    color: var(--cv-ui-text-primary);
    line-height: 1.4;
}
.cv-popconfirm__actions[data-v-f2dbf27a] {
    display: flex;
    justify-content: flex-end;
    gap: var(--cv-ui-spacing-sm);
}

.cv-color-picker[data-v-f967d3b8] {
    display: inline-block;
}
.cv-color-picker__trigger[data-v-f967d3b8] {
    display: inline-flex;
    align-items: center;
    gap: var(--cv-ui-spacing-sm);
    padding: var(--cv-ui-spacing-xs);
    border: 1px solid var(--cv-ui-border-color);
    border-radius: var(--cv-ui-radius-md);
    background: var(--cv-ui-bg-primary);
    cursor: pointer;
}
.cv-color-picker__trigger[data-v-f967d3b8]:hover:not(.cv-color-picker__trigger--disabled) {
    border-color: var(--cv-ui-border-color-hover);
}
.cv-color-picker__trigger--disabled[data-v-f967d3b8] {
    opacity: 0.6;
    cursor: not-allowed;
}
.cv-color-picker__trigger--sm .cv-color-picker__swatch[data-v-f967d3b8] {
    width: 18px;
    height: 18px;
}
.cv-color-picker__trigger--md .cv-color-picker__swatch[data-v-f967d3b8] {
    width: 24px;
    height: 24px;
}
.cv-color-picker__trigger--lg .cv-color-picker__swatch[data-v-f967d3b8] {
    width: 32px;
    height: 32px;
}
.cv-color-picker__swatch[data-v-f967d3b8] {
    flex-shrink: 0;
    border-radius: var(--cv-ui-radius-sm);
    border: 1px solid rgba(0, 0, 0, 0.15);
}
.cv-color-picker__input[data-v-f967d3b8] {
    min-width: 0;
    width: 6em;
    padding: var(--cv-ui-spacing-xs) var(--cv-ui-spacing-sm);
    font-family: var(--cv-ui-font-family);
    font-size: var(--cv-ui-font-size-sm);
    color: var(--cv-ui-text-primary);
    background: var(--cv-ui-bg-primary);
    border: 1px solid var(--cv-ui-border-color);
    border-radius: var(--cv-ui-radius-sm);
    outline: none;
}
.cv-color-picker__input[data-v-f967d3b8]:focus {
    border-color: var(--cv-ui-border-color-focus);
}
.cv-color-picker__panel[data-v-f967d3b8] {
    min-width: 220px;
    padding: var(--cv-ui-spacing-sm);
    font-family: var(--cv-ui-font-family);
}
.cv-color-picker__sv[data-v-f967d3b8] {
    position: relative;
    width: 100%;
    height: 140px;
    margin-bottom: var(--cv-ui-spacing-sm);
    border-radius: var(--cv-ui-radius-sm);
    cursor: crosshair;
    background: linear-gradient(to top, #000, transparent), linear-gradient(to right, #fff, var(--cv-color-picker-current-hue, red));
}
.cv-color-picker__sv-thumb[data-v-f967d3b8] {
    position: absolute;
    width: 14px;
    height: 14px;
    margin: -7px 0 0 -7px;
    border: 2px solid #fff;
    border-radius: 50%;
    box-shadow: 0 0 0 1px rgba(0, 0, 0, 0.3);
    pointer-events: none;
}
.cv-color-picker__hue[data-v-f967d3b8] {
    position: relative;
    width: 100%;
    height: 10px;
    margin-bottom: var(--cv-ui-spacing-sm);
    border-radius: var(--cv-ui-radius-full);
    cursor: pointer;
    background: linear-gradient(to right, #f00 0%, #ff0 17%, #0f0 33%, #0ff 50%, #00f 67%, #f0f 83%, #f00 100%);
}
.cv-color-picker__hue-thumb[data-v-f967d3b8] {
    position: absolute;
    top: 50%;
    width: 14px;
    height: 14px;
    margin: -7px 0 0 -7px;
    border: 2px solid #fff;
    border-radius: 50%;
    box-shadow: 0 0 0 1px rgba(0, 0, 0, 0.3);
    pointer-events: none;
}
.cv-color-picker__alpha[data-v-f967d3b8] {
    position: relative;
    width: 100%;
    height: 10px;
    margin-bottom: var(--cv-ui-spacing-sm);
    border-radius: var(--cv-ui-radius-full);
    cursor: pointer;
    background: linear-gradient(to right, transparent, var(--cv-color-picker-current-solid)),
        linear-gradient(45deg, #ccc 25%, transparent 25%), linear-gradient(-45deg, #ccc 25%, transparent 25%),
        linear-gradient(45deg, transparent 75%, #ccc 75%), linear-gradient(-45deg, transparent 75%, #ccc 75%);
    background-size: 100% 100%, 8px 8px, 8px 8px, 8px 8px, 8px 8px;
    background-position: 0 0, 0 0, 4px 0, 4px -4px, 0 4px;
    background-color: #fff;
}
.cv-color-picker__alpha-thumb[data-v-f967d3b8] {
    position: absolute;
    top: 50%;
    width: 14px;
    height: 14px;
    margin: -7px 0 0 -7px;
    border: 2px solid #fff;
    border-radius: 50%;
    box-shadow: 0 0 0 1px rgba(0, 0, 0, 0.3);
    pointer-events: none;
}
.cv-color-picker__inputs[data-v-f967d3b8] {
    display: flex;
    flex-direction: column;
    gap: var(--cv-ui-spacing-xs);
    margin-bottom: var(--cv-ui-spacing-sm);
}
.cv-color-picker__mode-input[data-v-f967d3b8] {
    width: 100%;
    padding: var(--cv-ui-spacing-xs) var(--cv-ui-spacing-sm);
    font-family: var(--cv-ui-font-family);
    font-size: var(--cv-ui-font-size-sm);
    color: var(--cv-ui-text-primary);
    background: var(--cv-ui-bg-primary);
    border: 1px solid var(--cv-ui-border-color);
    border-radius: var(--cv-ui-radius-sm);
    outline: none;
}
.cv-color-picker__mode-tabs[data-v-f967d3b8] {
    display: flex;
    gap: 2px;
}
.cv-color-picker__mode-tab[data-v-f967d3b8] {
    flex: 1;
    padding: var(--cv-ui-spacing-xs);
    font-size: var(--cv-ui-font-size-xs);
    color: var(--cv-ui-text-secondary);
    background: var(--cv-ui-bg-tertiary);
    border: none;
    border-radius: var(--cv-ui-radius-sm);
    cursor: pointer;
}
.cv-color-picker__mode-tab--active[data-v-f967d3b8] {
    color: var(--cv-ui-text-primary);
    background: var(--cv-ui-bg-secondary);
}
.cv-color-picker__swatches[data-v-f967d3b8] {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
}
.cv-color-picker__swatch-btn[data-v-f967d3b8] {
    width: 22px;
    height: 22px;
    padding: 0;
    border: 1px solid var(--cv-ui-border-color);
    border-radius: var(--cv-ui-radius-sm);
    cursor: pointer;
}
.cv-color-picker__swatch-btn[data-v-f967d3b8]:hover {
    transform: scale(1.1);
}

.cv-progress[data-v-58da3325] {
    --cv-progress-color: var(--cv-ui-color-primary);
    --cv-progress-duration: 200ms;
}
.cv-progress--primary[data-v-58da3325] {
    --cv-progress-color: var(--cv-ui-color-primary);
}
.cv-progress--secondary[data-v-58da3325] {
    --cv-progress-color: var(--cv-ui-color-secondary);
}
.cv-progress--success[data-v-58da3325] {
    --cv-progress-color: var(--cv-ui-color-success);
}
.cv-progress--warning[data-v-58da3325] {
    --cv-progress-color: var(--cv-ui-color-warning);
}
.cv-progress--danger[data-v-58da3325] {
    --cv-progress-color: var(--cv-ui-color-danger);
}
.cv-progress--info[data-v-58da3325] {
    --cv-progress-color: var(--cv-ui-color-info);
}

/* ----- Line ----- */
.cv-progress--line[data-v-58da3325] {
    display: inline-flex;
    align-items: center;
    gap: var(--cv-ui-spacing-sm);
}
.cv-progress__track[data-v-58da3325] {
    flex: 1;
    min-width: 80px;
    height: var(--cv-progress-height, 8px);
    background-color: var(--cv-ui-bg-tertiary);
    border-radius: var(--cv-ui-radius-full);
    overflow: hidden;
}
.cv-progress__fill[data-v-58da3325] {
    height: 100%;
    background-color: var(--cv-progress-color);
    border-radius: inherit;
    transition: width var(--cv-progress-duration) var(--cv-ui-transition-timing);
}
.cv-progress__fill--indeterminate[data-v-58da3325] {
    width: 30% !important;
    animation: cv-progress-line-indeterminate-58da3325 1.5s ease-in-out infinite;
}
@keyframes cv-progress-line-indeterminate-58da3325 {
0% {
        transform: translateX(-100%);
}
100% {
        transform: translateX(433%);
}
}
.cv-progress--line.cv-progress--sm .cv-progress__track[data-v-58da3325] {
    --cv-progress-height: 4px;
}
.cv-progress--line.cv-progress--md .cv-progress__track[data-v-58da3325] {
    --cv-progress-height: 8px;
}
.cv-progress--line.cv-progress--lg .cv-progress__track[data-v-58da3325] {
    --cv-progress-height: 12px;
}
.cv-progress__label--line[data-v-58da3325] {
    flex-shrink: 0;
    min-width: 2.5em;
    font-family: var(--cv-ui-font-family);
    font-size: var(--cv-ui-font-size-sm);
    font-weight: var(--cv-ui-font-weight-medium);
    color: var(--cv-ui-text-primary);
}

/* ----- Circle ----- */
.cv-progress--circle[data-v-58da3325] {
    display: inline-block;
}
.cv-progress__circle-wrap[data-v-58da3325] {
    position: relative;
    width: var(--cv-progress-circle-size, 80px);
    height: var(--cv-progress-circle-size, 80px);
}
.cv-progress__circle-svg[data-v-58da3325] {
    width: 100%;
    height: 100%;
    transform: rotate(-90deg);
}
.cv-progress__circle-track[data-v-58da3325] {
    stroke: var(--cv-ui-bg-tertiary);
    stroke-width: 6;
}
.cv-progress__circle-fill[data-v-58da3325] {
    stroke: var(--cv-progress-color);
    stroke-width: 6;
    stroke-linecap: round;
    transition: stroke-dashoffset var(--cv-progress-duration) var(--cv-ui-transition-timing);
}
.cv-progress__circle-fill--indeterminate[data-v-58da3325] {
    stroke-dasharray: 70 212;
    animation: cv-progress-circle-indeterminate-58da3325 1s linear infinite;
}
@keyframes cv-progress-circle-indeterminate-58da3325 {
0% {
        stroke-dashoffset: 0;
}
100% {
        stroke-dashoffset: -283;
}
}
.cv-progress__circle-wrap .cv-progress__circle-fill[data-v-58da3325] {
    transform: rotate(-90deg);
}
.cv-progress__label--circle[data-v-58da3325] {
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    font-family: var(--cv-ui-font-family);
    font-size: var(--cv-ui-font-size-sm);
    font-weight: var(--cv-ui-font-weight-medium);
    color: var(--cv-ui-text-primary);
}
.cv-progress--circle.cv-progress--sm .cv-progress__circle-wrap[data-v-58da3325] {
    --cv-progress-circle-size: 48px;
}
.cv-progress--circle.cv-progress--md .cv-progress__circle-wrap[data-v-58da3325] {
    --cv-progress-circle-size: 80px;
}
.cv-progress--circle.cv-progress--lg .cv-progress__circle-wrap[data-v-58da3325] {
    --cv-progress-circle-size: 120px;
}

.cv-tabs[data-v-d0ec26e7] {
    font-family: var(--cv-ui-font-family);
}

.cv-tab-list[data-v-188b3ea5] {
    display: flex;
    align-items: stretch;
    gap: 0;
}
.cv-tab-list--underline[data-v-188b3ea5] {
    border-bottom: 1px solid var(--cv-ui-border-color);
}
.cv-tab-list--pills[data-v-188b3ea5] {
    gap: var(--cv-ui-spacing-xs);
    border-bottom: none;
}
.cv-tab-list--boxed[data-v-188b3ea5] {
    gap: 0;
    padding: var(--cv-ui-spacing-xs);
    background-color: var(--cv-ui-bg-tertiary);
    border-radius: var(--cv-ui-radius-md);
    border: 1px solid var(--cv-ui-border-color);
}
.cv-tab-list--minimal[data-v-188b3ea5] {
    border-bottom: none;
}
.cv-tab-list--segmented[data-v-188b3ea5] {
    gap: 0;
    width: fit-content;
    padding: var(--cv-ui-spacing-sm);
    background-color: var(--cv-ui-bg-tertiary);
    border-radius: var(--cv-ui-radius-full);
    border: none;
}
.cv-tab-list--cards[data-v-188b3ea5] {
    display: grid;
    grid-template-columns: repeat(var(--cv-tabs-cards-cols-base, 2), minmax(0, 1fr));
    gap: var(--cv-ui-spacing-sm);
    border-bottom: none;
}
@media (min-width: 640px) {
.cv-tab-list--cards[data-v-188b3ea5] {
        grid-template-columns: repeat(var(--cv-tabs-cards-cols-sm, var(--cv-tabs-cards-cols-base, 2)), minmax(0, 1fr));
}
}
@media (min-width: 768px) {
.cv-tab-list--cards[data-v-188b3ea5] {
        grid-template-columns: repeat(var(--cv-tabs-cards-cols-md, var(--cv-tabs-cards-cols-sm, 2)), minmax(0, 1fr));
}
}
@media (min-width: 1024px) {
.cv-tab-list--cards[data-v-188b3ea5] {
        grid-template-columns: repeat(var(--cv-tabs-cards-cols-lg, var(--cv-tabs-cards-cols-md, 3)), minmax(0, 1fr));
}
}
@media (min-width: 1280px) {
.cv-tab-list--cards[data-v-188b3ea5] {
        grid-template-columns: repeat(var(--cv-tabs-cards-cols-xl, var(--cv-tabs-cards-cols-lg, 4)), minmax(0, 1fr));
}
}
.cv-tab-list--cards-no-wrap[data-v-188b3ea5] {
    display: grid;
    grid-auto-flow: column;
    grid-auto-columns: minmax(180px, 1fr);
    grid-template-columns: none;
    overflow-x: auto;
    overflow-y: hidden;
}
.cv-tab-list--scrollable[data-v-188b3ea5] {
    overflow-x: auto;
    overflow-y: hidden;
    scrollbar-width: thin;
    -webkit-overflow-scrolling: touch;
}
.cv-tab-list--scrollable[data-v-188b3ea5]::-webkit-scrollbar {
    height: 4px;
}

.cv-tab[data-v-73019821] {
    position: relative;
    padding: var(--cv-ui-spacing-sm) var(--cv-ui-spacing-md);
    font-family: var(--cv-ui-font-family);
    font-size: var(--cv-ui-font-size-sm);
    font-weight: var(--cv-ui-font-weight-medium);
    color: var(--cv-ui-text-secondary);
    background: transparent;
    border: none;
    cursor: pointer;
    outline: none;
    transition:
        color var(--cv-ui-transition-fast) var(--cv-ui-transition-timing),
        background-color var(--cv-ui-transition-fast) var(--cv-ui-transition-timing),
        border-color var(--cv-ui-transition-fast) var(--cv-ui-transition-timing),
        box-shadow var(--cv-ui-transition-fast) var(--cv-ui-transition-timing);
}
.cv-tab[data-v-73019821]:hover:not(.cv-tab--disabled) {
    color: var(--cv-ui-text-primary);
}
.cv-tab[data-v-73019821]:focus-visible {
    box-shadow: inset 0 0 0 2px var(--cv-ui-border-color-focus);
}
.cv-tab--disabled[data-v-73019821] {
    opacity: 0.6;
    cursor: not-allowed;
}
.cv-tab--cards[data-v-73019821] {
    width: 100%;
    min-width: 0;
    min-height: var(--cv-tabs-cards-min-height, 44px);
    justify-content: flex-start;
    gap: var(--cv-ui-spacing-xs);
    padding: var(--cv-ui-spacing-sm) var(--cv-ui-spacing-md);
    text-align: left;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    border: 1px solid var(--cv-ui-border-color);
    border-radius: var(--cv-ui-radius-md);
    background-color: var(--cv-ui-bg-primary);
}
.cv-tab--cards.cv-tab--dense[data-v-73019821] {
    min-height: 36px;
    padding: var(--cv-ui-spacing-xs) var(--cv-ui-spacing-sm);
}
.cv-tab--cards[data-v-73019821]:hover:not(.cv-tab--disabled) {
    background-color: var(--cv-ui-bg-hover);
    border-color: color-mix(in oklab, var(--cv-ui-border-color) 60%, var(--cv-ui-color-primary) 40%);
}
.cv-tab--cards.cv-tab--selected[data-v-73019821] {
    color: var(--cv-ui-color-primary);
    border-color: var(--cv-ui-color-primary);
    background-color: var(--cv-ui-color-primary-light);
    box-shadow: var(--cv-ui-shadow-sm);
}

/* ----- Underline (default) ----- */
.cv-tab--underline[data-v-73019821] {
    border-bottom: 2px solid transparent;
}
.cv-tab--underline[data-v-73019821]:hover:not(.cv-tab--disabled) {
    background-color: var(--cv-ui-bg-hover);
}
.cv-tab--underline.cv-tab--selected[data-v-73019821] {
    color: var(--cv-ui-color-primary);
    border-bottom-color: var(--cv-ui-color-primary);
}

/* ----- Pills ----- */
.cv-tab--pills[data-v-73019821] {
    border-radius: var(--cv-ui-radius-md);
}
.cv-tab--pills[data-v-73019821]:hover:not(.cv-tab--disabled) {
    background-color: var(--cv-ui-bg-hover);
}
.cv-tab--pills.cv-tab--selected[data-v-73019821] {
    color: var(--cv-ui-color-primary);
    background-color: var(--cv-ui-color-primary-light);
}

/* ----- Boxed ----- */
.cv-tab--boxed[data-v-73019821] {
    border-radius: var(--cv-ui-radius-sm);
}
.cv-tab--boxed[data-v-73019821]:hover:not(.cv-tab--disabled) {
    background-color: var(--cv-ui-bg-hover);
}
.cv-tab--boxed.cv-tab--selected[data-v-73019821] {
    color: var(--cv-ui-text-inverse);
    background-color: var(--cv-ui-color-primary);
}
.cv-tab--boxed.cv-tab--selected[data-v-73019821]:hover:not(.cv-tab--disabled) {
    background-color: var(--cv-ui-color-primary-hover);
}

/* ----- Minimal ----- */
.cv-tab--minimal[data-v-73019821]:hover:not(.cv-tab--disabled) {
    color: var(--cv-ui-text-primary);
}
.cv-tab--minimal.cv-tab--selected[data-v-73019821] {
    color: var(--cv-ui-color-primary);
    font-weight: var(--cv-ui-font-weight-semibold);
}

/* ----- Segmented (iOS-style control) ----- */
.cv-tab--segmented[data-v-73019821] {
    flex: 1;
    min-width: 0;
    border-radius: var(--cv-ui-radius-md);
}
.cv-tab--segmented[data-v-73019821]:hover:not(.cv-tab--disabled) {
    background-color: var(--cv-ui-bg-hover);
}
.cv-tab--segmented.cv-tab--selected[data-v-73019821] {
    color: var(--cv-ui-text-inverse);
    background-color: var(--cv-ui-color-primary);
    box-shadow: var(--cv-ui-shadow-sm);
}
.cv-tab--segmented.cv-tab--selected[data-v-73019821]:hover:not(.cv-tab--disabled) {
    background-color: var(--cv-ui-color-primary-hover);
}

/* Stepper */
.cv-tab--stepper[data-v-73019821] {
    display: flex;
    align-items: flex-start;
    gap: var(--cv-ui-spacing-sm);
    padding: var(--cv-ui-spacing-md);
    text-align: left;
}
.cv-tab__step-marker[data-v-73019821] {
    flex-shrink: 0;
    width: 24px;
    height: 24px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: var(--cv-ui-radius-full);
    font-size: var(--cv-ui-font-size-xs);
    font-weight: var(--cv-ui-font-weight-semibold);
    background: var(--cv-ui-bg-tertiary);
    color: var(--cv-ui-text-tertiary);
}
.cv-tab__step-marker--complete[data-v-73019821] {
    background: var(--cv-ui-color-success);
    color: var(--cv-ui-text-inverse);
}
.cv-tab__step-marker--current[data-v-73019821] {
    background: var(--cv-ui-color-primary);
    color: var(--cv-ui-text-inverse);
}
.cv-tab__step-marker--error[data-v-73019821] {
    background: var(--cv-ui-color-danger);
    color: var(--cv-ui-text-inverse);
}
.cv-tab__step-check[data-v-73019821] {
    line-height: 1;
}
.cv-tab__step-content[data-v-73019821] {
    display: flex;
    flex-direction: column;
    gap: 2px;
}
.cv-tab__step-title[data-v-73019821] {
    font-weight: var(--cv-ui-font-weight-medium);
    color: inherit;
}
.cv-tab__step-desc[data-v-73019821] {
    font-size: var(--cv-ui-font-size-xs);
    font-weight: var(--cv-ui-font-weight-normal);
    color: var(--cv-ui-text-tertiary);
}
.cv-tab--stepper-selected .cv-tab__step-title[data-v-73019821],
.cv-tab--stepper-current .cv-tab__step-title[data-v-73019821] {
    color: var(--cv-ui-color-primary);
}

.cv-tab-panel[data-v-477aa98f] {
    padding: var(--cv-ui-spacing-md) 0;
    font-family: var(--cv-ui-font-family);
    font-size: var(--cv-ui-font-size-sm);
    color: var(--cv-ui-text-primary);
}

.cv-date-picker-wrapper[data-v-b18ffd56] {
        position: relative;
        width: 100%;
}
.cv-date-picker__field-wrap[data-v-b18ffd56] {
        position: relative;
        display: flex;
        align-items: center;
        width: 100%;
}
.cv-date-picker__input[data-v-b18ffd56] {
        flex: 1;
        width: 100%;
        padding: var(--cv-ui-spacing-sm) var(--cv-ui-spacing-md);
        font-family: var(--cv-ui-font-family);
        font-size: var(--cv-ui-font-size-sm);
        color: var(--cv-ui-text-primary);
        background-color: var(--cv-ui-bg-primary);
        border: 1px solid var(--cv-ui-border-color);
        border-radius: var(--cv-ui-radius-md);
        box-shadow: var(--cv-ui-shadow-sm);
        outline: none;
        transition: border-color var(--cv-ui-transition-fast) var(--cv-ui-transition-timing);
}
.cv-date-picker__input[data-v-b18ffd56]::placeholder {
        color: var(--cv-ui-text-tertiary);
}
.cv-date-picker__input[data-v-b18ffd56]:hover:not(.cv-date-picker__input--disabled) {
        border-color: var(--cv-ui-border-color-hover);
}
.cv-date-picker__input[data-v-b18ffd56]:focus {
        border-color: var(--cv-ui-border-color-focus);
        box-shadow: var(--cv-ui-shadow-focus);
}
.cv-date-picker__input--disabled[data-v-b18ffd56] {
        opacity: 0.7;
        cursor: not-allowed;
        background-color: var(--cv-ui-bg-tertiary);
}
.cv-date-picker__input--error[data-v-b18ffd56] {
        border-color: var(--cv-ui-border-color-error);
}
.cv-date-picker__input--success[data-v-b18ffd56] {
        border-color: var(--cv-ui-color-success);
}
.cv-date-picker__input--sm[data-v-b18ffd56] {
        padding: var(--cv-ui-spacing-xs) var(--cv-ui-spacing-sm);
        font-size: var(--cv-ui-font-size-xs);
}
.cv-date-picker__input--lg[data-v-b18ffd56] {
        padding: var(--cv-ui-spacing-md) var(--cv-ui-spacing-lg);
        font-size: var(--cv-ui-font-size-md);
}
.cv-date-picker__trigger[data-v-b18ffd56] {
        position: absolute;
        right: var(--cv-ui-spacing-sm);
        display: flex;
        align-items: center;
        justify-content: center;
        padding: var(--cv-ui-spacing-xs);
        background: none;
        border: none;
        color: var(--cv-ui-text-tertiary);
        cursor: pointer;
        border-radius: var(--cv-ui-radius-sm);
}
.cv-date-picker__trigger[data-v-b18ffd56]:hover:not(:disabled) {
        color: var(--cv-ui-text-primary);
        background: var(--cv-ui-bg-tertiary);
}
.cv-date-picker__field-wrap:has(.cv-date-picker__trigger) .cv-date-picker__input[data-v-b18ffd56] {
        padding-right: 2.25rem;
}
.cv-date-picker__field-wrap:has(.cv-date-picker__clear) .cv-date-picker__input[data-v-b18ffd56] {
        padding-right: 4rem;
}
.cv-date-picker__clear[data-v-b18ffd56] {
        position: absolute;
        right: 2.25rem;
        top: 50%;
        transform: translateY(-50%);
        display: flex;
        align-items: center;
        justify-content: center;
        width: 1.5rem;
        height: 1.5rem;
        padding: 0;
        font-size: 1.25rem;
        line-height: 1;
        color: var(--cv-ui-text-tertiary);
        background: none;
        border: none;
        border-radius: var(--cv-ui-radius-sm);
        cursor: pointer;
        transition: color var(--cv-ui-transition-fast) var(--cv-ui-transition-timing);
}
.cv-date-picker__clear[data-v-b18ffd56]:hover:not(:disabled) {
        color: var(--cv-ui-text-primary);
        background: var(--cv-ui-bg-tertiary);
}
.cv-date-picker__calendar-footer[data-v-b18ffd56] {
        display: flex;
        justify-content: space-between;
        gap: var(--cv-ui-spacing-sm);
        margin-top: var(--cv-ui-spacing-sm);
        padding-top: var(--cv-ui-spacing-sm);
        border-top: 1px solid var(--cv-ui-border-color);
}
.cv-date-picker__footer-btn[data-v-b18ffd56] {
        padding: var(--cv-ui-spacing-xs) var(--cv-ui-spacing-sm);
        font-family: var(--cv-ui-font-family);
        font-size: var(--cv-ui-font-size-xs);
        font-weight: var(--cv-ui-font-weight-medium);
        color: var(--cv-ui-color-primary);
        background: none;
        border: none;
        border-radius: var(--cv-ui-radius-md);
        cursor: pointer;
        transition: background-color var(--cv-ui-transition-fast) var(--cv-ui-transition-timing);
}
.cv-date-picker__footer-btn[data-v-b18ffd56]:hover {
        background: var(--cv-ui-bg-hover);
}
.cv-date-picker__footer-btn--secondary[data-v-b18ffd56] {
        color: var(--cv-ui-text-secondary);
}
.cv-date-picker-feedback[data-v-b18ffd56] {
        margin-top: var(--cv-ui-spacing-xs);
        font-size: var(--cv-ui-font-size-xs);
}
.cv-date-picker-feedback--error[data-v-b18ffd56] {
        color: var(--cv-ui-color-danger);
}
.cv-date-picker-feedback--success[data-v-b18ffd56] {
        color: var(--cv-ui-color-success);
}

    /* Dropdown calendar (position set via inline style when using Teleport) */
.cv-date-picker__dropdown[data-v-b18ffd56] {
        position: fixed;
        z-index: var(--cv-ui-z-dropdown);
        padding: var(--cv-ui-spacing-sm);
        background: var(--cv-ui-bg-primary);
        border: 1px solid var(--cv-ui-border-color);
        border-radius: var(--cv-ui-radius-lg);
        box-shadow: var(--cv-ui-shadow-lg);
}
.cv-date-picker__calendar[data-v-b18ffd56] {
        min-width: 220px;
}
.cv-date-picker__calendar-header[data-v-b18ffd56] {
        display: flex;
        align-items: center;
        justify-content: space-between;
        gap: 2px;
        margin-bottom: var(--cv-ui-spacing-sm);
}
.cv-date-picker__month-year[data-v-b18ffd56] {
        display: flex;
        align-items: center;
        gap: var(--cv-ui-spacing-xs);
        flex: 1;
        min-width: 0;
        justify-content: center;
}
.cv-date-picker__year-select[data-v-b18ffd56] {
        padding: 2px 6px;
        font-family: var(--cv-ui-font-family);
        font-size: var(--cv-ui-font-size-xs);
        font-weight: var(--cv-ui-font-weight-medium);
        color: var(--cv-ui-text-primary);
        background: var(--cv-ui-bg-primary);
        border: 1px solid var(--cv-ui-border-color);
        border-radius: var(--cv-ui-radius-sm);
        cursor: pointer;
        min-width: 3.5rem;
}
.cv-date-picker__year-select[data-v-b18ffd56]:hover {
        border-color: var(--cv-ui-border-color-hover);
}
.cv-date-picker__year-select[data-v-b18ffd56]:focus {
        outline: none;
        border-color: var(--cv-ui-border-color-focus);
        box-shadow: var(--cv-ui-shadow-focus);
}
.cv-date-picker__nav[data-v-b18ffd56] {
        display: flex;
        align-items: center;
        justify-content: center;
        width: 2rem;
        height: 2rem;
        padding: 0;
        font-size: 1.25rem;
        color: var(--cv-ui-text-secondary);
        background: none;
        border: none;
        border-radius: var(--cv-ui-radius-md);
        cursor: pointer;
}
.cv-date-picker__nav[data-v-b18ffd56]:hover:not(:disabled) {
        background: var(--cv-ui-bg-hover);
        color: var(--cv-ui-text-primary);
}
.cv-date-picker__nav[data-v-b18ffd56]:disabled {
        opacity: 0.4;
        cursor: not-allowed;
}
.cv-date-picker__nav--year[data-v-b18ffd56] {
        font-size: 0.875rem;
}
.cv-date-picker__month-label[data-v-b18ffd56] {
        font-size: var(--cv-ui-font-size-sm);
        font-weight: var(--cv-ui-font-weight-medium);
        color: var(--cv-ui-text-primary);
}
.cv-date-picker__weekdays[data-v-b18ffd56] {
        display: grid;
        grid-template-columns: repeat(7, 1fr);
        gap: 2px;
        margin-bottom: 4px;
}
.cv-date-picker__weekday[data-v-b18ffd56] {
        font-size: 0.65rem;
        font-weight: 500;
        color: var(--cv-ui-text-tertiary);
        text-align: center;
}
.cv-date-picker__days[data-v-b18ffd56] {
        display: grid;
        grid-template-columns: repeat(7, 1fr);
        gap: 2px;
}
.cv-date-picker__day[data-v-b18ffd56] {
        display: flex;
        align-items: center;
        justify-content: center;
        width: 2rem;
        height: 2rem;
        padding: 0;
        font-size: var(--cv-ui-font-size-xs);
        color: var(--cv-ui-text-primary);
        background: none;
        border: none;
        border-radius: var(--cv-ui-radius-md);
        cursor: pointer;
}
.cv-date-picker__day[data-v-b18ffd56]:hover:not(:disabled):not(.cv-date-picker__day--selected) {
        background: var(--cv-ui-bg-hover);
}
.cv-date-picker__day--selected[data-v-b18ffd56] {
        background: var(--cv-ui-color-primary);
        color: var(--cv-ui-text-inverse);
}
.cv-date-picker__day--today[data-v-b18ffd56] {
        font-weight: 600;
}
.cv-date-picker__day--other[data-v-b18ffd56] {
        color: var(--cv-ui-text-tertiary);
}
.cv-date-picker__day--empty[data-v-b18ffd56] {
        width: 2rem;
        height: 2rem;
}
.cv-date-picker__day[data-v-b18ffd56]:disabled {
        opacity: 0.5;
        cursor: not-allowed;
}

.cv-tree__item[data-v-d1a337b6] {
    display: flex;
    flex-direction: column;
    width: 100%;
    min-width: 0;
}
.cv-tree__row[data-v-d1a337b6] {
    display: inline-flex;
    align-items: center;
    gap: var(--cv-ui-spacing-xs);
    min-width: 0;
    padding-inline-end: var(--cv-ui-spacing-sm);
    border-radius: var(--cv-ui-radius-sm);
    box-sizing: border-box;
    color: inherit;
    line-height: 1.25;
    user-select: none;
    cursor: pointer;
    outline: none;
    transition:
        background-color var(--cv-ui-transition-fast) var(--cv-ui-transition-timing),
        color var(--cv-ui-transition-fast) var(--cv-ui-transition-timing);
}
.cv-tree__row--block-line[data-v-d1a337b6] {
    display: flex;
    width: 100%;
    max-width: 100%;
}
.cv-tree__row[data-v-d1a337b6]:hover {
    background: var(--cv-tree-row-hover-bg, var(--cv-ui-bg-hover));
}
.cv-tree__row[data-v-d1a337b6]:active {
    background: var(--cv-tree-row-active-bg, var(--cv-ui-bg-active));
}
.cv-tree__row--selected[data-v-d1a337b6] {
    background: color-mix(in srgb, var(--cv-tree-row-active-bg, var(--cv-ui-bg-active)) 75%, transparent);
}
.cv-tree__row--selected[data-v-d1a337b6]:hover {
    background: var(--cv-tree-row-active-bg, var(--cv-ui-bg-active));
}
.cv-tree__row[data-v-d1a337b6]:focus-visible {
    box-shadow: 0 0 0 2px var(--cv-tree-focus-ring, var(--cv-ui-border-color-focus));
}
.cv-tree__row--disabled[data-v-d1a337b6] {
    color: var(--cv-tree-muted, var(--cv-ui-text-disabled));
    cursor: not-allowed;
}
.cv-tree__row--disabled[data-v-d1a337b6]:hover,
.cv-tree__row--disabled[data-v-d1a337b6]:active {
    background: transparent;
}
.cv-tree__toggle[data-v-d1a337b6],
.cv-tree__toggle-spacer[data-v-d1a337b6] {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 16px;
    min-width: 16px;
    height: 16px;
    flex-shrink: 0;
}
.cv-tree__toggle[data-v-d1a337b6] {
    padding: 0;
    border: none;
    border-radius: var(--cv-ui-radius-sm);
    background: transparent;
    color: var(--cv-tree-muted, var(--cv-ui-text-secondary));
    cursor: pointer;
}
.cv-tree__toggle[data-v-d1a337b6]:not(:disabled):hover {
    background: var(--cv-ui-bg-hover);
    color: var(--cv-tree-text, var(--cv-ui-text-primary));
}
.cv-tree__toggle[data-v-d1a337b6]:disabled {
    cursor: not-allowed;
    opacity: 0.5;
}
.cv-tree__toggle-icon[data-v-d1a337b6] {
    width: 14px;
    height: 14px;
}
.cv-tree__leading-icon[data-v-d1a337b6] {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 16px;
    min-width: 16px;
    height: 16px;
    flex-shrink: 0;
    color: var(--cv-tree-muted, var(--cv-ui-text-secondary));
}
.cv-tree__leading-icon[data-v-d1a337b6] svg {
    width: 16px;
    height: 16px;
}
.cv-tree__row--selected .cv-tree__leading-icon[data-v-d1a337b6] {
    color: var(--cv-tree-text, var(--cv-ui-text-primary));
}
.cv-tree__label[data-v-d1a337b6] {
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    flex: 1;
}
.cv-tree__label--custom[data-v-d1a337b6] {
    overflow: visible;
    white-space: normal;
    display: flex;
    align-items: center;
    width: 100%;
}
.cv-tree__row--drag-before[data-v-d1a337b6] {
    box-shadow: 0 -2px 0 var(--cv-ui-color-primary, #3b82f6);
}
.cv-tree__row--drag-after[data-v-d1a337b6] {
    box-shadow: 0 2px 0 var(--cv-ui-color-primary, #3b82f6);
}
.cv-tree__row--drag-inside[data-v-d1a337b6] {
    outline: 2px solid var(--cv-ui-color-primary, #3b82f6);
    outline-offset: -2px;
}
.cv-tree__children[data-v-d1a337b6] {
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.cv-tree[data-v-5de90e03] {
    display: flex;
    flex-direction: column;
    gap: 2px;
    min-width: 0;
    padding: var(--cv-ui-spacing-xs);
    border: 1px solid var(--cv-tree-border, var(--cv-ui-border-color));
    border-radius: var(--cv-ui-radius-md);
    background: var(--cv-tree-bg, var(--cv-ui-bg-primary));
    color: var(--cv-tree-text, var(--cv-ui-text-primary));
    font-family: var(--cv-ui-font-family);
    font-size: var(--cv-ui-font-size-sm);
}

.cv-empty-state[data-v-92194a79] {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    text-align: center;
    padding: var(--cv-ui-spacing-xl);
    font-family: var(--cv-ui-font-family);
}

/* Icon wrapper — soft circle background */
.cv-empty-state__icon-wrapper[data-v-92194a79] {
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: var(--cv-ui-radius-full);
    background-color: var(--cv-ui-bg-tertiary);
    color: var(--cv-ui-text-secondary);
    flex-shrink: 0;
}
.cv-empty-state__icon[data-v-92194a79] {
    display: block;
}

/* Size: sm */
.cv-empty-state--sm .cv-empty-state__icon-wrapper[data-v-92194a79] {
    width: 56px;
    height: 56px;
    margin-bottom: var(--cv-ui-spacing-sm);
}
.cv-empty-state--sm .cv-empty-state__icon[data-v-92194a79] {
    width: 28px;
    height: 28px;
}
.cv-empty-state--sm .cv-empty-state__title[data-v-92194a79] {
    font-size: var(--cv-ui-font-size-md);
}
.cv-empty-state--sm .cv-empty-state__description[data-v-92194a79] {
    font-size: var(--cv-ui-font-size-xs);
}

/* Size: md */
.cv-empty-state--md .cv-empty-state__icon-wrapper[data-v-92194a79] {
    width: 80px;
    height: 80px;
    margin-bottom: var(--cv-ui-spacing-md);
}
.cv-empty-state--md .cv-empty-state__icon[data-v-92194a79] {
    width: 40px;
    height: 40px;
}
.cv-empty-state--md .cv-empty-state__title[data-v-92194a79] {
    font-size: var(--cv-ui-font-size-lg);
}
.cv-empty-state--md .cv-empty-state__description[data-v-92194a79] {
    font-size: var(--cv-ui-font-size-sm);
}

/* Size: lg */
.cv-empty-state--lg .cv-empty-state__icon-wrapper[data-v-92194a79] {
    width: 112px;
    height: 112px;
    margin-bottom: var(--cv-ui-spacing-lg);
}
.cv-empty-state--lg .cv-empty-state__icon[data-v-92194a79] {
    width: 56px;
    height: 56px;
}
.cv-empty-state--lg .cv-empty-state__title[data-v-92194a79] {
    font-size: var(--cv-ui-font-size-xl);
}
.cv-empty-state--lg .cv-empty-state__description[data-v-92194a79] {
    font-size: var(--cv-ui-font-size-md);
}

/* Title */
.cv-empty-state__title[data-v-92194a79] {
    margin: 0 0 var(--cv-ui-spacing-xs);
    font-weight: var(--cv-ui-font-weight-semibold);
    color: var(--cv-ui-text-primary);
    line-height: 1.4;
}

/* Description */
.cv-empty-state__description[data-v-92194a79] {
    margin: 0;
    color: var(--cv-ui-text-secondary);
    max-width: 36ch;
    line-height: 1.6;
}

/* Actions slot */
.cv-empty-state__actions[data-v-92194a79] {
    display: flex;
    align-items: center;
    justify-content: center;
    flex-wrap: wrap;
    gap: var(--cv-ui-spacing-sm);
    margin-top: var(--cv-ui-spacing-md);
}

.cv-dropdown[data-v-75affc56] {
    display: inline-block;
    position: relative;
    font-family: var(--cv-ui-font-family);
}
.cv-dropdown--disabled[data-v-75affc56] {
    pointer-events: none;
    opacity: 0.6;
}
.cv-dropdown__trigger[data-v-75affc56] {
    display: inline-flex;
    cursor: pointer;
}

/* Floating panel */
.cv-dropdown__panel[data-v-75affc56] {
    position: fixed;
    z-index: var(--cv-ui-z-dropdown);
    min-width: 180px;
    padding: var(--cv-ui-spacing-xs);
    background-color: var(--cv-ui-bg-primary);
    border: 1px solid var(--cv-ui-border-color);
    border-radius: var(--cv-ui-radius-lg);
    box-shadow: var(--cv-ui-shadow-lg);
    outline: none;
}

/* Divider */
.cv-dropdown__divider[data-v-75affc56] {
    height: 1px;
    background-color: var(--cv-ui-border-color);
    margin: var(--cv-ui-spacing-xs) 0;
}

/* Item */
.cv-dropdown__item[data-v-75affc56] {
    display: flex;
    align-items: center;
    gap: var(--cv-ui-spacing-sm);
    width: 100%;
    height: 36px;
    padding: 0 var(--cv-ui-spacing-sm);
    border: none;
    border-radius: var(--cv-ui-radius-md);
    background: transparent;
    color: var(--cv-ui-text-primary);
    font-family: var(--cv-ui-font-family);
    font-size: var(--cv-ui-font-size-sm);
    font-weight: var(--cv-ui-font-weight-normal);
    text-align: left;
    cursor: pointer;
    transition:
        background-color var(--cv-ui-transition-fast) var(--cv-ui-transition-timing),
        color var(--cv-ui-transition-fast) var(--cv-ui-transition-timing);
    outline: none;
}
.cv-dropdown__item[data-v-75affc56]:hover:not(.cv-dropdown__item--disabled),
.cv-dropdown__item--focused[data-v-75affc56]:not(.cv-dropdown__item--disabled) {
    background-color: var(--cv-ui-bg-hover);
}
.cv-dropdown__item[data-v-75affc56]:focus-visible {
    box-shadow: 0 0 0 2px var(--cv-ui-border-focus);
}
.cv-dropdown__item--danger[data-v-75affc56] {
    color: var(--cv-ui-color-danger);
}
.cv-dropdown__item--danger[data-v-75affc56]:hover:not(.cv-dropdown__item--disabled),
.cv-dropdown__item--danger.cv-dropdown__item--focused[data-v-75affc56]:not(.cv-dropdown__item--disabled) {
    background-color: var(--cv-ui-color-danger-light);
}
.cv-dropdown__item--disabled[data-v-75affc56] {
    opacity: 0.45;
    cursor: not-allowed;
}

/* Icon */
.cv-dropdown__item-icon[data-v-75affc56] {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 16px;
    height: 16px;
    flex-shrink: 0;
    color: inherit;
}

/* Label */
.cv-dropdown__item-label[data-v-75affc56] {
    flex: 1;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

/* Shortcut */
.cv-dropdown__item-shortcut[data-v-75affc56] {
    flex-shrink: 0;
    font-size: var(--cv-ui-font-size-xs);
    color: var(--cv-ui-text-tertiary);
    font-family: var(--cv-ui-font-family);
}

/* Transition */
.cv-dropdown-fade-enter-active[data-v-75affc56],
.cv-dropdown-fade-leave-active[data-v-75affc56] {
    transition:
        opacity var(--cv-ui-transition-fast) var(--cv-ui-transition-timing),
        transform var(--cv-ui-transition-fast) var(--cv-ui-transition-timing);
}
.cv-dropdown-fade-enter-from[data-v-75affc56],
.cv-dropdown-fade-leave-to[data-v-75affc56] {
    opacity: 0;
    transform: translateY(-4px) scale(0.98);
}

.cv-pagination[data-v-37ca6743] {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: var(--cv-ui-spacing-sm);
    font-family: var(--cv-ui-font-family);
    font-size: var(--cv-ui-font-size-sm);
    color: var(--cv-ui-text-secondary);
}
.cv-pagination--disabled[data-v-37ca6743] {
    opacity: 0.5;
    pointer-events: none;
}

/* Total label */
.cv-pagination__total[data-v-37ca6743] {
    color: var(--cv-ui-text-secondary);
    white-space: nowrap;
}

/* Page size select */
.cv-pagination__page-size[data-v-37ca6743] {
    height: 32px;
    padding: 0 var(--cv-ui-spacing-xs);
    border: 1px solid var(--cv-ui-border-color);
    border-radius: var(--cv-ui-radius-md);
    background-color: var(--cv-ui-bg-primary);
    color: var(--cv-ui-text-primary);
    font-family: var(--cv-ui-font-family);
    font-size: var(--cv-ui-font-size-sm);
    cursor: pointer;
    outline: none;
    transition: border-color var(--cv-ui-transition-fast) var(--cv-ui-transition-timing);
}
.cv-pagination__page-size[data-v-37ca6743]:focus-visible {
    border-color: var(--cv-ui-border-focus);
    box-shadow: var(--cv-ui-shadow-focus);
}
.cv-pagination--sm .cv-pagination__page-size[data-v-37ca6743] {
    height: 28px;
    font-size: var(--cv-ui-font-size-xs);
}

/* Controls row */
.cv-pagination__controls[data-v-37ca6743] {
    display: inline-flex;
    align-items: center;
    gap: 2px;
}

/* Base button */
.cv-pagination__btn[data-v-37ca6743] {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border: 1px solid var(--cv-ui-border-color);
    border-radius: var(--cv-ui-radius-md);
    background-color: var(--cv-ui-bg-primary);
    color: var(--cv-ui-text-primary);
    font-family: var(--cv-ui-font-family);
    font-size: var(--cv-ui-font-size-sm);
    cursor: pointer;
    transition:
        background-color var(--cv-ui-transition-fast) var(--cv-ui-transition-timing),
        border-color var(--cv-ui-transition-fast) var(--cv-ui-transition-timing),
        color var(--cv-ui-transition-fast) var(--cv-ui-transition-timing);
    outline: none;
    user-select: none;
}

/* md size */
.cv-pagination--md .cv-pagination__btn[data-v-37ca6743] {
    min-width: 36px;
    height: 36px;
    padding: 0 var(--cv-ui-spacing-xs);
}

/* sm size */
.cv-pagination--sm .cv-pagination__btn[data-v-37ca6743] {
    min-width: 28px;
    height: 28px;
    padding: 0 4px;
    font-size: var(--cv-ui-font-size-xs);
}
.cv-pagination__btn[data-v-37ca6743]:hover:not(:disabled) {
    background-color: var(--cv-ui-bg-hover);
    border-color: var(--cv-ui-border-hover);
}
.cv-pagination__btn[data-v-37ca6743]:focus-visible {
    border-color: var(--cv-ui-border-focus);
    box-shadow: var(--cv-ui-shadow-focus);
}

/* Active page */
.cv-pagination__btn--active[data-v-37ca6743] {
    background-color: var(--cv-ui-color-primary) !important;
    border-color: var(--cv-ui-color-primary) !important;
    color: var(--cv-ui-text-inverse) !important;
    font-weight: var(--cv-ui-font-weight-semibold);
    cursor: default;
}

/* Disabled */
.cv-pagination__btn--disabled[data-v-37ca6743],
.cv-pagination__btn[data-v-37ca6743]:disabled {
    opacity: 0.4;
    cursor: not-allowed;
}
.cv-pagination__btn--disabled[data-v-37ca6743]:hover,
.cv-pagination__btn[data-v-37ca6743]:disabled:hover {
    background-color: var(--cv-ui-bg-primary);
    border-color: var(--cv-ui-border-color);
}

/* Ellipsis */
.cv-pagination__ellipsis[data-v-37ca6743] {
    display: inline-flex;
    align-items: flex-end;
    justify-content: center;
    color: var(--cv-ui-text-tertiary);
    user-select: none;
    padding: 0 var(--cv-ui-spacing-xs);
}
.cv-pagination--md .cv-pagination__ellipsis[data-v-37ca6743] {
    min-width: 36px;
    height: 36px;
}
.cv-pagination--sm .cv-pagination__ellipsis[data-v-37ca6743] {
    min-width: 28px;
    height: 28px;
    font-size: var(--cv-ui-font-size-xs);
}

.cv-stat-card[data-v-d028929c] {
    position: relative;
    display: flex;
    flex-direction: column;
    gap: var(--cv-ui-spacing-xs);
    padding: var(--cv-ui-spacing-md);
    background-color: var(--cv-ui-bg-primary);
    border: 1px solid var(--cv-ui-border-color);
    border-radius: var(--cv-ui-radius-xl);
    box-shadow: var(--cv-ui-shadow-sm);
    font-family: var(--cv-ui-font-family);
    overflow: hidden;
}

/* Icon badge */
.cv-stat-card__icon-wrap[data-v-d028929c] {
    position: absolute;
    top: var(--cv-ui-spacing-md);
    right: var(--cv-ui-spacing-md);
    display: flex;
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 40px;
    border-radius: var(--cv-ui-radius-lg);
}
.cv-stat-card__icon[data-v-d028929c] {
    width: 20px;
    height: 20px;
}

/* Severity color maps for the icon badge */
.cv-stat-card__icon-wrap--primary[data-v-d028929c] {
    background-color: var(--cv-ui-color-primary-light);
    color: var(--cv-ui-color-primary);
}
.cv-stat-card__icon-wrap--success[data-v-d028929c] {
    background-color: var(--cv-ui-color-success-light);
    color: var(--cv-ui-color-success);
}
.cv-stat-card__icon-wrap--warning[data-v-d028929c] {
    background-color: var(--cv-ui-color-warning-light);
    color: var(--cv-ui-color-warning);
}
.cv-stat-card__icon-wrap--danger[data-v-d028929c] {
    background-color: var(--cv-ui-color-danger-light);
    color: var(--cv-ui-color-danger);
}
.cv-stat-card__icon-wrap--info[data-v-d028929c] {
    background-color: var(--cv-ui-color-info-light);
    color: var(--cv-ui-color-info);
}

/* Label */
.cv-stat-card__label[data-v-d028929c] {
    font-size: var(--cv-ui-font-size-sm);
    font-weight: var(--cv-ui-font-weight-medium);
    color: var(--cv-ui-text-secondary);
    /* leave room for icon badge */
    padding-right: 52px;
}

/* Value row */
.cv-stat-card__value-row[data-v-d028929c] {
    display: flex;
    align-items: baseline;
}
.cv-stat-card__value[data-v-d028929c] {
    font-size: var(--cv-ui-font-size-xl);
    font-weight: var(--cv-ui-font-weight-bold);
    color: var(--cv-ui-text-primary);
    line-height: 1.2;
    letter-spacing: -0.02em;
}
.cv-stat-card__affix[data-v-d028929c] {
    font-size: var(--cv-ui-font-size-md);
    font-weight: var(--cv-ui-font-weight-semibold);
    color: var(--cv-ui-text-secondary);
}

/* Skeleton shimmer */
.cv-stat-card__skeleton[data-v-d028929c] {
    display: block;
    width: 120px;
    height: 2rem;
    border-radius: var(--cv-ui-radius-md);
    background: linear-gradient(
        90deg,
        var(--cv-ui-bg-tertiary) 25%,
        var(--cv-ui-bg-hover) 50%,
        var(--cv-ui-bg-tertiary) 75%
    );
    background-size: 200% 100%;
    animation: cv-stat-skeleton-shimmer-d028929c 1.4s ease-in-out infinite;
}
@keyframes cv-stat-skeleton-shimmer-d028929c {
0% { background-position: 200% 0;
}
100% { background-position: -200% 0;
}
}

/* Trend */
.cv-stat-card__trend[data-v-d028929c] {
    display: flex;
    align-items: center;
    gap: 4px;
    margin-top: 2px;
}
.cv-stat-card__trend-icon[data-v-d028929c] {
    display: inline-flex;
    align-items: center;
    flex-shrink: 0;
}
.cv-stat-card__trend-icon--up[data-v-d028929c] {
    color: var(--cv-ui-color-success);
}
.cv-stat-card__trend-icon--down[data-v-d028929c] {
    color: var(--cv-ui-color-danger);
}
.cv-stat-card__trend-icon--flat[data-v-d028929c] {
    color: var(--cv-ui-text-tertiary);
}
.cv-stat-card__trend-value[data-v-d028929c] {
    font-size: var(--cv-ui-font-size-sm);
    font-weight: var(--cv-ui-font-weight-semibold);
}
.cv-stat-card__trend-value--up[data-v-d028929c] {
    color: var(--cv-ui-color-success);
}
.cv-stat-card__trend-value--down[data-v-d028929c] {
    color: var(--cv-ui-color-danger);
}
.cv-stat-card__trend-value--flat[data-v-d028929c] {
    color: var(--cv-ui-text-tertiary);
}
.cv-stat-card__trend-label[data-v-d028929c] {
    font-size: var(--cv-ui-font-size-xs);
    color: var(--cv-ui-text-tertiary);
}

/* Footer slot */
.cv-stat-card__footer[data-v-d028929c] {
    margin-top: var(--cv-ui-spacing-xs);
    padding-top: var(--cv-ui-spacing-xs);
    border-top: 1px solid var(--cv-ui-border-color);
    font-size: var(--cv-ui-font-size-xs);
    color: var(--cv-ui-text-secondary);
}

.cv-timeline[data-v-6dc87734] {
    display: flex;
    flex-direction: column;
    position: relative;
    padding: 0;
    margin: 0;
    list-style: none;
}

/* The continuous vertical line drawn behind all items */
.cv-timeline[data-v-6dc87734]::before {
    content: '';
    position: absolute;
    top: 0;
    bottom: 0;
    width: 2px;
    background-color: var(--cv-ui-border-color);
}

/* left / right: line sits close to the dot column */
.cv-timeline--left[data-v-6dc87734]::before {
    left: 13px; /* centre of a 28px dot area */
}
.cv-timeline--right[data-v-6dc87734]::before {
    right: 13px;
}

/* alternate: line sits at the horizontal centre of the container */
.cv-timeline--alternate[data-v-6dc87734]::before {
    left: 50%;
    transform: translateX(-50%);
}

/* ── Item layout ─────────────────────────────────────────────────── */
.cv-timeline-item[data-v-9fc26da2] {
    --cv-timeline-dot-size: 12px;
    --cv-timeline-dot-col-width: 28px; /* fixed gutter for the dot area */
    --cv-timeline-severity-color: var(--cv-ui-color-primary);

    display: flex;
    align-items: flex-start;
    gap: var(--cv-ui-spacing-sm);
    padding-bottom: var(--cv-ui-spacing-lg);
    position: relative;
}

/* Remove bottom padding from the very last item */
.cv-timeline-item[data-v-9fc26da2]:last-child {
    padding-bottom: 0;
}

/* ── Severity colour tokens ──────────────────────────────────────── */
.cv-timeline-item--primary[data-v-9fc26da2]   { --cv-timeline-severity-color: var(--cv-ui-color-primary);
}
.cv-timeline-item--secondary[data-v-9fc26da2] { --cv-timeline-severity-color: var(--cv-ui-color-secondary);
}
.cv-timeline-item--success[data-v-9fc26da2]   { --cv-timeline-severity-color: var(--cv-ui-color-success);
}
.cv-timeline-item--warning[data-v-9fc26da2]   { --cv-timeline-severity-color: var(--cv-ui-color-warning);
}
.cv-timeline-item--danger[data-v-9fc26da2]    { --cv-timeline-severity-color: var(--cv-ui-color-danger);
}
.cv-timeline-item--info[data-v-9fc26da2]      { --cv-timeline-severity-color: var(--cv-ui-color-info);
}

/* ── Dot column ──────────────────────────────────────────────────── */
.cv-timeline-item__dot-col[data-v-9fc26da2] {
    flex-shrink: 0;
    width: var(--cv-timeline-dot-col-width);
    display: flex;
    align-items: flex-start;
    justify-content: center;
    /* Push the dot so its centre aligns with the parent ::before line */
    padding-top: 2px;
}
.cv-timeline-item__dot[data-v-9fc26da2] {
    width: var(--cv-timeline-dot-size);
    height: var(--cv-timeline-dot-size);
    border-radius: var(--cv-ui-radius-full);
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    position: relative;
    z-index: 1;
    transition: box-shadow var(--cv-ui-transition-fast) var(--cv-ui-transition-timing);
}

/* Filled dot */
.cv-timeline-item--filled .cv-timeline-item__dot[data-v-9fc26da2] {
    background-color: var(--cv-timeline-severity-color);
    border: 2px solid var(--cv-timeline-severity-color);
}

/* Outlined (ring) dot */
.cv-timeline-item--outlined .cv-timeline-item__dot[data-v-9fc26da2] {
    background-color: var(--cv-ui-bg-primary);
    border: 2px solid var(--cv-timeline-severity-color);
}

/* When an icon is present the dot grows to 28px to house it */
.cv-timeline-item--has-icon .cv-timeline-item__dot[data-v-9fc26da2] {
    width: 28px;
    height: 28px;
}
.cv-timeline-item__dot-icon[data-v-9fc26da2] {
    width: 14px;
    height: 14px;
    color: var(--cv-ui-bg-primary);
    flex-shrink: 0;
}
.cv-timeline-item--outlined.cv-timeline-item--has-icon .cv-timeline-item__dot-icon[data-v-9fc26da2] {
    color: var(--cv-timeline-severity-color);
}

/* ── Content ─────────────────────────────────────────────────────── */
.cv-timeline-item__content[data-v-9fc26da2] {
    flex: 1;
    min-width: 0;
    padding-top: 0;
}
.cv-timeline-item__title[data-v-9fc26da2] {
    margin: 0;
    font-family: var(--cv-ui-font-family);
    font-size: var(--cv-ui-font-size-sm);
    font-weight: var(--cv-ui-font-weight-semibold);
    color: var(--cv-ui-text-primary);
    line-height: 1.4;
}
.cv-timeline-item__subtitle[data-v-9fc26da2] {
    margin: 2px 0 0;
    font-family: var(--cv-ui-font-family);
    font-size: var(--cv-ui-font-size-xs);
    color: var(--cv-ui-text-secondary);
    line-height: 1.4;
}
.cv-timeline-item__body[data-v-9fc26da2] {
    margin-top: var(--cv-ui-spacing-xs);
    font-family: var(--cv-ui-font-family);
    font-size: var(--cv-ui-font-size-sm);
    color: var(--cv-ui-text-secondary);
    line-height: 1.6;
}

/* ── Right-aligned layout ────────────────────────────────────────── */
/*
 * When the parent timeline is `align="right"` the dot column moves to
 * the right and content flows to the left.
 */
.cv-timeline-item--align-right[data-v-9fc26da2] {
    flex-direction: row-reverse;
}
.cv-timeline-item--align-right .cv-timeline-item__content[data-v-9fc26da2] {
    text-align: right;
}

/* ── Alternate layout ────────────────────────────────────────────── */
/*
 * Use a 3-column grid: [left-half] [dot] [right-half]
 * The dot column is always in the center; content goes to one side only.
 * This prevents content from crossing the center line.
 */
.cv-timeline-item--align-alternate[data-v-9fc26da2] {
    display: grid;
    grid-template-columns:
        calc(50% - var(--cv-timeline-dot-col-width) / 2 - var(--cv-ui-spacing-sm) / 2)
        var(--cv-timeline-dot-col-width)
        calc(50% - var(--cv-timeline-dot-col-width) / 2 - var(--cv-ui-spacing-sm) / 2);
    gap: calc(var(--cv-ui-spacing-sm) / 2);
    align-items: flex-start;
}

/* Dot column always in the center column */
.cv-timeline-item--align-alternate .cv-timeline-item__dot-col[data-v-9fc26da2] {
    grid-column: 2;
    grid-row: 1;
    width: auto;
    justify-content: center;
}

/* Odd items: content on the LEFT, empty cell on the right */
.cv-timeline-item--align-alternate:nth-child(odd) .cv-timeline-item__content[data-v-9fc26da2] {
    grid-column: 1;
    grid-row: 1;
    text-align: right;
    min-width: 0;
}

/* Even items: empty cell on the left, content on the RIGHT */
.cv-timeline-item--align-alternate:nth-child(even) .cv-timeline-item__content[data-v-9fc26da2] {
    grid-column: 3;
    grid-row: 1;
    text-align: left;
    min-width: 0;
}

/* ── Backdrop ────────────────────────────────────────────────────── */
.cv-sidebar-backdrop[data-v-36e5200a] {
    position: fixed;
    inset: 0;
    z-index: var(--cv-ui-z-modal-backdrop);
    background-color: rgba(0, 0, 0, 0.4);
}

/* ── Panel ───────────────────────────────────────────────────────── */
.cv-sidebar-panel[data-v-36e5200a] {
    position: fixed;
    top: 0;
    bottom: 0;
    z-index: var(--cv-ui-z-modal);
    display: flex;
    flex-direction: column;
    background-color: var(--cv-ui-bg-primary);
    box-shadow: var(--cv-ui-shadow-xl);
    /* Height is always 100vh via top:0 / bottom:0 */
}
.cv-sidebar-panel--left[data-v-36e5200a] {
    left: 0;
    border-right: 1px solid var(--cv-ui-border-color);
}
.cv-sidebar-panel--right[data-v-36e5200a] {
    right: 0;
    border-left: 1px solid var(--cv-ui-border-color);
}

/* ── Header ──────────────────────────────────────────────────────── */
.cv-sidebar-panel__header[data-v-36e5200a] {
    flex-shrink: 0;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--cv-ui-spacing-sm);
    padding: var(--cv-ui-spacing-md) var(--cv-ui-spacing-lg);
    border-bottom: 1px solid var(--cv-ui-border-color);
    min-height: 56px;
}
.cv-sidebar-panel__title[data-v-36e5200a] {
    font-family: var(--cv-ui-font-family);
    font-size: var(--cv-ui-font-size-md);
    font-weight: var(--cv-ui-font-weight-semibold);
    color: var(--cv-ui-text-primary);
    flex: 1;
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.cv-sidebar-panel__close[data-v-36e5200a] {
    flex-shrink: 0;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 32px;
    height: 32px;
    padding: 0;
    border: none;
    border-radius: var(--cv-ui-radius-md);
    background-color: transparent;
    color: var(--cv-ui-text-secondary);
    cursor: pointer;
    transition:
        background-color var(--cv-ui-transition-fast) var(--cv-ui-transition-timing),
        color var(--cv-ui-transition-fast) var(--cv-ui-transition-timing);
}
.cv-sidebar-panel__close[data-v-36e5200a]:hover {
    background-color: var(--cv-ui-bg-hover);
    color: var(--cv-ui-text-primary);
}
.cv-sidebar-panel__close[data-v-36e5200a]:focus-visible {
    outline: 2px solid var(--cv-ui-border-focus);
    outline-offset: 2px;
}

/* ── Body ────────────────────────────────────────────────────────── */
.cv-sidebar-panel__body[data-v-36e5200a] {
    flex: 1;
    overflow-y: auto;
    padding: var(--cv-ui-spacing-lg);
    font-family: var(--cv-ui-font-family);
    font-size: var(--cv-ui-font-size-sm);
    color: var(--cv-ui-text-primary);
}

/* ── Footer ──────────────────────────────────────────────────────── */
.cv-sidebar-panel__footer[data-v-36e5200a] {
    flex-shrink: 0;
    padding: var(--cv-ui-spacing-md) var(--cv-ui-spacing-lg);
    border-top: 1px solid var(--cv-ui-border-color);
    display: flex;
    justify-content: flex-end;
    gap: var(--cv-ui-spacing-sm);
}

/* ── Backdrop fade transition ────────────────────────────────────── */
.cv-sidebar-fade-enter-active[data-v-36e5200a],
.cv-sidebar-fade-leave-active[data-v-36e5200a] {
    transition: opacity var(--cv-ui-transition-base) var(--cv-ui-transition-timing);
}
.cv-sidebar-fade-enter-from[data-v-36e5200a],
.cv-sidebar-fade-leave-to[data-v-36e5200a] {
    opacity: 0;
}

/* ── Panel slide-from-right transition ───────────────────────────── */
.cv-sidebar-slide-right-enter-active[data-v-36e5200a],
.cv-sidebar-slide-right-leave-active[data-v-36e5200a] {
    transition: transform var(--cv-ui-transition-slow) var(--cv-ui-transition-timing);
}
.cv-sidebar-slide-right-enter-from[data-v-36e5200a],
.cv-sidebar-slide-right-leave-to[data-v-36e5200a] {
    transform: translateX(100%);
}

/* ── Panel slide-from-left transition ────────────────────────────── */
.cv-sidebar-slide-left-enter-active[data-v-36e5200a],
.cv-sidebar-slide-left-leave-active[data-v-36e5200a] {
    transition: transform var(--cv-ui-transition-slow) var(--cv-ui-transition-timing);
}
.cv-sidebar-slide-left-enter-from[data-v-36e5200a],
.cv-sidebar-slide-left-leave-to[data-v-36e5200a] {
    transform: translateX(-100%);
}

.cv-alert[data-v-09d42d69] {
        display: flex;
        align-items: flex-start;
        gap: var(--cv-ui-spacing-sm);
        padding: var(--cv-ui-spacing-sm) var(--cv-ui-spacing-md);
        border-radius: var(--cv-ui-radius-md);
        font-family: var(--cv-ui-font-family);
        font-size: var(--cv-ui-font-size-sm);
        border: 1px solid transparent;
        width: 100%;
        box-sizing: border-box;
}
.cv-alert__icon[data-v-09d42d69] {
        flex-shrink: 0;
        display: inline-flex;
        align-items: center;
        justify-content: center;
        width: 20px;
        height: 20px;
        margin-top: 1px;
}
.cv-alert__icon-svg[data-v-09d42d69],
    .cv-alert__icon[data-v-09d42d69] svg {
        display: block;
        width: 20px;
        height: 20px;
        flex-shrink: 0;
}
.cv-alert__body[data-v-09d42d69] {
        flex: 1;
        min-width: 0;
        display: flex;
        flex-direction: column;
        gap: 2px;
}
.cv-alert__title[data-v-09d42d69] {
        margin: 0;
        font-weight: var(--cv-ui-font-weight-semibold);
        font-size: var(--cv-ui-font-size-sm);
        line-height: 1.4;
}
.cv-alert__message[data-v-09d42d69] {
        line-height: 1.5;
        font-weight: var(--cv-ui-font-weight-normal);
}
.cv-alert__action[data-v-09d42d69] {
        margin-top: var(--cv-ui-spacing-xs);
}
.cv-alert__close[data-v-09d42d69] {
        flex-shrink: 0;
        display: inline-flex;
        align-items: center;
        justify-content: center;
        width: 1.5rem;
        height: 1.5rem;
        padding: 0;
        border: none;
        border-radius: var(--cv-ui-radius-sm);
        background: transparent;
        cursor: pointer;
        opacity: 0.7;
        color: inherit;
        transition: opacity var(--cv-ui-transition-fast) var(--cv-ui-transition-timing),
            background-color var(--cv-ui-transition-fast) var(--cv-ui-transition-timing);
        margin-top: 0;
}
.cv-alert__close[data-v-09d42d69]:hover {
        opacity: 1;
}
.cv-alert__close[data-v-09d42d69]:focus-visible {
        outline: 2px solid currentColor;
        outline-offset: 2px;
}
.cv-alert__close-icon[data-v-09d42d69] {
        width: 1rem;
        height: 1rem;
}

    /* ── Subtle variant ─────────────────────────────────────── */
.cv-alert--subtle.cv-alert--success[data-v-09d42d69] {
        background-color: var(--cv-ui-color-success-light);
        color: var(--cv-ui-color-success-dark);
        border-color: transparent;
}
.cv-alert--subtle.cv-alert--info[data-v-09d42d69] {
        background-color: var(--cv-ui-color-info-light);
        color: var(--cv-ui-color-info-dark);
        border-color: transparent;
}
.cv-alert--subtle.cv-alert--warning[data-v-09d42d69] {
        background-color: var(--cv-ui-color-warning-light);
        color: var(--cv-ui-color-warning-dark);
        border-color: transparent;
}
.cv-alert--subtle.cv-alert--danger[data-v-09d42d69] {
        background-color: var(--cv-ui-color-danger-light);
        color: var(--cv-ui-color-danger-dark);
        border-color: transparent;
}

    /* ── Filled variant ─────────────────────────────────────── */
.cv-alert--filled.cv-alert--success[data-v-09d42d69] {
        background-color: var(--cv-ui-color-success);
        color: var(--cv-ui-text-inverse);
        border-color: transparent;
}
.cv-alert--filled.cv-alert--info[data-v-09d42d69] {
        background-color: var(--cv-ui-color-info);
        color: var(--cv-ui-text-inverse);
        border-color: transparent;
}
.cv-alert--filled.cv-alert--warning[data-v-09d42d69] {
        background-color: var(--cv-ui-color-warning);
        color: var(--cv-ui-text-inverse);
        border-color: transparent;
}
.cv-alert--filled.cv-alert--danger[data-v-09d42d69] {
        background-color: var(--cv-ui-color-danger);
        color: var(--cv-ui-text-inverse);
        border-color: transparent;
}

    /* ── Outlined variant ───────────────────────────────────── */
.cv-alert--outlined.cv-alert--success[data-v-09d42d69] {
        background-color: transparent;
        color: var(--cv-ui-color-success-dark);
        border-color: var(--cv-ui-color-success);
}
.cv-alert--outlined.cv-alert--info[data-v-09d42d69] {
        background-color: transparent;
        color: var(--cv-ui-color-info-dark);
        border-color: var(--cv-ui-color-info);
}
.cv-alert--outlined.cv-alert--warning[data-v-09d42d69] {
        background-color: transparent;
        color: var(--cv-ui-color-warning-dark);
        border-color: var(--cv-ui-color-warning);
}
.cv-alert--outlined.cv-alert--danger[data-v-09d42d69] {
        background-color: transparent;
        color: var(--cv-ui-color-danger-dark);
        border-color: var(--cv-ui-color-danger);
}

.cv-badge-wrapper[data-v-448de034] {
        position: relative;
        display: inline-flex;
        vertical-align: middle;
        flex-shrink: 0;
}
.cv-badge[data-v-448de034] {
        position: absolute;
        top: 0;
        right: 0;
        display: inline-flex;
        align-items: center;
        justify-content: center;
        font-family: var(--cv-ui-font-family);
        font-size: var(--cv-ui-font-size-xs);
        font-weight: var(--cv-ui-font-weight-bold);
        line-height: 1;
        white-space: nowrap;
        border-radius: var(--cv-ui-radius-full);
        min-width: 18px;
        height: 18px;
        padding: 0 4px;
        box-sizing: border-box;
        pointer-events: none;
        z-index: 1;
}
.cv-badge--dot[data-v-448de034] {
        min-width: 8px;
        width: 8px;
        height: 8px;
        padding: 0;
        border-radius: var(--cv-ui-radius-full);
}
.cv-badge--empty[data-v-448de034] {
        min-width: 8px;
        width: 8px;
        height: 8px;
        padding: 0;
}

    /* Severity colors */
.cv-badge--danger[data-v-448de034] {
        background-color: var(--cv-ui-color-danger);
        color: var(--cv-ui-text-inverse);
}
.cv-badge--primary[data-v-448de034] {
        background-color: var(--cv-ui-color-primary);
        color: var(--cv-ui-text-inverse);
}
.cv-badge--success[data-v-448de034] {
        background-color: var(--cv-ui-color-success);
        color: var(--cv-ui-text-inverse);
}
.cv-badge--warning[data-v-448de034] {
        background-color: var(--cv-ui-color-warning);
        color: var(--cv-ui-text-inverse);
}

    /* Transition */
.cv-badge-enter-active[data-v-448de034],
    .cv-badge-leave-active[data-v-448de034] {
        transition:
            transform var(--cv-ui-transition-fast) var(--cv-ui-transition-timing),
            opacity var(--cv-ui-transition-fast) var(--cv-ui-transition-timing);
}
.cv-badge-enter-from[data-v-448de034] {
        opacity: 0;
        transform: scale(0.5) translate(50%, -50%);
}
.cv-badge-leave-to[data-v-448de034] {
        opacity: 0;
        transform: scale(0.5) translate(50%, -50%);
}

.cv-avatar[data-v-af7d6f2e] {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        flex-shrink: 0;
        overflow: hidden;
        font-family: var(--cv-ui-font-family);
        font-weight: var(--cv-ui-font-weight-semibold);
        user-select: none;
        box-sizing: border-box;
}
.cv-avatar--circle[data-v-af7d6f2e] {
        border-radius: var(--cv-ui-radius-full);
}
.cv-avatar--square[data-v-af7d6f2e] {
        border-radius: var(--cv-ui-radius-md);
}
.cv-avatar__img[data-v-af7d6f2e] {
        width: 100%;
        height: 100%;
        object-fit: cover;
        display: block;
}
.cv-avatar__initials[data-v-af7d6f2e] {
        line-height: 1;
        letter-spacing: 0.03em;
}

    /* Severity backgrounds for initials */
.cv-avatar--primary[data-v-af7d6f2e] {
        background-color: var(--cv-ui-color-primary);
        color: var(--cv-ui-text-inverse);
}
.cv-avatar--secondary[data-v-af7d6f2e] {
        background-color: var(--cv-ui-color-secondary);
        color: var(--cv-ui-text-inverse);
}
.cv-avatar--success[data-v-af7d6f2e] {
        background-color: var(--cv-ui-color-success);
        color: var(--cv-ui-text-inverse);
}
.cv-avatar--warning[data-v-af7d6f2e] {
        background-color: var(--cv-ui-color-warning);
        color: var(--cv-ui-text-inverse);
}
.cv-avatar--danger[data-v-af7d6f2e] {
        background-color: var(--cv-ui-color-danger);
        color: var(--cv-ui-text-inverse);
}

.cv-avatar-group[data-v-d945342b] {
        display: inline-flex;
        align-items: center;
        flex-direction: row-reverse;
}

    /* Overlap: each avatar overlaps the previous by ~25% */
.cv-avatar-group[data-v-d945342b] >  .cv-avatar,
    .cv-avatar-group[data-v-d945342b] >  [class*='cv-avatar'],
    .cv-avatar-group__overflow[data-v-d945342b] {
        margin-left: -8px;
        box-shadow: 0 0 0 2px var(--cv-ui-bg-primary);
        transition: transform var(--cv-ui-transition-fast) var(--cv-ui-transition-timing);
}
.cv-avatar-group[data-v-d945342b] >  .cv-avatar:hover,
    .cv-avatar-group__overflow[data-v-d945342b]:hover {
        transform: translateY(-2px);
        z-index: 1;
}
.cv-avatar-group[data-v-d945342b] >  .cv-avatar:last-child,
    .cv-avatar-group__overflow[data-v-d945342b]:last-child {
        margin-left: 0;
}
.cv-avatar-group__overflow[data-v-d945342b] {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        border-radius: var(--cv-ui-radius-full);
        background-color: var(--cv-ui-bg-tertiary);
        color: var(--cv-ui-text-secondary);
        font-family: var(--cv-ui-font-family);
        font-weight: var(--cv-ui-font-weight-semibold);
        cursor: default;
        user-select: none;
        flex-shrink: 0;
        box-sizing: border-box;
}

.cv-skeleton-wrapper[data-v-fa80171a] {
        display: flex;
        flex-direction: column;
        gap: var(--cv-ui-spacing-xs);
        width: 100%;
}
.cv-skeleton[data-v-fa80171a] {
        display: block;
        background-color: var(--cv-ui-bg-tertiary);
        position: relative;
        overflow: hidden;
        border-radius: var(--cv-ui-radius-sm);
}

    /* Variant shapes */
.cv-skeleton--text[data-v-fa80171a] {
        height: 1em;
        border-radius: var(--cv-ui-radius-sm);
        width: 100%;
}
.cv-skeleton--circular[data-v-fa80171a] {
        border-radius: var(--cv-ui-radius-full);
        width: 40px;
        height: 40px;
}
.cv-skeleton--rectangular[data-v-fa80171a] {
        border-radius: 0;
        width: 100%;
        height: 120px;
}
.cv-skeleton--rounded[data-v-fa80171a] {
        border-radius: var(--cv-ui-radius-lg);
        width: 100%;
        height: 120px;
}

    /* Shimmer animation */
.cv-skeleton--animate[data-v-fa80171a]::after {
        content: '';
        position: absolute;
        inset: 0;
        background: linear-gradient(
            90deg,
            transparent 0%,
            var(--cv-ui-bg-hover) 40%,
            var(--cv-ui-bg-active) 55%,
            var(--cv-ui-bg-hover) 70%,
            transparent 100%
        );
        background-size: 200% 100%;
        animation: cv-skeleton-shimmer-fa80171a 1.6s ease-in-out infinite;
}
@keyframes cv-skeleton-shimmer-fa80171a {
0% {
            background-position: 200% 0;
}
100% {
            background-position: -200% 0;
}
}

    /* ── Base ───────────────────────────────────────────────── */
.cv-divider[data-v-e13bd1c5] {
        flex-shrink: 0;
        font-family: var(--cv-ui-font-family);
        font-size: var(--cv-ui-font-size-xs);
        font-weight: var(--cv-ui-font-weight-medium);
        color: var(--cv-ui-text-tertiary);
        border-color: var(--cv-ui-border-color);
}

    /* ── Horizontal ─────────────────────────────────────────── */
.cv-divider--horizontal[data-v-e13bd1c5] {
        display: block;
        width: 100%;
        border-top-style: solid; /* overridden by variant */
        border-top-width: 1px;
        border-right: none;
        border-bottom: none;
        border-left: none;
}
.cv-divider--horizontal.cv-divider--md[data-v-e13bd1c5] {
        border-top-width: 2px;
}

    /* Variant line styles */
.cv-divider--solid.cv-divider--horizontal[data-v-e13bd1c5] {
        border-top-style: solid;
}
.cv-divider--dashed.cv-divider--horizontal[data-v-e13bd1c5] {
        border-top-style: dashed;
}
.cv-divider--dotted.cv-divider--horizontal[data-v-e13bd1c5] {
        border-top-style: dotted;
}

    /* ── Horizontal with label ─────────────────────────────── */
.cv-divider--horizontal.cv-divider--has-label[data-v-e13bd1c5] {
        display: flex;
        align-items: center;
        border: none;
        gap: var(--cv-ui-spacing-sm);
}
.cv-divider--horizontal.cv-divider--has-label[data-v-e13bd1c5]::before,
    .cv-divider--horizontal.cv-divider--has-label[data-v-e13bd1c5]::after {
        content: '';
        flex: 1;
        border-color: inherit;
        border-top-width: 1px;
        border-top-style: solid;
        border-right: none;
        border-bottom: none;
        border-left: none;
}
.cv-divider--md.cv-divider--has-label[data-v-e13bd1c5]::before,
    .cv-divider--md.cv-divider--has-label[data-v-e13bd1c5]::after {
        border-top-width: 2px;
}
.cv-divider--solid.cv-divider--has-label[data-v-e13bd1c5]::before,
    .cv-divider--solid.cv-divider--has-label[data-v-e13bd1c5]::after {
        border-top-style: solid;
}
.cv-divider--dashed.cv-divider--has-label[data-v-e13bd1c5]::before,
    .cv-divider--dashed.cv-divider--has-label[data-v-e13bd1c5]::after {
        border-top-style: dashed;
}
.cv-divider--dotted.cv-divider--has-label[data-v-e13bd1c5]::before,
    .cv-divider--dotted.cv-divider--has-label[data-v-e13bd1c5]::after {
        border-top-style: dotted;
}

    /* Label position */
.cv-divider--label-start[data-v-e13bd1c5]::before {
        flex: 0 0 var(--cv-ui-spacing-md);
        flex-basis: var(--cv-ui-spacing-md);
}
.cv-divider--label-end[data-v-e13bd1c5]::after {
        flex: 0 0 var(--cv-ui-spacing-md);
        flex-basis: var(--cv-ui-spacing-md);
}
.cv-divider__label[data-v-e13bd1c5] {
        white-space: nowrap;
        flex-shrink: 0;
}

    /* ── Vertical ───────────────────────────────────────────── */
.cv-divider--vertical[data-v-e13bd1c5] {
        display: inline-block;
        width: 1px;
        height: 100%;
        min-height: 1em;
        border-left-style: solid;
        border-left-width: 1px;
        border-right: none;
        border-top: none;
        border-bottom: none;
        align-self: stretch;
}
.cv-divider--vertical.cv-divider--md[data-v-e13bd1c5] {
        width: 2px;
        border-left-width: 2px;
}
.cv-divider--solid.cv-divider--vertical[data-v-e13bd1c5] {
        border-left-style: solid;
}
.cv-divider--dashed.cv-divider--vertical[data-v-e13bd1c5] {
        border-left-style: dashed;
}
.cv-divider--dotted.cv-divider--vertical[data-v-e13bd1c5] {
        border-left-style: dotted;
}

.cv-breadcrumb[data-v-3c65ab20] {
        display: inline-flex;
        align-items: center;
        font-family: var(--cv-ui-font-family);
        font-size: var(--cv-ui-font-size-sm);
}
.cv-breadcrumb__list[data-v-3c65ab20] {
        display: flex;
        flex-wrap: wrap;
        align-items: center;
        gap: 0;
        list-style: none;
        margin: 0;
        padding: 0;
}
.cv-breadcrumb__item[data-v-3c65ab20] {
        display: flex;
        align-items: center;
        gap: var(--cv-ui-spacing-xs);
}
.cv-breadcrumb__separator[data-v-3c65ab20] {
        display: inline-flex;
        align-items: center;
        padding: 0 var(--cv-ui-spacing-xs);
        color: var(--cv-ui-text-tertiary);
        user-select: none;
}
.cv-breadcrumb__link[data-v-3c65ab20] {
        display: inline-flex;
        align-items: center;
        gap: var(--cv-ui-spacing-xs);
        color: var(--cv-ui-text-secondary);
        text-decoration: none;
        border-radius: var(--cv-ui-radius-sm);
        transition:
            color var(--cv-ui-transition-fast) var(--cv-ui-transition-timing),
            text-decoration-color var(--cv-ui-transition-fast) var(--cv-ui-transition-timing);
        outline: none;
}
.cv-breadcrumb__link[data-v-3c65ab20]:hover {
        color: var(--cv-ui-text-primary);
        text-decoration: underline;
}
.cv-breadcrumb__link[data-v-3c65ab20]:focus-visible {
        outline: 2px solid var(--cv-ui-border-focus);
        outline-offset: 2px;
}
.cv-breadcrumb__label[data-v-3c65ab20] {
        display: inline-flex;
        align-items: center;
        gap: var(--cv-ui-spacing-xs);
        color: var(--cv-ui-text-secondary);
}
.cv-breadcrumb__label--current[data-v-3c65ab20] {
        color: var(--cv-ui-text-primary);
        font-weight: var(--cv-ui-font-weight-medium);
}
.cv-breadcrumb__ellipsis[data-v-3c65ab20] {
        display: inline-flex;
        align-items: center;
        color: var(--cv-ui-text-tertiary);
        padding: 0 var(--cv-ui-spacing-xs);
        font-size: var(--cv-ui-font-size-md);
        letter-spacing: 0.05em;
}
.cv-breadcrumb__icon[data-v-3c65ab20] {
        width: 1em;
        height: 1em;
        flex-shrink: 0;
}

.cv-accordion[data-v-e57da5b7] {
        width: 100%;
        font-family: var(--cv-ui-font-family);
}

    /* Default variant: simple dividers */
.cv-accordion--default[data-v-e57da5b7] {
        border-top: 1px solid var(--cv-ui-border-color);
}

    /* Bordered variant: single outer border box */
.cv-accordion--bordered[data-v-e57da5b7] {
        border: 1px solid var(--cv-ui-border-color);
        border-radius: var(--cv-ui-radius-lg);
        overflow: hidden;
}

    /* Separated variant: each item is its own card */
.cv-accordion--separated[data-v-e57da5b7] {
        display: flex;
        flex-direction: column;
        gap: var(--cv-ui-spacing-sm);
}

.cv-accordion-item[data-v-1938ce4d] {
        border-bottom: 1px solid var(--cv-ui-border-color);
}

    /* Separated variant — parent sets gap, item needs its own border box */
[data-v-1938ce4d] .cv-accordion--separated .cv-accordion-item {
        border: 1px solid var(--cv-ui-border-color);
        border-radius: var(--cv-ui-radius-lg);
        overflow: hidden;
}

    /* Bordered variant — no individual bottom border except between items */
[data-v-1938ce4d] .cv-accordion--bordered .cv-accordion-item:last-child {
        border-bottom: none;
}

    /* Separated variant — remove individual bottom border (box border handles it) */
[data-v-1938ce4d] .cv-accordion--separated .cv-accordion-item {
        border-bottom: 1px solid var(--cv-ui-border-color);
}
.cv-accordion-item__heading[data-v-1938ce4d] {
        margin: 0;
        padding: 0;
}
.cv-accordion-item__trigger[data-v-1938ce4d] {
        display: flex;
        align-items: center;
        justify-content: space-between;
        width: 100%;
        padding: var(--cv-ui-spacing-md);
        background: transparent;
        border: none;
        cursor: pointer;
        text-align: left;
        font-family: var(--cv-ui-font-family);
        font-size: var(--cv-ui-font-size-sm);
        font-weight: var(--cv-ui-font-weight-medium);
        color: var(--cv-ui-text-primary);
        transition: background-color var(--cv-ui-transition-fast) var(--cv-ui-transition-timing);
        outline: none;
        gap: var(--cv-ui-spacing-sm);
}
.cv-accordion-item__trigger[data-v-1938ce4d]:hover:not(:disabled) {
        background-color: var(--cv-ui-bg-hover);
}
.cv-accordion-item__trigger[data-v-1938ce4d]:focus-visible {
        background-color: var(--cv-ui-bg-hover);
        box-shadow: inset 0 0 0 2px var(--cv-ui-border-focus);
}
.cv-accordion-item__trigger[data-v-1938ce4d]:disabled {
        opacity: 0.5;
        cursor: not-allowed;
}
.cv-accordion-item__title[data-v-1938ce4d] {
        flex: 1;
        min-width: 0;
}
.cv-accordion-item__chevron[data-v-1938ce4d] {
        flex-shrink: 0;
        display: inline-flex;
        align-items: center;
        color: var(--cv-ui-text-tertiary);
        transition: transform var(--cv-ui-transition-base) var(--cv-ui-transition-timing);
}
.cv-accordion-item--open .cv-accordion-item__chevron[data-v-1938ce4d] {
        transform: rotate(180deg);
}
.cv-accordion-item__panel[data-v-1938ce4d] {
        overflow: hidden;
        max-height: 0;
        transition: max-height var(--cv-ui-transition-slow) var(--cv-ui-transition-timing);
}
.cv-accordion-item__panel-inner[data-v-1938ce4d] {
        padding: 0 var(--cv-ui-spacing-md) var(--cv-ui-spacing-md);
        font-size: var(--cv-ui-font-size-sm);
        color: var(--cv-ui-text-secondary);
        line-height: 1.6;
}

.cv-card[data-v-48e71473] {
        position: relative;
        display: flex;
        flex-direction: column;
        background-color: var(--cv-ui-bg-primary);
        font-family: var(--cv-ui-font-family);
        overflow: hidden;
        transition:
            box-shadow var(--cv-ui-transition-base) var(--cv-ui-transition-timing),
            transform var(--cv-ui-transition-base) var(--cv-ui-transition-timing);
}

    /* ── Border ── */
.cv-card--border[data-v-48e71473] {
        border: 1px solid var(--cv-ui-border-color);
}

    /* ── Radius ── */
.cv-card--radius-sm[data-v-48e71473] { border-radius: var(--cv-ui-radius-sm);
}
.cv-card--radius-md[data-v-48e71473] { border-radius: var(--cv-ui-radius-md);
}
.cv-card--radius-lg[data-v-48e71473] { border-radius: var(--cv-ui-radius-lg);
}
.cv-card--radius-xl[data-v-48e71473] { border-radius: var(--cv-ui-radius-xl);
}

    /* ── Shadow ── */
.cv-card--shadow-none[data-v-48e71473] { box-shadow: none;
}
.cv-card--shadow-sm[data-v-48e71473]   { box-shadow: var(--cv-ui-shadow-sm);
}
.cv-card--shadow-md[data-v-48e71473]   { box-shadow: var(--cv-ui-shadow-md);
}
.cv-card--shadow-lg[data-v-48e71473]   { box-shadow: var(--cv-ui-shadow-lg);
}

    /* ── Hoverable / Clickable ── */
.cv-card--hoverable[data-v-48e71473]:hover {
        box-shadow: var(--cv-ui-shadow-lg);
}
.cv-card--clickable[data-v-48e71473] {
        cursor: pointer;
        user-select: none;
}
.cv-card--clickable[data-v-48e71473]:hover {
        transform: translateY(-2px);
        box-shadow: var(--cv-ui-shadow-lg);
}
.cv-card--clickable[data-v-48e71473]:active {
        transform: translateY(0);
        box-shadow: var(--cv-ui-shadow-md);
}
.cv-card--clickable[data-v-48e71473]:focus-visible {
        outline: 2px solid var(--cv-ui-border-focus);
        outline-offset: 2px;
}

    /* ── Media ── */
.cv-card__media[data-v-48e71473] {
        flex-shrink: 0;
        overflow: hidden;
        /* Rounded top corners only — clip the media content */
        border-radius: inherit;
        border-bottom-left-radius: 0;
        border-bottom-right-radius: 0;
        line-height: 0;
}
.cv-card__media[data-v-48e71473] >  img,
    .cv-card__media[data-v-48e71473] >  video {
        display: block;
        width: 100%;
        object-fit: cover;
}

    /* ── Header ── */
.cv-card__header[data-v-48e71473] {
        flex-shrink: 0;
        border-bottom: 1px solid var(--cv-ui-border-color);
        font-size: var(--cv-ui-font-size-md);
        font-weight: var(--cv-ui-font-weight-semibold);
        color: var(--cv-ui-text-primary);
}

    /* ── Body ── */
.cv-card__body[data-v-48e71473] {
        flex: 1;
        font-size: var(--cv-ui-font-size-sm);
        color: var(--cv-ui-text-primary);
}

    /* ── Footer ── */
.cv-card__footer[data-v-48e71473] {
        flex-shrink: 0;
        border-top: 1px solid var(--cv-ui-border-color);
        font-size: var(--cv-ui-font-size-sm);
        color: var(--cv-ui-text-secondary);
}

    /* ── Padding helpers ── */
.cv-card--pad-none[data-v-48e71473] { padding: 0;
}
.cv-card--pad-sm[data-v-48e71473]   { padding: var(--cv-ui-spacing-sm);
}
.cv-card--pad-md[data-v-48e71473]   { padding: var(--cv-ui-spacing-md);
}
.cv-card--pad-lg[data-v-48e71473]   { padding: var(--cv-ui-spacing-lg);
}

.cv-slider[data-v-1fcd11c1] {
        position: relative;
        width: 100%;
        padding: var(--cv-ui-spacing-sm) 0;
        user-select: none;
}
.cv-slider--disabled[data-v-1fcd11c1] {
        opacity: 0.5;
        cursor: not-allowed;
        pointer-events: none;
}

    /* Track container */
.cv-slider__track[data-v-1fcd11c1] {
        position: relative;
        width: 100%;
        cursor: pointer;
}

    /* Size variants — track height */
.cv-slider--sm .cv-slider__track[data-v-1fcd11c1] {
        height: 24px;
}
.cv-slider--md .cv-slider__track[data-v-1fcd11c1] {
        height: 28px;
}
.cv-slider--lg .cv-slider__track[data-v-1fcd11c1] {
        height: 32px;
}

    /* Rail (background bar) */
.cv-slider__rail[data-v-1fcd11c1] {
        position: absolute;
        left: 0;
        right: 0;
        top: 50%;
        transform: translateY(-50%);
        background: var(--cv-ui-border-color);
        border-radius: var(--cv-ui-radius-full);
}
.cv-slider--sm .cv-slider__rail[data-v-1fcd11c1] {
        height: 4px;
}
.cv-slider--md .cv-slider__rail[data-v-1fcd11c1] {
        height: 6px;
}
.cv-slider--lg .cv-slider__rail[data-v-1fcd11c1] {
        height: 8px;
}

    /* Filled portion */
.cv-slider__fill[data-v-1fcd11c1] {
        position: absolute;
        top: 50%;
        transform: translateY(-50%);
        border-radius: var(--cv-ui-radius-full);
        pointer-events: none;
        transition: left var(--cv-ui-transition-fast) var(--cv-ui-transition-timing),
                    width var(--cv-ui-transition-fast) var(--cv-ui-transition-timing);
}

    /* No transition lag during active drag */
.cv-slider__fill--dragging[data-v-1fcd11c1] {
        transition: none;
}
.cv-slider--sm .cv-slider__fill[data-v-1fcd11c1] {
        height: 4px;
}
.cv-slider--md .cv-slider__fill[data-v-1fcd11c1] {
        height: 6px;
}
.cv-slider--lg .cv-slider__fill[data-v-1fcd11c1] {
        height: 8px;
}

    /* Severity colors for fill */
.cv-slider--primary .cv-slider__fill[data-v-1fcd11c1] {
        background: var(--cv-ui-color-primary);
}
.cv-slider--success .cv-slider__fill[data-v-1fcd11c1] {
        background: var(--cv-ui-color-success);
}
.cv-slider--warning .cv-slider__fill[data-v-1fcd11c1] {
        background: var(--cv-ui-color-warning);
}
.cv-slider--danger .cv-slider__fill[data-v-1fcd11c1] {
        background: var(--cv-ui-color-danger);
}

    /* Thumb */
.cv-slider__thumb[data-v-1fcd11c1] {
        position: absolute;
        top: 50%;
        transform: translate(-50%, -50%);
        border-radius: var(--cv-ui-radius-full);
        background: var(--cv-ui-bg-primary);
        border: 2px solid currentColor;
        box-shadow: var(--cv-ui-shadow-sm);
        cursor: grab;
        transition:
            box-shadow var(--cv-ui-transition-fast) var(--cv-ui-transition-timing),
            transform var(--cv-ui-transition-fast) var(--cv-ui-transition-timing);
        outline: none;
        z-index: 2;
}
.cv-slider__thumb[data-v-1fcd11c1]:active {
        cursor: grabbing;
        transform: translate(-50%, -50%) scale(1.15);
}
.cv-slider--primary .cv-slider__thumb[data-v-1fcd11c1] {
        color: var(--cv-ui-color-primary);
}
.cv-slider--success .cv-slider__thumb[data-v-1fcd11c1] {
        color: var(--cv-ui-color-success);
}
.cv-slider--warning .cv-slider__thumb[data-v-1fcd11c1] {
        color: var(--cv-ui-color-warning);
}
.cv-slider--danger .cv-slider__thumb[data-v-1fcd11c1] {
        color: var(--cv-ui-color-danger);
}
.cv-slider--sm .cv-slider__thumb[data-v-1fcd11c1] {
        width: 16px;
        height: 16px;
        border-width: 2px;
}
.cv-slider--md .cv-slider__thumb[data-v-1fcd11c1] {
        width: 20px;
        height: 20px;
        border-width: 2px;
}
.cv-slider--lg .cv-slider__thumb[data-v-1fcd11c1] {
        width: 24px;
        height: 24px;
        border-width: 3px;
}
.cv-slider__thumb[data-v-1fcd11c1]:hover,
    .cv-slider__thumb[data-v-1fcd11c1]:focus-visible {
        box-shadow: 0 0 0 4px color-mix(in srgb, currentColor 20%, transparent);
}
.cv-slider__thumb[data-v-1fcd11c1]:focus-visible {
        box-shadow: 0 0 0 4px color-mix(in srgb, currentColor 30%, transparent);
}

    /* Tooltip */
.cv-slider__tooltip[data-v-1fcd11c1] {
        position: absolute;
        bottom: calc(100% + 8px);
        left: 50%;
        transform: translateX(-50%);
        background: var(--cv-ui-text-primary);
        color: var(--cv-ui-text-inverse);
        font-family: var(--cv-ui-font-family);
        font-size: var(--cv-ui-font-size-xs);
        font-weight: var(--cv-ui-font-weight-medium);
        white-space: nowrap;
        padding: 2px 6px;
        border-radius: var(--cv-ui-radius-sm);
        pointer-events: none;
}
.cv-slider__tooltip[data-v-1fcd11c1]::after {
        content: '';
        position: absolute;
        top: 100%;
        left: 50%;
        transform: translateX(-50%);
        border: 4px solid transparent;
        border-top-color: var(--cv-ui-text-primary);
}

    /* Tick marks */
.cv-slider__mark[data-v-1fcd11c1] {
        position: absolute;
        top: 50%;
        transform: translate(-50%, -50%);
        width: 4px;
        background: var(--cv-ui-bg-primary);
        border-radius: var(--cv-ui-radius-full);
        pointer-events: none;
        border: 1px solid var(--cv-ui-border-color);
}
.cv-slider--sm .cv-slider__mark[data-v-1fcd11c1] {
        height: 4px;
}
.cv-slider--md .cv-slider__mark[data-v-1fcd11c1] {
        height: 6px;
}
.cv-slider--lg .cv-slider__mark[data-v-1fcd11c1] {
        height: 8px;
}

.cv-otp-input[data-v-18cd89a0] {
        display: inline-flex;
        align-items: center;
        gap: var(--cv-ui-spacing-sm);
}
.cv-otp-input--disabled[data-v-18cd89a0] {
        opacity: 0.6;
        cursor: not-allowed;
        pointer-events: none;
}
.cv-otp-input__field[data-v-18cd89a0] {
        display: block;
        font-family: 'Courier New', Courier, monospace;
        font-weight: var(--cv-ui-font-weight-semibold);
        color: var(--cv-ui-text-primary);
        background-color: var(--cv-ui-bg-primary);
        border: 1.5px solid var(--cv-ui-border-color);
        border-radius: var(--cv-ui-radius-md);
        text-align: center;
        box-shadow: var(--cv-ui-shadow-sm);
        outline: none;
        transition:
            border-color var(--cv-ui-transition-fast) var(--cv-ui-transition-timing),
            box-shadow var(--cv-ui-transition-fast) var(--cv-ui-transition-timing);
        /* Remove browser number input arrows */
        -moz-appearance: textfield;
}
.cv-otp-input__field[data-v-18cd89a0]::-webkit-outer-spin-button,
    .cv-otp-input__field[data-v-18cd89a0]::-webkit-inner-spin-button {
        -webkit-appearance: none;
        margin: 0;
}
.cv-otp-input__field[data-v-18cd89a0]::placeholder {
        color: var(--cv-ui-text-tertiary);
}
.cv-otp-input__field[data-v-18cd89a0]:hover:not(:disabled) {
        border-color: var(--cv-ui-border-color-hover);
}
.cv-otp-input__field[data-v-18cd89a0]:focus {
        border-color: var(--cv-ui-border-color-focus);
        box-shadow: var(--cv-ui-shadow-focus);
}

    /* Status variants */
.cv-otp-input--error .cv-otp-input__field[data-v-18cd89a0] {
        border-color: var(--cv-ui-border-color-error);
}
.cv-otp-input--error .cv-otp-input__field[data-v-18cd89a0]:focus {
        box-shadow: var(--cv-ui-shadow-focus-error);
}
.cv-otp-input--success .cv-otp-input__field[data-v-18cd89a0] {
        border-color: var(--cv-ui-color-success);
}
.cv-otp-input--success .cv-otp-input__field[data-v-18cd89a0]:focus {
        box-shadow: var(--cv-ui-shadow-focus-success);
}

    /* Sizes */
.cv-otp-input--sm .cv-otp-input__field[data-v-18cd89a0] {
        width: 32px;
        height: 36px;
        font-size: var(--cv-ui-font-size-sm);
}
.cv-otp-input--md .cv-otp-input__field[data-v-18cd89a0] {
        width: 40px;
        height: 46px;
        font-size: var(--cv-ui-font-size-md);
}
.cv-otp-input--lg .cv-otp-input__field[data-v-18cd89a0] {
        width: 52px;
        height: 58px;
        font-size: var(--cv-ui-font-size-lg);
}

.cv-rating[data-v-cb0d9b79] {
        display: inline-flex;
        align-items: center;
        gap: var(--cv-ui-spacing-sm);
        font-family: var(--cv-ui-font-family);
}
.cv-rating--disabled[data-v-cb0d9b79] {
        opacity: 0.5;
        cursor: not-allowed;
        pointer-events: none;
}
.cv-rating__stars[data-v-cb0d9b79] {
        display: inline-flex;
        align-items: center;
        gap: 2px;
}
.cv-rating__star-wrap[data-v-cb0d9b79] {
        position: relative;
        display: inline-flex;
        align-items: center;
        justify-content: center;
        cursor: pointer;
        line-height: 0;
}
.cv-rating--readonly .cv-rating__star-wrap[data-v-cb0d9b79],
    .cv-rating--disabled .cv-rating__star-wrap[data-v-cb0d9b79] {
        cursor: default;
}

    /* Hidden radio */
.cv-rating__radio[data-v-cb0d9b79] {
        position: absolute;
        width: 0;
        height: 0;
        opacity: 0;
        pointer-events: none;
}

    /* Left half overlay for half-star click/hover detection */
.cv-rating__half[data-v-cb0d9b79] {
        position: absolute;
        top: 0;
        left: 0;
        width: 50%;
        height: 100%;
        z-index: 1;
}

    /* Star SVG */
.cv-rating__star[data-v-cb0d9b79] {
        display: block;
        transition: transform var(--cv-ui-transition-fast) var(--cv-ui-transition-timing);
        position: relative;
        z-index: 0;
}
.cv-rating__star-wrap:hover .cv-rating__star[data-v-cb0d9b79] {
        transform: scale(1.15);
}
.cv-rating--readonly .cv-rating__star-wrap:hover .cv-rating__star[data-v-cb0d9b79],
    .cv-rating--disabled .cv-rating__star-wrap:hover .cv-rating__star[data-v-cb0d9b79] {
        transform: none;
}

    /* Sizes */
.cv-rating--sm .cv-rating__star[data-v-cb0d9b79] {
        width: 16px;
        height: 16px;
}
.cv-rating--md .cv-rating__star[data-v-cb0d9b79] {
        width: 22px;
        height: 22px;
}
.cv-rating--lg .cv-rating__star[data-v-cb0d9b79] {
        width: 30px;
        height: 30px;
}

    /* Colors */
.cv-rating--warning[data-v-cb0d9b79] {
        color: var(--cv-ui-color-warning);
}
.cv-rating--primary[data-v-cb0d9b79] {
        color: var(--cv-ui-color-primary);
}
.cv-rating__value[data-v-cb0d9b79] {
        font-size: var(--cv-ui-font-size-sm);
        font-weight: var(--cv-ui-font-weight-semibold);
        color: var(--cv-ui-text-secondary);
        min-width: 1.5ch;
}
.cv-rating--sm .cv-rating__value[data-v-cb0d9b79] {
        font-size: var(--cv-ui-font-size-xs);
}
.cv-rating--lg .cv-rating__value[data-v-cb0d9b79] {
        font-size: var(--cv-ui-font-size-md);
}

.cv-kbd[data-v-62c9692b] {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        font-family: 'Courier New', Courier, monospace;
        font-weight: var(--cv-ui-font-weight-medium);
        color: var(--cv-ui-text-primary);
        background-color: var(--cv-ui-bg-secondary);
        border: 1px solid var(--cv-ui-border-color);
        border-bottom-width: 3px;
        border-radius: var(--cv-ui-radius-sm);
        box-shadow: inset 0 -1px 0 var(--cv-ui-border-color), var(--cv-ui-shadow-sm);
        line-height: 1;
        white-space: nowrap;
        vertical-align: baseline;
}
.cv-kbd--sm[data-v-62c9692b] {
        font-size: 11px;
        padding: 2px 5px;
        min-width: 20px;
        height: 20px;
}
.cv-kbd--md[data-v-62c9692b] {
        font-size: 13px;
        padding: 3px 7px;
        min-width: 24px;
        height: 24px;
}
.cv-kbd--lg[data-v-62c9692b] {
        font-size: 15px;
        padding: 4px 9px;
        min-width: 30px;
        height: 30px;
}

.cv-code[data-v-293ba84e] {
        position: relative;
        display: flex;
        flex-direction: column;
        font-family: var(--cv-ui-font-family);
        background-color: var(--cv-ui-bg-secondary);
        border: 1px solid var(--cv-ui-border-color);
        border-radius: var(--cv-ui-radius-lg);
        overflow: hidden;
        box-shadow: var(--cv-ui-shadow-sm);
}

    /* ── Header ── */
.cv-code__header[data-v-293ba84e] {
        display: flex;
        align-items: center;
        justify-content: space-between;
        padding: var(--cv-ui-spacing-xs) var(--cv-ui-spacing-md);
        background-color: var(--cv-ui-bg-tertiary);
        border-bottom: 1px solid var(--cv-ui-border-color);
        gap: var(--cv-ui-spacing-sm);
        min-height: 36px;
}
.cv-code__header-left[data-v-293ba84e],
    .cv-code__header-right[data-v-293ba84e] {
        display: flex;
        align-items: center;
        gap: var(--cv-ui-spacing-xs);
}
.cv-code__file-icon[data-v-293ba84e] {
        width: 14px;
        height: 14px;
        color: var(--cv-ui-text-tertiary);
        flex-shrink: 0;
}
.cv-code__filename[data-v-293ba84e] {
        font-size: var(--cv-ui-font-size-xs);
        font-weight: var(--cv-ui-font-weight-medium);
        color: var(--cv-ui-text-secondary);
        font-family: 'Courier New', Courier, monospace;
}
.cv-code__language[data-v-293ba84e] {
        font-size: var(--cv-ui-font-size-xs);
        font-weight: var(--cv-ui-font-weight-normal);
        color: var(--cv-ui-text-tertiary);
        text-transform: lowercase;
        letter-spacing: 0.02em;
}

    /* ── Copy button ── */
.cv-code__copy-btn[data-v-293ba84e] {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        padding: 4px;
        background: transparent;
        border: 1px solid transparent;
        border-radius: var(--cv-ui-radius-sm);
        color: var(--cv-ui-text-tertiary);
        cursor: pointer;
        transition:
            color var(--cv-ui-transition-fast) var(--cv-ui-transition-timing),
            background-color var(--cv-ui-transition-fast) var(--cv-ui-transition-timing),
            border-color var(--cv-ui-transition-fast) var(--cv-ui-transition-timing);
        line-height: 0;
}
.cv-code__copy-btn[data-v-293ba84e]:hover {
        color: var(--cv-ui-text-primary);
        background-color: var(--cv-ui-bg-hover);
        border-color: var(--cv-ui-border-color);
}

    /* Floating copy button (when no header) */
.cv-code__copy-btn--floating[data-v-293ba84e] {
        position: absolute;
        top: var(--cv-ui-spacing-sm);
        right: var(--cv-ui-spacing-sm);
        z-index: 1;
        background-color: var(--cv-ui-bg-tertiary);
        border-color: var(--cv-ui-border-color);
        opacity: 0;
        transition:
            opacity var(--cv-ui-transition-fast) var(--cv-ui-transition-timing),
            color var(--cv-ui-transition-fast) var(--cv-ui-transition-timing),
            background-color var(--cv-ui-transition-fast) var(--cv-ui-transition-timing);
}
.cv-code:hover .cv-code__copy-btn--floating[data-v-293ba84e] {
        opacity: 1;
}
.cv-code__copy-icon[data-v-293ba84e] {
        width: 15px;
        height: 15px;
}
.cv-code__copy-icon--check[data-v-293ba84e] {
        color: var(--cv-ui-color-success);
}

    /* ── Code body ── */
.cv-code__body[data-v-293ba84e] {
        display: flex;
        overflow-x: auto;
}

    /* Line numbers */
.cv-code__line-numbers[data-v-293ba84e] {
        display: flex;
        flex-direction: column;
        padding: var(--cv-ui-spacing-md) 0;
        padding-left: var(--cv-ui-spacing-md);
        padding-right: var(--cv-ui-spacing-sm);
        border-right: 1px solid var(--cv-ui-border-color);
        background-color: var(--cv-ui-bg-tertiary);
        user-select: none;
        flex-shrink: 0;
}
.cv-code__line-number[data-v-293ba84e] {
        display: block;
        font-family: 'Courier New', Courier, monospace;
        font-size: var(--cv-ui-font-size-xs);
        line-height: 1.6;
        color: var(--cv-ui-text-tertiary);
        text-align: right;
        min-width: 2ch;
}

    /* Pre / code */
.cv-code__pre[data-v-293ba84e] {
        flex: 1;
        margin: 0;
        padding: var(--cv-ui-spacing-md);
        overflow-x: auto;
        background: transparent;
        line-height: 1.6;
}
.cv-code__content[data-v-293ba84e] {
        font-family: 'Courier New', Courier, monospace;
        font-size: var(--cv-ui-font-size-sm);
        color: var(--cv-ui-text-primary);
        white-space: pre;
        word-break: normal;
        tab-size: 2;
}

    /* ── Root ────────────────────────────────────────────────── */
.cv-uploader[data-v-f277fd5d] {
        font-family: var(--cv-ui-font-family);
        display: flex;
        flex-direction: column;
        gap: var(--cv-ui-spacing-md);
        width: 100%;
}
.cv-uploader--disabled[data-v-f277fd5d] {
        opacity: 0.55;
        pointer-events: none;
}

    /* ── Drop zone ───────────────────────────────────────────── */
.cv-uploader__zone[data-v-f277fd5d] {
        position: relative;
        display: flex;
        flex-direction: column;
        align-items: center;
        justify-content: center;
        gap: var(--cv-ui-spacing-sm);
        padding: var(--cv-ui-spacing-2xl) var(--cv-ui-spacing-lg);
        border: 2px dashed var(--cv-ui-border-color);
        border-radius: var(--cv-ui-radius-xl);
        background: var(--cv-ui-bg-secondary);
        color: var(--cv-ui-text-secondary);
        cursor: pointer;
        text-align: center;
        transition:
            border-color var(--cv-ui-transition-fast) var(--cv-ui-transition-timing),
            background-color var(--cv-ui-transition-fast) var(--cv-ui-transition-timing),
            color var(--cv-ui-transition-fast) var(--cv-ui-transition-timing),
            box-shadow var(--cv-ui-transition-fast) var(--cv-ui-transition-timing);
        outline: none;
}
.cv-uploader__zone[data-v-f277fd5d]:hover,
    .cv-uploader__zone[data-v-f277fd5d]:focus-visible {
        border-color: var(--cv-ui-color-primary);
        background: var(--cv-ui-color-primary-light);
        color: var(--cv-ui-color-primary-dark);
        box-shadow: var(--cv-ui-shadow-focus);
}
.cv-uploader__zone--drag[data-v-f277fd5d] {
        border-color: var(--cv-ui-color-primary);
        background: var(--cv-ui-color-primary-light);
        color: var(--cv-ui-color-primary);
        box-shadow: var(--cv-ui-shadow-focus);
        transform: scale(1.005);
}
.cv-uploader__zone--error[data-v-f277fd5d] {
        border-color: var(--cv-ui-border-color-error);
        background: var(--cv-ui-color-danger-light);
        color: var(--cv-ui-color-danger-dark);
        box-shadow: var(--cv-ui-shadow-focus-error);
}

    /* Hidden native input */
.cv-uploader__input[data-v-f277fd5d] {
        position: absolute;
        inset: 0;
        opacity: 0;
        pointer-events: none;
        width: 0;
        height: 0;
}
.cv-uploader__icon svg[data-v-f277fd5d] {
        width: 40px;
        height: 40px;
        stroke-width: 1.2;
        opacity: 0.7;
}
.cv-uploader__label[data-v-f277fd5d] {
        font-size: var(--cv-ui-font-size-md);
        font-weight: var(--cv-ui-font-weight-medium);
        color: inherit;
}
.cv-uploader__browse[data-v-f277fd5d] {
        color: var(--cv-ui-color-primary);
        text-decoration: underline;
        text-decoration-color: transparent;
        transition: text-decoration-color var(--cv-ui-transition-fast) var(--cv-ui-transition-timing);
        margin-left: 4px;
}
.cv-uploader__zone:hover .cv-uploader__browse[data-v-f277fd5d],
    .cv-uploader__zone--drag .cv-uploader__browse[data-v-f277fd5d] {
        text-decoration-color: currentColor;
}
.cv-uploader__hint[data-v-f277fd5d] {
        font-size: var(--cv-ui-font-size-xs);
        color: var(--cv-ui-text-tertiary);
}
.cv-uploader__zone-error[data-v-f277fd5d] {
        font-size: var(--cv-ui-font-size-xs);
        font-weight: var(--cv-ui-font-weight-medium);
        color: var(--cv-ui-color-danger);
}

    /* ── File list ───────────────────────────────────────────── */
.cv-uploader__list[data-v-f277fd5d] {
        list-style: none;
        margin: 0;
        padding: 0;
        display: flex;
        flex-direction: column;
        gap: var(--cv-ui-spacing-sm);
}
.cv-uploader__item[data-v-f277fd5d] {
        display: flex;
        align-items: center;
        gap: var(--cv-ui-spacing-sm);
        padding: var(--cv-ui-spacing-sm) var(--cv-ui-spacing-md);
        border: 1px solid var(--cv-ui-border-color);
        border-radius: var(--cv-ui-radius-lg);
        background: var(--cv-ui-bg-primary);
        box-shadow: var(--cv-ui-shadow-sm);
        transition:
            border-color var(--cv-ui-transition-fast) var(--cv-ui-transition-timing),
            background-color var(--cv-ui-transition-fast) var(--cv-ui-transition-timing);
}
.cv-uploader__item--success[data-v-f277fd5d] {
        border-color: var(--cv-ui-color-success);
        background: var(--cv-ui-color-success-light);
}
.cv-uploader__item--error[data-v-f277fd5d] {
        border-color: var(--cv-ui-border-color-error);
        background: var(--cv-ui-color-danger-light);
}

    /* ── Thumbnail ───────────────────────────────────────────── */
.cv-uploader__thumb[data-v-f277fd5d] {
        flex-shrink: 0;
        width: 40px;
        height: 40px;
        border-radius: var(--cv-ui-radius-md);
        background: var(--cv-ui-bg-tertiary);
        display: flex;
        align-items: center;
        justify-content: center;
        overflow: hidden;
}
.cv-uploader__thumb-img[data-v-f277fd5d] {
        width: 100%;
        height: 100%;
        object-fit: cover;
}
.cv-uploader__thumb-icon svg[data-v-f277fd5d] {
        width: 20px;
        height: 20px;
        color: var(--cv-ui-text-tertiary);
}

    /* ── Info ────────────────────────────────────────────────── */
.cv-uploader__info[data-v-f277fd5d] {
        flex: 1;
        min-width: 0;
        display: flex;
        flex-direction: column;
        gap: 2px;
}
.cv-uploader__name[data-v-f277fd5d] {
        font-size: var(--cv-ui-font-size-sm);
        font-weight: var(--cv-ui-font-weight-medium);
        color: var(--cv-ui-text-primary);
        white-space: nowrap;
        overflow: hidden;
        text-overflow: ellipsis;
}
.cv-uploader__meta[data-v-f277fd5d] {
        font-size: var(--cv-ui-font-size-xs);
        color: var(--cv-ui-text-secondary);
}
.cv-uploader__error-msg[data-v-f277fd5d] {
        color: var(--cv-ui-color-danger);
        font-weight: var(--cv-ui-font-weight-medium);
}

    /* ── Progress ────────────────────────────────────────────── */
.cv-uploader__progress[data-v-f277fd5d] {
        height: 4px;
        background: var(--cv-ui-border-color);
        border-radius: var(--cv-ui-radius-full);
        overflow: hidden;
        margin-top: 4px;
}
.cv-uploader__progress-fill[data-v-f277fd5d] {
        height: 100%;
        background: var(--cv-ui-color-primary);
        border-radius: var(--cv-ui-radius-full);
        transition: width 0.2s ease;
}

    /* ── Status icon ─────────────────────────────────────────── */
.cv-uploader__status-icon[data-v-f277fd5d] {
        flex-shrink: 0;
        width: 20px;
        height: 20px;
        display: flex;
        align-items: center;
        justify-content: center;
}
.cv-uploader__status-icon svg[data-v-f277fd5d] {
        width: 20px;
        height: 20px;
}
.cv-uploader__item--success .cv-uploader__status-icon svg[data-v-f277fd5d] {
        color: var(--cv-ui-color-success);
}
.cv-uploader__item--error .cv-uploader__status-icon svg[data-v-f277fd5d] {
        color: var(--cv-ui-color-danger);
}
.cv-uploader__item--uploading .cv-uploader__status-icon svg[data-v-f277fd5d] {
        color: var(--cv-ui-color-primary);
}

    /* Spinner animation */
@keyframes cv-spin-f277fd5d {
to { transform: rotate(360deg);
}
}
.cv-uploader__spin[data-v-f277fd5d] {
        animation: cv-spin-f277fd5d 0.8s linear infinite;
        transform-origin: center;
}

    /* ── Remove button ───────────────────────────────────────── */
.cv-uploader__remove[data-v-f277fd5d] {
        flex-shrink: 0;
        width: 28px;
        height: 28px;
        display: flex;
        align-items: center;
        justify-content: center;
        padding: 0;
        border: none;
        border-radius: var(--cv-ui-radius-sm);
        background: transparent;
        color: var(--cv-ui-text-tertiary);
        cursor: pointer;
        transition:
            color var(--cv-ui-transition-fast) var(--cv-ui-transition-timing),
            background-color var(--cv-ui-transition-fast) var(--cv-ui-transition-timing);
}
.cv-uploader__remove[data-v-f277fd5d]:hover {
        color: var(--cv-ui-color-danger);
        background: var(--cv-ui-color-danger-light);
}
.cv-uploader__remove[data-v-f277fd5d]:focus-visible {
        outline: none;
        box-shadow: var(--cv-ui-shadow-focus);
}
.cv-uploader__remove svg[data-v-f277fd5d] {
        width: 14px;
        height: 14px;
}

    /* ── List transitions ────────────────────────────────────── */
.cv-uploader-list-enter-active[data-v-f277fd5d],
    .cv-uploader-list-leave-active[data-v-f277fd5d] {
        transition:
            opacity 0.2s ease,
            transform 0.2s ease,
            max-height 0.25s ease;
        overflow: hidden;
        max-height: 80px;
}
.cv-uploader-list-enter-from[data-v-f277fd5d] {
        opacity: 0;
        transform: translateY(-6px);
}
.cv-uploader-list-leave-to[data-v-f277fd5d] {
        opacity: 0;
        transform: translateX(8px);
        max-height: 0;
}

.cv-autocomplete-wrapper[data-v-534bc599] {
        position: relative;
        width: 100%;
}
.cv-autocomplete__field-wrap[data-v-534bc599] {
        position: relative;
        flex: 1;
        min-width: 0;
}
.cv-autocomplete[data-v-534bc599] {
        width: 100%;
        padding: var(--cv-ui-spacing-sm) var(--cv-ui-spacing-md);
        font-family: var(--cv-ui-font-family);
        font-size: var(--cv-ui-font-size-sm);
        font-weight: var(--cv-ui-font-weight-normal);
        color: var(--cv-ui-text-primary);
        background-color: var(--cv-ui-bg-primary);
        border: 1px solid var(--cv-ui-border-color);
        border-radius: var(--cv-ui-radius-md);
        box-shadow: var(--cv-ui-shadow-sm);
        transition:
            border-color var(--cv-ui-transition-fast) var(--cv-ui-transition-timing),
            box-shadow var(--cv-ui-transition-fast) var(--cv-ui-transition-timing);
        outline: none;
}
.cv-autocomplete[data-v-534bc599]::placeholder {
        color: var(--cv-ui-text-tertiary);
}
.cv-autocomplete[data-v-534bc599]:hover:not(.cv-autocomplete--disabled) {
        border-color: var(--cv-ui-border-color-hover);
}
.cv-autocomplete[data-v-534bc599]:focus {
        border-color: var(--cv-ui-border-color-focus);
        box-shadow: var(--cv-ui-shadow-focus);
}
.cv-autocomplete--disabled[data-v-534bc599] {
        opacity: 0.7;
        cursor: not-allowed;
        background-color: var(--cv-ui-bg-tertiary);
        color: var(--cv-ui-text-disabled);
}
.cv-autocomplete--error[data-v-534bc599] {
        border-color: var(--cv-ui-border-color-error);
}
.cv-autocomplete--error[data-v-534bc599]:focus {
        box-shadow: var(--cv-ui-shadow-focus-error);
}
.cv-autocomplete--success[data-v-534bc599] {
        border-color: var(--cv-ui-color-success);
}
.cv-autocomplete--sm[data-v-534bc599] {
        padding: var(--cv-ui-spacing-xs) var(--cv-ui-spacing-sm);
        font-size: var(--cv-ui-font-size-xs);
}
.cv-autocomplete--lg[data-v-534bc599] {
        padding: var(--cv-ui-spacing-md) var(--cv-ui-spacing-lg);
        font-size: var(--cv-ui-font-size-md);
}
.cv-autocomplete__dropdown[data-v-534bc599] {
        position: fixed;
        z-index: var(--cv-ui-z-dropdown);
        max-height: 16rem;
        overflow-y: auto;
        padding: var(--cv-ui-spacing-xs);
        background: var(--cv-ui-bg-primary);
        border: 1px solid var(--cv-ui-border-color);
        border-radius: var(--cv-ui-radius-lg);
        box-shadow: var(--cv-ui-shadow-lg);
}
.cv-autocomplete__option[data-v-534bc599] {
        display: flex;
        align-items: center;
        width: 100%;
        padding: var(--cv-ui-spacing-sm) var(--cv-ui-spacing-md);
        font-family: var(--cv-ui-font-family);
        font-size: var(--cv-ui-font-size-sm);
        font-weight: var(--cv-ui-font-weight-normal);
        color: var(--cv-ui-text-primary);
        text-align: left;
        background: transparent;
        border: none;
        border-radius: var(--cv-ui-radius-md);
        cursor: pointer;
        transition: background-color var(--cv-ui-transition-fast) var(--cv-ui-transition-timing);
}
.cv-autocomplete__option[data-v-534bc599]:hover {
        background-color: var(--cv-ui-bg-hover);
}
.cv-autocomplete__option--focused[data-v-534bc599] {
        background-color: var(--cv-ui-bg-hover);
}
.cv-autocomplete__option--selected[data-v-534bc599] {
        background-color: var(--cv-ui-color-primary-light);
        color: var(--cv-ui-color-primary-dark);
        font-weight: var(--cv-ui-font-weight-medium);
}
.cv-autocomplete-feedback[data-v-534bc599] {
        margin-top: var(--cv-ui-spacing-xs);
        font-size: var(--cv-ui-font-size-xs);
}
.cv-autocomplete-feedback--error[data-v-534bc599] {
        color: var(--cv-ui-color-danger);
}
.cv-autocomplete-feedback--success[data-v-534bc599] {
        color: var(--cv-ui-color-success);
}

.cv-password-wrapper[data-v-72a13926] {
        width: 100%;
}
.cv-password__field-wrap[data-v-72a13926] {
        position: relative;
        display: flex;
        align-items: center;
}
.cv-password[data-v-72a13926] {
        width: 100%;
        padding: var(--cv-ui-spacing-sm) var(--cv-ui-spacing-md);
        padding-right: 2.5rem;
        font-family: var(--cv-ui-font-family);
        font-size: var(--cv-ui-font-size-sm);
        font-weight: var(--cv-ui-font-weight-normal);
        color: var(--cv-ui-text-primary);
        background-color: var(--cv-ui-bg-primary);
        border: 1px solid var(--cv-ui-border-color);
        border-radius: var(--cv-ui-radius-md);
        box-shadow: var(--cv-ui-shadow-sm);
        transition:
            border-color var(--cv-ui-transition-fast) var(--cv-ui-transition-timing),
            box-shadow var(--cv-ui-transition-fast) var(--cv-ui-transition-timing);
        outline: none;
}
.cv-password[data-v-72a13926]::placeholder {
        color: var(--cv-ui-text-tertiary);
}
.cv-password[data-v-72a13926]:hover:not(.cv-password--disabled) {
        border-color: var(--cv-ui-border-color-hover);
}
.cv-password[data-v-72a13926]:focus {
        border-color: var(--cv-ui-border-color-focus);
        box-shadow: var(--cv-ui-shadow-focus);
}
.cv-password--disabled[data-v-72a13926] {
        opacity: 0.7;
        cursor: not-allowed;
        background-color: var(--cv-ui-bg-tertiary);
        color: var(--cv-ui-text-disabled);
}
.cv-password--error[data-v-72a13926] {
        border-color: var(--cv-ui-border-color-error);
}
.cv-password--error[data-v-72a13926]:focus {
        box-shadow: var(--cv-ui-shadow-focus-error);
}
.cv-password--success[data-v-72a13926] {
        border-color: var(--cv-ui-color-success);
}
.cv-password--sm[data-v-72a13926] {
        padding: var(--cv-ui-spacing-xs) var(--cv-ui-spacing-sm);
        padding-right: 2rem;
        font-size: var(--cv-ui-font-size-xs);
}
.cv-password--lg[data-v-72a13926] {
        padding: var(--cv-ui-spacing-md) var(--cv-ui-spacing-lg);
        padding-right: 3rem;
        font-size: var(--cv-ui-font-size-md);
}
.cv-password__toggle[data-v-72a13926] {
        position: absolute;
        right: var(--cv-ui-spacing-sm);
        display: inline-flex;
        align-items: center;
        justify-content: center;
        width: 1.75rem;
        height: 1.75rem;
        padding: 0;
        background: transparent;
        border: none;
        border-radius: var(--cv-ui-radius-sm);
        color: var(--cv-ui-text-tertiary);
        cursor: pointer;
        transition:
            color var(--cv-ui-transition-fast) var(--cv-ui-transition-timing),
            background-color var(--cv-ui-transition-fast) var(--cv-ui-transition-timing);
}
.cv-password__toggle[data-v-72a13926]:hover:not(:disabled) {
        color: var(--cv-ui-text-primary);
        background-color: var(--cv-ui-bg-hover);
}
.cv-password__toggle[data-v-72a13926]:disabled {
        opacity: 0.5;
        cursor: not-allowed;
}
.cv-password__toggle--sm[data-v-72a13926] {
        width: 1.5rem;
        height: 1.5rem;
}
.cv-password__toggle--lg[data-v-72a13926] {
        right: var(--cv-ui-spacing-md);
        width: 2rem;
        height: 2rem;
}
.cv-password__icon[data-v-72a13926] {
        width: 1rem;
        height: 1rem;
}
.cv-password-feedback[data-v-72a13926] {
        margin-top: var(--cv-ui-spacing-xs);
        font-size: var(--cv-ui-font-size-xs);
}
.cv-password-feedback--error[data-v-72a13926] {
        color: var(--cv-ui-color-danger);
}
.cv-password-feedback--success[data-v-72a13926] {
        color: var(--cv-ui-color-success);
}

.cv-listbox-wrapper[data-v-d4442b30] {
        width: 100%;
}
.cv-listbox__search[data-v-d4442b30] {
        margin-bottom: var(--cv-ui-spacing-xs);
}
.cv-listbox__search-input[data-v-d4442b30] {
        width: 100%;
        padding: var(--cv-ui-spacing-sm) var(--cv-ui-spacing-md);
        font-family: var(--cv-ui-font-family);
        font-size: var(--cv-ui-font-size-sm);
        color: var(--cv-ui-text-primary);
        background-color: var(--cv-ui-bg-primary);
        border: 1px solid var(--cv-ui-border-color);
        border-radius: var(--cv-ui-radius-md);
        outline: none;
        box-sizing: border-box;
        transition: border-color var(--cv-ui-transition-fast) var(--cv-ui-transition-timing);
}
.cv-listbox__search-input[data-v-d4442b30]:focus {
        border-color: var(--cv-ui-border-color-focus);
        box-shadow: var(--cv-ui-shadow-focus);
}
.cv-listbox__search-input--sm[data-v-d4442b30] {
        padding: var(--cv-ui-spacing-xs) var(--cv-ui-spacing-sm);
        font-size: var(--cv-ui-font-size-xs);
}
.cv-listbox__search-input--lg[data-v-d4442b30] {
        padding: var(--cv-ui-spacing-md) var(--cv-ui-spacing-lg);
        font-size: var(--cv-ui-font-size-md);
}
.cv-listbox[data-v-d4442b30] {
        overflow-y: auto;
        border: 1px solid var(--cv-ui-border-color);
        border-radius: var(--cv-ui-radius-md);
        background: var(--cv-ui-bg-primary);
        padding: var(--cv-ui-spacing-xs);
        outline: none;
}
.cv-listbox[data-v-d4442b30]:focus {
        border-color: var(--cv-ui-border-color-focus);
        box-shadow: var(--cv-ui-shadow-focus);
}
.cv-listbox--disabled[data-v-d4442b30] {
        opacity: 0.7;
        cursor: not-allowed;
        background-color: var(--cv-ui-bg-tertiary);
        pointer-events: none;
}
.cv-listbox--error[data-v-d4442b30] {
        border-color: var(--cv-ui-border-color-error);
}
.cv-listbox--error[data-v-d4442b30]:focus {
        box-shadow: var(--cv-ui-shadow-focus-error);
}
.cv-listbox--success[data-v-d4442b30] {
        border-color: var(--cv-ui-color-success);
}
.cv-listbox__no-result[data-v-d4442b30] {
        padding: var(--cv-ui-spacing-sm) var(--cv-ui-spacing-md);
        font-size: var(--cv-ui-font-size-sm);
        color: var(--cv-ui-text-tertiary);
        text-align: center;
        margin: 0;
}
.cv-listbox__option[data-v-d4442b30] {
        display: flex;
        align-items: center;
        gap: var(--cv-ui-spacing-sm);
        width: 100%;
        padding: var(--cv-ui-spacing-sm) var(--cv-ui-spacing-md);
        font-family: var(--cv-ui-font-family);
        font-size: var(--cv-ui-font-size-sm);
        font-weight: var(--cv-ui-font-weight-normal);
        color: var(--cv-ui-text-primary);
        text-align: left;
        background: transparent;
        border: none;
        border-radius: var(--cv-ui-radius-md);
        cursor: pointer;
        transition: background-color var(--cv-ui-transition-fast) var(--cv-ui-transition-timing);
}
.cv-listbox--sm .cv-listbox__option[data-v-d4442b30] {
        padding: var(--cv-ui-spacing-xs) var(--cv-ui-spacing-sm);
        font-size: var(--cv-ui-font-size-xs);
}
.cv-listbox--lg .cv-listbox__option[data-v-d4442b30] {
        padding: var(--cv-ui-spacing-md) var(--cv-ui-spacing-lg);
        font-size: var(--cv-ui-font-size-md);
}
.cv-listbox__option[data-v-d4442b30]:hover:not(.cv-listbox__option--disabled) {
        background-color: var(--cv-ui-bg-hover);
}
.cv-listbox__option--focused[data-v-d4442b30]:not(.cv-listbox__option--selected) {
        background-color: var(--cv-ui-bg-hover);
}
.cv-listbox__option--selected[data-v-d4442b30],
    .cv-listbox__option--selected[data-v-d4442b30]:hover {
        background-color: var(--cv-ui-color-primary-light);
        color: var(--cv-ui-color-primary-dark);
        font-weight: var(--cv-ui-font-weight-medium);
}
.cv-listbox__option--disabled[data-v-d4442b30] {
        opacity: 0.5;
        cursor: not-allowed;
}
.cv-listbox__option-check[data-v-d4442b30] {
        flex-shrink: 0;
        display: inline-flex;
        align-items: center;
        justify-content: center;
        width: 1rem;
        height: 1rem;
        border: 1px solid var(--cv-ui-border-color);
        border-radius: var(--cv-ui-radius-sm);
        background: var(--cv-ui-bg-primary);
}
.cv-listbox__option--selected .cv-listbox__option-check[data-v-d4442b30] {
        background: var(--cv-ui-color-primary);
        border-color: var(--cv-ui-color-primary);
        color: var(--cv-ui-text-inverse);
}
.cv-listbox__option-check-icon[data-v-d4442b30] {
        font-size: 0.75rem;
        font-weight: bold;
        line-height: 1;
}
.cv-listbox-feedback[data-v-d4442b30] {
        margin-top: var(--cv-ui-spacing-xs);
        font-size: var(--cv-ui-font-size-xs);
}
.cv-listbox-feedback--error[data-v-d4442b30] {
        color: var(--cv-ui-color-danger);
}
.cv-listbox-feedback--success[data-v-d4442b30] {
        color: var(--cv-ui-color-success);
}

.story-pad[data-v-b3294595] {
        padding: 4px;
}
.story-gap[data-v-b3294595] {
        display: flex;
        flex-direction: column;
        gap: 12px;
}

.cv-flow-root[data-v-fddd8cdc] {
        height: 100%;
        width: 100%;
        display: flex;
        flex-direction: column;
        border: 1px solid var(--cv-ui-border-color, #e2e8f0);
        border-radius: var(--cv-ui-radius-lg, 8px);
        overflow: hidden;
        background-color: var(--cv-ui-bg-primary, #fff);
}
.cv-flow-header[data-v-fddd8cdc] {
        display: flex;
        align-items: center;
        gap: var(--cv-ui-spacing-sm, 8px);
        padding-left: var(--cv-ui-spacing-md, 16px);
        padding-right: var(--cv-ui-spacing-md, 16px);
        height: 44px;
        border-bottom: 1px solid var(--cv-ui-border-color, #e2e8f0);
        background-color: var(--cv-ui-bg-primary, #fff);
}
.cv-flow-back[data-v-fddd8cdc] {
        height: 32px;
        width: 32px;
        display: flex;
        align-items: center;
        justify-content: center;
        border-radius: var(--cv-ui-radius-sm, 4px);
        border: none;
        background: transparent;
        cursor: pointer;
        color: inherit;
        font: inherit;
}
.cv-flow-back[data-v-fddd8cdc]:hover {
        background-color: var(--cv-ui-bg-hover, #f3f4f6);
}
.cv-flow-header-content[data-v-fddd8cdc] {
        min-width: 0;
        flex: 1;
}
.cv-flow-title[data-v-fddd8cdc] {
        font-size: var(--cv-ui-font-size-sm, 14px);
        font-weight: var(--cv-ui-font-weight-medium, 500);
        overflow: hidden;
        text-overflow: ellipsis;
        white-space: nowrap;
}
.cv-flow-subtitle[data-v-fddd8cdc] {
        font-size: var(--cv-ui-font-size-xs, 12px);
        color: var(--cv-ui-text-tertiary, #6b7280);
        overflow: hidden;
        text-overflow: ellipsis;
        white-space: nowrap;
}
.cv-flow-slot-hidden[data-v-fddd8cdc] {
        position: absolute;
        width: 1px;
        height: 1px;
        padding: 0;
        margin: -1px;
        overflow: hidden;
        clip: rect(0, 0, 0, 0);
        white-space: nowrap;
        border: 0;
}
.cv-flow-body[data-v-fddd8cdc] {
        position: relative;
        flex: 1;
        overflow: hidden;
}
.cv-flow-stack[data-v-fddd8cdc] {
        position: relative;
        height: 100%;
        width: 100%;
}
.cv-flow-screen[data-v-fddd8cdc] {
        position: absolute;
        inset: 0;
        height: 100%;
        width: 100%;
        background-color: var(--cv-ui-bg-primary, #fff);
}
.cv-flow-enter-active[data-v-fddd8cdc],
    .cv-flow-leave-active[data-v-fddd8cdc] {
        transition:
            transform 180ms ease,
            opacity 180ms ease;
}
.cv-flow-enter-from[data-v-fddd8cdc] {
        transform: translateX(24px);
        opacity: 0;
}
.cv-flow-enter-to[data-v-fddd8cdc] {
        transform: translateX(0);
        opacity: 1;
}
.cv-flow-leave-from[data-v-fddd8cdc] {
        transform: translateX(0);
        opacity: 1;
}
.cv-flow-leave-to[data-v-fddd8cdc] {
        transform: translateX(24px);
        opacity: 0;
}

.story-flow-wrap[data-v-89acd3fa] {
        padding: 4px;
        height: 520px;
}
.story-flow-size[data-v-89acd3fa] {
        height: 520px;
        width: 360px;
}
.story-flow-list[data-v-89acd3fa] {
        padding: 12px;
        display: flex;
        flex-direction: column;
        gap: 4px;
}
.story-flow-block[data-v-89acd3fa] {
        padding: 12px;
}
.story-flow-text[data-v-89acd3fa] {
        font-size: 14px;
}
.story-flow-text p[data-v-89acd3fa] {
        margin: 0 0 8px;
}
.story-flow-btn[data-v-89acd3fa] {
        width: 100%;
        display: flex;
        justify-content: space-between;
        align-items: center;
        padding: 8px 12px;
        border-radius: 6px;
        border: none;
        background: transparent;
        cursor: pointer;
        font: inherit;
}
.story-flow-btn[data-v-89acd3fa]:hover {
        background: #f3f4f6;
}

.cv-tooltip-trigger[data-v-9ecbd550] {
        display: inline-flex;
}
.cv-tooltip[data-v-9ecbd550] {
        position: fixed;
        z-index: 9999;
        padding: var(--cv-ui-spacing-xs, 4px) var(--cv-ui-spacing-sm, 8px);
        font-size: var(--cv-ui-font-size-xs, 12px);
        line-height: 1.4;
        color: var(--cv-ui-text-inverse, #fff);
        background-color: var(--cv-ui-color-secondary-dark, #374151);
        border-radius: var(--cv-ui-radius-sm, 4px);
        box-shadow: 0 2px 8px rgba(0, 0, 0, 0.15);
        pointer-events: auto;
        max-width: 240px;
        word-wrap: break-word;
}

    /* Fond clair forcé + tokens light pour que tout soit lisible quel que soit le thème Histoire */
.ui-catalogue[data-v-8f81b7ee] {
        --ui-cat-bg: #ffffff;
        --ui-cat-bg-soft: #f1f5f9;
        --ui-cat-text: #1e293b;
        --ui-cat-text-muted: #475569;
        --ui-cat-border: #e2e8f0;
        /* Surcharge tokens en mode clair pour les composants enfants */
        --cv-ui-bg-primary: #ffffff;
        --cv-ui-bg-secondary: #f8fafc;
        --cv-ui-bg-tertiary: #f1f5f9;
        --cv-ui-text-primary: #1e293b;
        --cv-ui-text-secondary: #475569;
        --cv-ui-text-tertiary: #64748b;
        --cv-ui-text-disabled: #94a3b8;
        --cv-ui-border-color: #e2e8f0;
        --cv-ui-border-color-hover: #cbd5e1;
        padding: 32px;
        max-width: 900px;
        margin: 0 auto;
        min-height: 100%;
        font-family: var(--cv-ui-font-family);
        background: var(--ui-cat-bg);
        color: var(--ui-cat-text);
        box-shadow: 0 0 0 1px var(--ui-cat-border);
}
.ui-catalogue__title[data-v-8f81b7ee] {
        font-size: 1.5rem;
        font-weight: 700;
        margin-bottom: 28px;
        color: var(--ui-cat-text);
        letter-spacing: -0.02em;
}
.ui-catalogue__section[data-v-8f81b7ee] {
        margin-bottom: 32px;
        padding-bottom: 24px;
        border-bottom: 1px solid var(--ui-cat-border);
}
.ui-catalogue__section[data-v-8f81b7ee]:last-of-type {
        border-bottom: none;
}
.ui-catalogue__section-title[data-v-8f81b7ee] {
        font-size: 1.125rem;
        font-weight: 600;
        margin-bottom: 16px;
        color: var(--ui-cat-text);
}
.ui-catalogue__subtitle[data-v-8f81b7ee] {
        font-size: 0.875rem;
        font-weight: 500;
        margin-bottom: 10px;
        color: var(--ui-cat-text-muted);
}
.ui-catalogue__grid[data-v-8f81b7ee] {
        display: flex;
        flex-direction: column;
        gap: 16px;
}
.ui-catalogue__grid--wrap[data-v-8f81b7ee] {
        flex-direction: row;
        flex-wrap: wrap;
        align-items: center;
        gap: 20px;
}
.ui-catalogue__item[data-v-8f81b7ee] {
        display: flex;
        flex-direction: column;
        gap: 6px;
        max-width: 320px;
}
.ui-catalogue__item--row[data-v-8f81b7ee] {
        flex-direction: row;
        align-items: center;
        gap: 10px;
        max-width: none;
}
.ui-catalogue__label[data-v-8f81b7ee] {
        font-size: 0.75rem;
        font-weight: 500;
        color: var(--ui-cat-text-muted);
        text-transform: uppercase;
        letter-spacing: 0.04em;
}
.ui-catalogue__buttons[data-v-8f81b7ee] {
        display: flex;
        flex-wrap: wrap;
        gap: 10px;
        margin-bottom: 16px;
}
.ui-catalogue__block[data-v-8f81b7ee] {
        margin-bottom: 24px;
}
.ui-catalogue__switch-label[data-v-8f81b7ee] {
        font-size: 0.875rem;
        color: var(--ui-cat-text-muted);
}
.ui-catalogue__hint[data-v-8f81b7ee] {
        font-size: 0.875rem;
        color: var(--ui-cat-text-muted);
        margin-top: 8px;
}
.ui-catalogue__section--data .ui-catalogue__pre[data-v-8f81b7ee] {
        font-size: 0.75rem;
        line-height: 1.5;
        padding: 16px;
        background: var(--ui-cat-bg-soft);
        border: 1px solid var(--ui-cat-border);
        border-radius: 8px;
        overflow: auto;
        margin: 0;
        color: var(--ui-cat-text);
}

.ui-story[data-v-d2079ac7] {
        padding: 24px;
        font-family: var(--cv-ui-font-family);
}
.ui-story__block[data-v-d2079ac7] {
        margin-bottom: 32px;
}
.ui-story__subtitle[data-v-d2079ac7] {
        font-size: 0.875rem;
        font-weight: 500;
        margin-bottom: 10px;
        color: var(--cv-ui-text-secondary);
}

    /* Rich content — table */
.demo-table[data-v-d2079ac7] {
        width: 100%;
        border-collapse: collapse;
        font-size: 0.8125rem;
        color: var(--cv-ui-text-primary);
}
.demo-table th[data-v-d2079ac7] {
        text-align: left;
        font-weight: 600;
        font-size: 0.75rem;
        color: var(--cv-ui-text-secondary);
        text-transform: uppercase;
        letter-spacing: 0.04em;
        padding: 6px 8px;
        border-bottom: 1px solid var(--cv-ui-border-color);
}
.demo-table td[data-v-d2079ac7] {
        padding: 8px;
        border-bottom: 1px solid var(--cv-ui-border-color);
}
.demo-table tr:last-child td[data-v-d2079ac7] {
        border-bottom: none;
}
.status-dot[data-v-d2079ac7] {
        display: inline-block;
        width: 7px;
        height: 7px;
        border-radius: 50%;
        margin-right: 5px;
        vertical-align: middle;
}
.status-dot--active[data-v-d2079ac7] {
        background-color: #22c55e;
}
.status-dot--idle[data-v-d2079ac7] {
        background-color: var(--cv-ui-text-tertiary);
}

    /* Rich content — list */
.demo-list[data-v-d2079ac7] {
        padding-left: 20px;
        margin: 0;
        display: flex;
        flex-direction: column;
        gap: 10px;
        font-size: 0.8125rem;
        color: var(--cv-ui-text-secondary);
        line-height: 1.6;
}
.demo-list li strong[data-v-d2079ac7] {
        color: var(--cv-ui-text-primary);
}

    /* Rich content — plan */
.demo-plan[data-v-d2079ac7] {
        display: flex;
        flex-direction: column;
        gap: 10px;
}
.demo-plan__header[data-v-d2079ac7] {
        display: flex;
        align-items: center;
        gap: 10px;
}
.demo-plan__name[data-v-d2079ac7] {
        font-size: 0.9375rem;
        font-weight: 600;
        color: var(--cv-ui-text-primary);
}
.demo-plan__badge[data-v-d2079ac7] {
        display: inline-flex;
        align-items: center;
        padding: 2px 8px;
        border-radius: 999px;
        background-color: color-mix(in srgb, #22c55e 15%, transparent);
        color: #16a34a;
        font-size: 0.6875rem;
        font-weight: 600;
}
.demo-plan__desc[data-v-d2079ac7] {
        font-size: 0.8125rem;
        color: var(--cv-ui-text-secondary);
        line-height: 1.6;
        margin: 0;
}
.demo-plan__features[data-v-d2079ac7] {
        display: grid;
        grid-template-columns: 1fr 1fr;
        gap: 6px;
}
.demo-plan__feature[data-v-d2079ac7] {
        display: flex;
        align-items: center;
        gap: 6px;
        font-size: 0.8125rem;
        color: var(--cv-ui-text-secondary);
}
.demo-plan__feature svg[data-v-d2079ac7] {
        color: #22c55e;
        flex-shrink: 0;
}

.ui-story[data-v-239e624d] { padding: 24px; font-family: var(--cv-ui-font-family);
}
.ui-story__block[data-v-239e624d] { margin-bottom: 24px;
}
.ui-story__subtitle[data-v-239e624d] { font-size: 0.875rem; font-weight: 500; margin-bottom: 10px; color: var(--cv-ui-text-secondary);
}
.ui-story__grid[data-v-239e624d] { display: flex; flex-direction: column; gap: 12px; max-width: 560px;
}
/* Advanced Filter Builder Styles - Target AG Grid elements */
/* Note: Using standard CSS selectors (not :deep()) since this is an external CSS file */
.cv-data-table [class*='advanced-filter'][class*='button'],
.cv-data-table [class*='ag-advanced-filter-button-bar'],
.cv-data-table .ag-advanced-filter-button-bar,
.cv-data-table .ag-button.ag-standard-button.ag-filter-apply-panel-button.ag-filter-apply-panel-apply-button {
    margin: 0 15px !important;
}
/* ============================================
   RESPONSIVE DESIGN
   ============================================ */

/* Tablet and below: ThemeBuilder already on top, just adjust sizing */
@media (max-width: 1024px) {
    .cv-data-table__edit-layout__theme-builder {
        width: 100%;
        max-width: 100%;
        border-right: none;
        border-bottom: 2px solid rgba(100, 116, 139, 0.15);
        max-height: 50vh;
        overflow-y: auto;
    }

    .cv-data-table__grid-wrapper {
        width: 100%;
    }

    /* Hide PresetSlider on tablet - use presets in ThemeBuilder */
    .cv-data-table__edit-layout__preset-slider {
        display: none !important;
    }

    /* Show presets section in ThemeBuilder on tablet */
    .cv-data-table__edit-layout__theme-builder .cv-theme-builder__accordion--presets {
        display: block !important;
    }

    /* Quick filters (buttons): horizontal scroll instead of wrap */
    .cv-data-table .cv-data-table__quick-filters {
        padding-left: 1rem;
        padding-right: 1rem;
        justify-content: flex-start;
        overflow: hidden;
    }

    .cv-data-table .cv-data-table__quick-filters__container {
        flex-wrap: nowrap;
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
        justify-content: flex-start;
        width: 100%;
        min-width: 0;
        padding-bottom: 2px; /* space for scrollbar */
        scrollbar-width: thin;
    }

    .cv-data-table .cv-data-table__quick-filters__container .cv-data-table__quick-filters__button {
        flex-shrink: 0;
    }
}

/* Mobile: Hide edit mode button, make table full width */
@media (max-width: 768px) {
    .cv-data-table {
        width: 100%;
    }

    .cv-data-table__container {
        width: 100%;
    }

    .cv-data-table__edit-layout__content {
        flex-direction: column;
    }

    /* Theme Builder as full-screen modal on mobile */
    .cv-data-table__edit-layout__theme-builder {
        width: 100vw !important;
        max-width: 100vw !important;
        height: 100vh !important;
        max-height: 100vh !important;
        position: fixed !important;
        top: 0 !important;
        left: 0 !important;
        right: 0 !important;
        bottom: 0 !important;
        z-index: 2000 !important;
        border-radius: 0 !important;
        border: none !important;
        overflow-y: auto !important;
        overflow-x: hidden !important;
        -webkit-overflow-scrolling: touch !important;
        box-shadow: none !important;
    }

    /* Show close button on mobile */
    .cv-data-table__edit-layout__theme-builder .cv-theme-builder__close-btn {
        display: flex !important;
    }

    /* Hide PresetSlider on mobile - presets are now in ThemeBuilder accordion */
    .cv-data-table__edit-layout__preset-slider {
        display: none !important;
    }

    /* Show presets section on mobile, hide on desktop (desktop uses PresetSlider) */
    .cv-data-table__edit-layout__theme-builder .cv-theme-builder__accordion--presets {
        display: block !important;
    }

    /* Ensure theme builder content is scrollable on mobile */
    .cv-data-table__edit-layout__theme-builder .cv-theme-builder__content {
        padding-bottom: 2rem;
    }

    /* Make accordion sections more touch-friendly on mobile */
    .cv-data-table__edit-layout__theme-builder .cv-theme-builder__accordion-trigger {
        min-height: 48px;
        padding: 1rem;
    }

    /* Optimize form inputs for mobile */
    .cv-data-table__edit-layout__theme-builder .cv-theme-builder__input,
    .cv-data-table__edit-layout__theme-builder .cv-theme-builder__select {
        min-height: 44px;
        font-size: 16px; /* Prevents zoom on iOS */
    }

    /* Optimize presets grid for mobile - 2 columns */
    .cv-data-table__edit-layout__theme-builder .cv-theme-builder__presets-grid {
        grid-template-columns: repeat(2, 1fr) !important;
        gap: 0.75rem !important;
    }

    .cv-data-table__edit-layout__theme-builder .cv-theme-builder__preset-card {
        padding: 0.75rem !important;
        min-height: 120px !important;
    }

    .cv-data-table__edit-layout__theme-builder .cv-theme-builder__preset-preview {
        height: 50px !important;
    }

    .cv-data-table__edit-layout__theme-builder .cv-theme-builder__preset-label {
        font-size: 0.75rem !important;
        text-align: center !important;
    }

    /* Keep edit mode toggle on mobile but make it more accessible */
    .cv-data-table__edit-toggle {
        /* Keep visible but smaller on mobile */
        width: 36px;
        height: 36px;
    }

    /* Toolbar: stack in column on mobile — search first, then actions */
    .cv-data-table__toolbar {
        flex-direction: column;
        align-items: stretch;
        padding: 0.5rem 1rem;
        gap: 0.75rem;
    }

    .cv-data-table__toolbar-start {
        width: 100%;
    }

    .cv-data-table__toolbar-end {
        width: 100%;
        margin-left: 0;
        flex-direction: column;
        align-items: stretch;
        gap: 0.5rem;
    }

    /* Quick filter (search input): full width, no overflow, centered block */
    .cv-data-table__toolbar .cv-data-table__toolbar-end .cv-data-table__quick-filter {
        width: 100%;
        max-width: 100%;
        min-width: 0;
        flex: 1 1 auto;
        justify-content: center;
        padding-left: 0;
        padding-right: 0;
    }

    .cv-data-table__toolbar .cv-data-table__toolbar-end .cv-data-table__quick-filter .cv-data-table__quick-filter__input {
        min-width: 0;
        width: 100%;
        max-width: 100%;
        box-sizing: border-box;
    }

    .cv-data-table__toolbar .cv-data-table__top-actions {
        gap: 0.25rem;
        justify-content: flex-start;
        flex-wrap: wrap;
    }

    .cv-data-table__grid-features-btn {
        width: 36px;
        height: 36px;
    }

    /* Ensure table takes full width on mobile */
    .cv-data-table__grid-wrapper {
        width: 100%;
    }

    .cv-data-table__grid-inner {
        width: 100%;
    }

    /* AG Grid horizontal scroll on mobile */
    .cv-data-table__grid-inner :deep(.ag-body-viewport) {
        overflow-x: hidden; /* Hide horizontal scrollbar - use fake scrollbar instead */
        -webkit-overflow-scrolling: touch; /* Smooth scrolling on iOS */
    }

    /* Optimize AG Grid pagination panel for mobile - Flex layout with controlled widths */
    .cv-data-table .ag-paging-panel,
    .cv-data-table__grid-inner .ag-paging-panel,
    .cv-data-table .ag-root-wrapper .ag-paging-panel {
        display: flex !important;
        flex-direction: row !important;
        align-items: center !important;
        justify-content: space-between !important;
        gap: 0.5rem !important;
        width: 100% !important;
        padding: 0.75rem 0.5rem !important;
        font-size: 0.75rem !important;
        box-sizing: border-box !important;
        overflow: visible !important;
    }

    /* Page size selector - Reduced width but still usable */
    .cv-data-table .ag-paging-panel .ag-paging-page-size,
    .cv-data-table__grid-inner .ag-paging-panel .ag-paging-page-size,
    .cv-data-table .ag-root-wrapper .ag-paging-panel .ag-paging-page-size {
        display: flex !important;
        flex-direction: column !important;
        width: auto !important;
        min-width: 80px !important;
        max-width: 120px !important;
        flex-shrink: 0 !important;
        gap: 0.25rem !important;
        margin: 0 !important;
        padding: 0 !important;
    }

    .cv-data-table .ag-paging-panel .ag-paging-page-size label,
    .cv-data-table__grid-inner .ag-paging-panel .ag-paging-page-size label,
    .cv-data-table .ag-root-wrapper .ag-paging-panel .ag-paging-page-size label {
        display: block !important;
        width: 100% !important;
        margin: 0 !important;
        padding: 0 !important;
        font-size: 0.75rem !important;
        white-space: nowrap !important;
    }

    .cv-data-table .ag-paging-panel .ag-paging-page-size select,
    .cv-data-table__grid-inner .ag-paging-panel .ag-paging-page-size select,
    .cv-data-table .ag-root-wrapper .ag-paging-panel .ag-paging-page-size select {
        width: 100% !important;
        min-width: 80px !important;
        max-width: 120px !important;
        padding: 0.5rem !important;
        font-size: 0.75rem !important;
        box-sizing: border-box !important;
        margin: 0 !important;
    }

    /* Pagination info - Respectable width, centered */
    .cv-data-table .ag-paging-panel .ag-paging-row-summary-panel,
    .cv-data-table__grid-inner .ag-paging-panel .ag-paging-row-summary-panel,
    .cv-data-table .ag-root-wrapper .ag-paging-panel .ag-paging-row-summary-panel {
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
        flex: 1 !important;
        min-width: 120px !important;
        text-align: center !important;
        font-size: 0.75rem !important;
        line-height: 1.5 !important;
        margin: 0 !important;
        padding: 0 0.5rem !important;
        gap: 0.25rem !important;
    }

    /* Navigation buttons - Flex container, centered buttons */
    .cv-data-table .ag-paging-panel .ag-paging-button-panel,
    .cv-data-table__grid-inner .ag-paging-panel .ag-paging-button-panel,
    .cv-data-table .ag-root-wrapper .ag-paging-panel .ag-paging-button-panel {
        display: flex !important;
        justify-content: center !important;
        align-items: center !important;
        flex-shrink: 0 !important;
        gap: 0.5rem !important;
        flex-wrap: wrap !important;
        margin: 0 !important;
        padding: 0 !important;
    }

    .cv-data-table .ag-paging-panel .ag-paging-button-panel button,
    .cv-data-table__grid-inner .ag-paging-panel .ag-paging-button-panel button,
    .cv-data-table .ag-root-wrapper .ag-paging-panel .ag-paging-button-panel button {
        min-width: 44px !important;
        min-height: 44px !important;
        padding: 0.5rem !important;
        font-size: 0.75rem !important;
        border-radius: 6px !important;
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
        box-sizing: border-box !important;
        margin: 0 !important;
    }

    /* Page number display */
    .cv-data-table .ag-paging-panel .ag-paging-button-panel .ag-paging-description,
    .cv-data-table__grid-inner .ag-paging-panel .ag-paging-button-panel .ag-paging-description,
    .cv-data-table .ag-root-wrapper .ag-paging-panel .ag-paging-button-panel .ag-paging-description {
        font-size: 0.75rem !important;
        white-space: nowrap !important;
        padding: 0 0.5rem !important;
        margin: 0 !important;
    }

    /* Hide any misplaced page size selectors in table body */
    .cv-data-table .ag-body-viewport .ag-paging-page-size,
    .cv-data-table__grid-inner .ag-body-viewport .ag-paging-page-size,
    .cv-data-table .ag-body-viewport .ag-paging-panel {
        display: none !important;
    }
}

/* Small mobile: Further optimizations */
@media (max-width: 480px) {
    .cv-data-table__toolbar {
        padding: 0.375rem 0.75rem;
        min-height: 40px;
    }

    .cv-data-table__grid-features-btn {
        padding: 0.25rem;
        width: 36px;
        height: 36px;
        justify-content: center;
    }

    .cv-data-table__grid-features-icon {
        width: 18px;
        height: 18px;
    }

    /* Even more compact pagination on small mobile */
    .cv-data-table .ag-paging-panel,
    .cv-data-table__grid-inner .ag-paging-panel,
    .cv-data-table .ag-root-wrapper .ag-paging-panel {
        padding: 0.5rem 0.375rem !important;
        gap: 0.5rem !important;
        font-size: 0.6875rem !important; /* Reduced from 0.8125rem (11px) */
    }

    .cv-data-table .ag-paging-panel .ag-paging-button-panel button,
    .cv-data-table__grid-inner .ag-paging-panel .ag-paging-button-panel button {
        min-width: 40px !important;
        min-height: 40px !important;
        padding: 0.375rem !important;
        font-size: 0.6875rem !important; /* Reduced from 0.8125rem */
    }

    .cv-data-table .ag-paging-panel .ag-paging-row-summary-panel,
    .cv-data-table__grid-inner .ag-paging-panel .ag-paging-row-summary-panel {
        font-size: 0.6875rem !important; /* Reduced from 0.8125rem */
    }

    /* Simplify page size selector text on very small screens */
    .cv-data-table .ag-paging-panel .ag-paging-page-size label,
    .cv-data-table__grid-inner .ag-paging-panel .ag-paging-page-size label {
        font-size: 0.6875rem !important; /* Reduced from 0.8125rem */
    }

    .cv-data-table .ag-paging-panel .ag-paging-page-size select,
    .cv-data-table__grid-inner .ag-paging-panel .ag-paging-page-size select {
        font-size: 0.6875rem !important; /* Reduced from 0.8125rem */
        padding: 0.375rem !important;
    }
}
/* ============================================
   LAYOUT STYLES ONLY
   No AG Grid styling - use Theme API instead
   ============================================ */

/* Badge/chip cells: compact so they fit row height without truncation */
.cv-data-table .cv-datatable-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    box-sizing: border-box;
    max-height: 100%;
    padding: 2px 8px;
    border-radius: 9999px;
    font-size: 0.75rem;
    line-height: 1.25;
    font-weight: 500;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.cv-data-table .cv-datatable-badge--empty {
    opacity: 0.6;
}

.cv-data-table {
    display: flex;
    flex-direction: column;
    min-height: 0;
    /* Default: adapt to content */
    width: 100%;
    height: 100%;
}

.cv-data-table__error,
.cv-data-table__loading {
    padding: 2rem;
    text-align: center;
}

.cv-data-table__error-content {
    display: flex;
    flex-direction: column;
    gap: 1rem;
    align-items: center;
}

.cv-data-table__error-message {
    color: var(--cv-ui-color-danger, #ef4444);
}

.cv-data-table__error-retry {
    padding: 0.5rem 1rem;
    background-color: var(--cv-ui-color-primary, #3b82f6);
    color: white;
    border: none;
    border-radius: 4px;
    cursor: pointer;
}

.cv-data-table__container {
    position: relative;
    display: flex;
    flex-direction: column;
    min-height: 0;
    height: 100%;
    /* Default: adapt to content */
    max-width: 100%;
    transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1);
}

/* Grid content hidden behind skeleton during init — toolbar stays visible */
.cv-data-table__container:has(.cv-data-table__skeleton) .cv-data-table__grid-wrapper,
.cv-data-table__container:has(.cv-data-table__skeleton) .cv-data-table__edit-layout {
    opacity: 0;
    pointer-events: none;
}

/* Fullscreen Modal */
.cv-data-table__fullscreen-modal {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    width: 100vw;
    height: 100vh;
    z-index: 9999;
    background: rgba(0, 0, 0, 0.95);
    backdrop-filter: blur(8px);
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0;
    overflow: hidden;
}

.cv-data-table__fullscreen-modal-content {
    width: 100%;
    height: 100%;
    display: flex;
    flex-direction: column;
    background: var(--ag-background-color, #ffffff);
    position: relative;
    overflow: hidden;
}

.cv-data-table__fullscreen-grid-wrapper {
    flex: 1;
    min-height: 0;
    min-width: 0;
    display: flex;
    flex-direction: column;
    padding: 0;
    overflow: hidden;
}

/* Fullscreen Modal Transitions */
.fullscreen-modal-enter-active {
    transition: opacity 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

.fullscreen-modal-leave-active {
    transition: opacity 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

.fullscreen-modal-enter-from {
    opacity: 0;
}

.fullscreen-modal-enter-to {
    opacity: 1;
}

.fullscreen-modal-leave-from {
    opacity: 1;
}

.fullscreen-modal-leave-to {
    opacity: 0;
}

@keyframes fullscreen-enter {
    from {
        opacity: 0.95;
        transform: scale(0.98);
        box-shadow: 0 0 0 0 rgba(0, 0, 0, 0);
    }
    to {
        opacity: 1;
        transform: scale(1);
        box-shadow: 0 0 40px rgba(0, 0, 0, 0.3);
    }
}

@keyframes fullscreen-exit {
    from {
        opacity: 1;
        transform: scale(1);
        box-shadow: 0 0 40px rgba(0, 0, 0, 0.3);
    }
    to {
        opacity: 0.95;
        transform: scale(0.98);
        box-shadow: 0 0 0 0 rgba(0, 0, 0, 0);
    }
}

.cv-data-table__container--fullscreen .cv-data-table__edit-layout {
    flex: 1;
    height: 100vh; /* Full height since top actions are hidden */
    min-height: 0;
    border-radius: 0;
}

/* Hide ThemeBuilder in fullscreen mode (optional - can be enabled if needed) */
.cv-data-table__container--fullscreen .cv-data-table__edit-layout__theme-builder {
    display: none;
}

/* Fullscreen Exit Notification */
.cv-data-table__fullscreen-notification {
    position: fixed;
    top: 20px;
    left: 50%;
    transform: translateX(-50%);
    z-index: 10000;
    pointer-events: none;
}

.cv-data-table__fullscreen-notification-content {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    padding: 0.75rem 1.25rem;
    background: rgba(15, 23, 42, 0.95);
    backdrop-filter: blur(10px);
    border: 1px solid rgba(99, 102, 241, 0.3);
    border-radius: 12px;
    /* Single box-shadow to avoid accumulation */
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.4);
    color: #e2e8f0;
    font-size: 0.875rem;
    font-weight: 500;
}

.cv-data-table__fullscreen-notification-icon {
    width: 18px;
    height: 18px;
    color: #94a3b8;
    flex-shrink: 0;
}

.cv-data-table__fullscreen-notification-text {
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

.cv-data-table__fullscreen-notification-text kbd {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0.25rem 0.5rem;
    background: rgba(99, 102, 241, 0.2);
    border: 1px solid rgba(99, 102, 241, 0.4);
    border-radius: 6px;
    font-family: ui-monospace, SFMono-Regular, 'SF Mono', Menlo, Consolas, 'Liberation Mono', monospace;
    font-size: 0.75rem;
    font-weight: 600;
    color: #a78bfa;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.2);
    min-width: 24px;
}

/* Notification transitions */
.fullscreen-notification-enter-active {
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

.fullscreen-notification-leave-active {
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

.fullscreen-notification-enter-from {
    opacity: 0;
    transform: translateX(-50%) translateY(-20px) scale(0.9);
}

.fullscreen-notification-enter-to {
    opacity: 1;
    transform: translateX(-50%) translateY(0) scale(1);
}

.fullscreen-notification-leave-from {
    opacity: 1;
    transform: translateX(-50%) translateY(0) scale(1);
}

.fullscreen-notification-leave-to {
    opacity: 0;
    transform: translateX(-50%) translateY(-20px) scale(0.9);
}

/* Mobile: Adjust notification */
@media (max-width: 768px) {
    .cv-data-table__fullscreen-notification {
        top: 10px;
        left: 10px;
        right: 10px;
        transform: none;
    }

    .cv-data-table__fullscreen-notification-content {
        padding: 0.625rem 1rem;
        font-size: 0.8125rem;
    }

    .cv-data-table__fullscreen-notification-text {
        flex-direction: column;
        align-items: flex-start;
        gap: 0.375rem;
    }

    .fullscreen-notification-enter-from,
    .fullscreen-notification-leave-to {
        transform: translateY(-20px) scale(0.9);
    }

    .fullscreen-notification-enter-to,
    .fullscreen-notification-leave-from {
        transform: translateY(0) scale(1);
    }
}

/* Mobile Exit Button (visible in fullscreen on mobile) */
.cv-data-table__fullscreen-exit-btn {
    position: fixed;
    bottom: 20px;
    left: 50%;
    transform: translateX(-50%);
    z-index: 10000;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    padding: 0.875rem 1.5rem;
    background: var(--accent-color, #3b82f6);
    border: 1px solid var(--accent-color, #3b82f6);
    border-radius: 12px;
    color: #ffffff;
    font-size: 0.875rem;
    font-weight: 600;
    cursor: pointer;
    /* Single box-shadow to avoid accumulation */
    box-shadow: 0 4px 16px rgba(59, 130, 246, 0.5);
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

.cv-data-table__fullscreen-exit-btn:hover {
    background: var(--accent-color, #2563eb);
    border-color: var(--accent-color, #2563eb);
    transform: translateX(-50%) translateY(-2px);
    /* Single box-shadow on hover */
    box-shadow: 0 6px 24px rgba(59, 130, 246, 0.6);
}

.cv-data-table__fullscreen-exit-btn:active {
    transform: translateX(-50%) translateY(0);
}

.cv-data-table__fullscreen-exit-btn-icon {
    width: 18px;
    height: 18px;
    flex-shrink: 0;
}

/* Desktop: Hide exit button (use Escape key instead) */
@media (min-width: 769px) {
    .cv-data-table__fullscreen-exit-btn {
        display: none;
    }
}

/* Exit button transitions */
.fullscreen-exit-button-enter-active {
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

.fullscreen-exit-button-leave-active {
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

.fullscreen-exit-button-enter-from {
    opacity: 0;
    transform: translateX(-50%) translateY(20px) scale(0.9);
}

.fullscreen-exit-button-enter-to {
    opacity: 1;
    transform: translateX(-50%) translateY(0) scale(1);
}

.fullscreen-exit-button-leave-from {
    opacity: 1;
    transform: translateX(-50%) translateY(0) scale(1);
}

.fullscreen-exit-button-leave-to {
    opacity: 0;
    transform: translateX(-50%) translateY(20px) scale(0.9);
}

/* Edit Layout - replaced content-wrapper */
.cv-data-table__edit-layout {
    display: flex;
    flex-direction: column;
    flex: 1;
    min-height: 0;
    min-width: 0;
    overflow: hidden;
    /* border-radius is defined in DataTableEditLayout.vue to avoid conflicts */
}

.cv-data-table__edit-layout__content {
    display: flex;
    flex-direction: row;
    flex: 1;
    min-height: 0;
    min-width: 0;
    overflow: hidden;
}

/* Toolbar: slot (left) + search + top actions grouped (right) */
.cv-data-table__toolbar {
    display: flex;
    align-items: center;
    gap: 1rem;
    padding: 0.75rem 1rem;
    min-height: 48px;
    position: relative;
    z-index: 10;
    width: 100%;
    flex-shrink: 0;
    flex-wrap: wrap-reverse;
}

.cv-data-table__toolbar-start {
    flex-shrink: 0;
}

/* row-reverse : ordre DOM = [boutons, recherche], affichage desktop = [recherche, boutons] */
.cv-data-table__toolbar-end {
    display: flex;
    flex-direction: row-reverse;
    align-items: center;
    gap: 1rem;
    margin-left: auto;
    flex-shrink: 0;
    min-width: 0;
}

.cv-data-table__toolbar .cv-data-table__toolbar-end .cv-data-table__quick-filter {
    flex: 0 1 auto;
    min-width: 200px;
    max-width: 360px;
}

.cv-data-table__toolbar .cv-data-table__toolbar-end .cv-data-table__quick-filter--compact {
    min-width: 140px;
}

.cv-data-table__toolbar .cv-data-table__toolbar-end .cv-data-table__quick-filter--compact:focus-within {
    max-width: 320px;
}

.cv-data-table__toolbar .cv-data-table__top-actions {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0;
    background: transparent;
    min-height: 0;
    position: relative;
    z-index: 10;
    width: auto;
    flex-shrink: 0;
}

.cv-data-table__grid-features-container {
    position: relative;
}

/* Toolbar actions: discreet ghost style */
.cv-data-table__grid-features-btn {
    width: 36px;
    height: 36px;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0;
    border: 1px solid var(--ag-border-color, #cbd5e1);
    border-radius: 8px;
    background: transparent;
    color: var(--ag-secondary-foreground-color, #475569);
    cursor: pointer;
    transition:
        color 0.2s ease,
        background 0.2s ease,
        border-color 0.2s ease,
        transform 0.2s ease;
    position: relative;
}

.cv-data-table__grid-features-btn::before {
    display: none;
}

.cv-data-table__grid-features-icon {
    width: 18px;
    height: 18px;
    flex-shrink: 0;
    position: relative;
    z-index: 1;
    transition: transform 0.2s ease;
}

.cv-data-table__grid-features-btn:hover {
    background: rgba(var(--accent-color-rgb, 59, 130, 246), 0.08);
    border-color: var(--accent-color, #3b82f6);
    color: var(--accent-color, #3b82f6);
    transform: scale(1.02);
}

.cv-data-table__grid-features-btn:hover .cv-data-table__grid-features-icon {
    transform: rotate(12deg);
}

.cv-data-table__grid-features-btn--active {
    background: rgba(var(--accent-color-rgb, 59, 130, 246), 0.12);
    border-color: var(--accent-color, #3b82f6);
    color: var(--accent-color, #3b82f6);
}

.cv-data-table__edit-toggle {
    width: 36px;
    height: 36px;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0;
    border: 1px solid var(--ag-border-color, #cbd5e1);
    border-radius: 8px;
    background: transparent;
    color: var(--ag-secondary-foreground-color, #475569);
    cursor: pointer;
    transition:
        color 0.2s ease,
        background 0.2s ease,
        border-color 0.2s ease,
        transform 0.2s ease;
    position: relative;
}

.cv-data-table__edit-toggle::before {
    display: none;
}

.cv-data-table__edit-toggle-icon {
    width: 18px;
    height: 18px;
    flex-shrink: 0;
    position: relative;
    z-index: 1;
    transition: transform 0.2s ease;
}

.cv-data-table__edit-toggle:hover {
    background: rgba(var(--accent-color-rgb, 59, 130, 246), 0.08);
    border-color: var(--accent-color, #3b82f6);
    color: var(--accent-color, #3b82f6);
    transform: scale(1.02);
}

.cv-data-table__edit-toggle:hover .cv-data-table__edit-toggle-icon {
    transform: scale(1.05);
}

.cv-data-table__edit-toggle--active {
    background: rgba(var(--accent-color-rgb, 59, 130, 246), 0.12);
    border-color: var(--accent-color, #3b82f6);
    color: var(--accent-color, #3b82f6);
}

.cv-data-table__edit-toggle:disabled {
    opacity: 0.5;
    cursor: not-allowed;
    transform: none;
}

.cv-data-table__edit-toggle:disabled:hover {
    transform: none;
    background: transparent;
    border-color: var(--ag-border-color, #cbd5e1);
    color: var(--ag-secondary-foreground-color, #475569);
}

/* Add Button – same ghost style, slightly emphasised border for primary action */
.cv-data-table__add-btn {
    width: 36px;
    height: 36px;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0;
    border: 1px solid var(--accent-color, #3b82f6);
    border-radius: 8px;
    background: rgba(var(--accent-color-rgb, 59, 130, 246), 0.06);
    color: var(--accent-color, #3b82f6);
    cursor: pointer;
    transition:
        color 0.2s ease,
        background 0.2s ease,
        border-color 0.2s ease,
        transform 0.2s ease;
    position: relative;
}

.cv-data-table__add-btn::before {
    display: none;
}

.cv-data-table__add-btn-icon {
    width: 18px;
    height: 18px;
    flex-shrink: 0;
    position: relative;
    z-index: 1;
    transition: transform 0.2s ease;
    color: inherit;
}

.cv-data-table__add-btn:hover {
    background: rgba(var(--accent-color-rgb, 59, 130, 246), 0.12);
    transform: scale(1.02);
}

.cv-data-table__add-btn:hover .cv-data-table__add-btn-icon {
    transform: scale(1.08);
}

.cv-data-table__add-btn:active {
    transform: scale(0.98);
}

.cv-data-table__add-btn:active .cv-data-table__add-btn-icon {
    transform: scale(1);
}

.cv-data-table__export-excel-btn {
    width: 36px;
    height: 36px;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0;
    border: 1px solid var(--ag-border-color, #cbd5e1);
    border-radius: 8px;
    background: transparent;
    color: var(--ag-secondary-foreground-color, #475569);
    cursor: pointer;
    transition:
        color 0.2s ease,
        background 0.2s ease,
        border-color 0.2s ease,
        transform 0.2s ease;
    position: relative;
}

.cv-data-table__export-excel-btn::before {
    display: none;
}

.cv-data-table__export-excel-btn-icon {
    width: 18px;
    height: 18px;
    flex-shrink: 0;
    position: relative;
    z-index: 1;
    transition: transform 0.2s ease;
}

.cv-data-table__export-excel-btn:hover {
    background: rgba(var(--accent-color-rgb, 59, 130, 246), 0.08);
    border-color: var(--accent-color, #3b82f6);
    color: var(--accent-color, #3b82f6);
    transform: scale(1.02);
}

.cv-data-table__export-excel-btn:hover .cv-data-table__export-excel-btn-icon {
    transform: scale(1.05);
}

.cv-data-table__grid-wrapper {
    position: relative;
    flex: 1;
    min-height: 0;
    min-width: 0; /* Important for flex items to shrink properly */
    max-width: 100%; /* Prevent overflow */
    display: flex;
    flex-direction: column; /* Column layout: PresetSlider on top, table below */
    overflow: visible; /* Allow scroll to work properly */
    transition: width 0.3s ease;
}

/* Hide grid during loading */
.cv-data-table__grid-wrapper--loading {
    opacity: 0;
    pointer-events: none;
}

/* Show grid with animation after loading */
.cv-data-table__grid-wrapper:not(.cv-data-table__grid-wrapper--loading) {
    animation: cv-table-fade-in 0.5s ease-out;
}

@keyframes cv-table-fade-in {
    from {
        opacity: 0;
        transform: translateY(10px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.cv-data-table__grid-inner {
    min-height: 0;
    min-width: 0; /* Important for flex items to shrink properly */
    display: flex;
    flex-direction: column;
    overflow: visible; /* Allow content to be visible for scroll */
    /* Take available space in grid-wrapper */
    flex: 1;
    width: 100%;
    /* BorderRadius is applied via inline style from gridBorderRadius computed */
}

/* Layout fixes for AG Grid structure - necessary for flex layout */
.cv-data-table__grid-inner :deep(.ag-root-wrapper) {
    width: 100%;
    height: 100%;
    flex: 1;
    min-height: 0;
    min-width: 0;
    display: flex;
    flex-direction: column;
    overflow: visible; /* Allow scroll to work properly */
}

/* When using autoHeight, AG Grid should adapt to content */
.cv-data-table__grid-inner[style*='height: auto'] :deep(.ag-root-wrapper) {
    height: auto;
    flex: 0 1 auto;
}

.cv-data-table__grid-inner :deep(.ag-root) {
    width: 100%;
    height: 100%;
    flex: 1;
    min-height: 0;
    min-width: 0;
    display: flex;
    flex-direction: column;
    overflow: visible; /* Allow scroll to work properly */
}

/* When using autoHeight, AG Grid root should adapt to content */
.cv-data-table__grid-inner[style*='height: auto'] :deep(.ag-root) {
    height: auto;
    flex: 0 1 auto;
}

.cv-data-table__grid-inner :deep(.ag-body-viewport) {
    flex: 1;
    min-height: 0;
    min-width: 0;
    overflow-x: hidden; /* Hide horizontal scrollbar - use fake scrollbar instead */
    overflow-y: auto; /* Keep vertical scrollbar */
}

/* When using autoHeight, body viewport should adapt */
.cv-data-table__grid-inner[style*='height: auto'] :deep(.ag-body-viewport) {
    flex: 0 1 auto;
    overflow: visible;
}

/* Theme transition animations - subtle and performant */
.cv-data-table__grid-wrapper :deep(.ag-root-wrapper) {
    transition:
        background-color 0.3s ease,
        color 0.3s ease,
        border-color 0.3s ease;
}

/* Apply border radius to AG Grid root wrapper to match grid-inner */
.cv-data-table__grid-inner :deep(.ag-root-wrapper) {
    border-radius: inherit;
    overflow: hidden; /* Ensure border-radius is visible */
}

/* Apply border radius to AG Grid root element */
.cv-data-table__grid-inner :deep(.ag-root) {
    border-radius: inherit;
    overflow: hidden; /* Ensure border-radius is visible */
}

/* Apply border radius to header and body viewport */
.cv-data-table__grid-inner :deep(.ag-header) {
    border-top-left-radius: inherit;
    border-top-right-radius: inherit;
}

.cv-data-table__grid-inner :deep(.ag-body-viewport) {
    border-bottom-left-radius: inherit;
    border-bottom-right-radius: inherit;
}

/* ============================================
   CUSTOM SCROLLBARS FOR AG GRID
   ============================================ */
/* All scrollbar styles are handled globally in datatable-tool-panels.css */
/* This ensures consistent styling across all AG Grid elements without duplication */

/* Top Actions Bar */
.cv-data-table__top-actions {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.75rem 1rem;
    background: transparent;
    min-height: 48px;
    position: relative;
    z-index: 10;
    width: 100%;
    flex-shrink: 0;
    justify-content: flex-end; /* Group buttons together on the right */
}

/* Hide top actions in fullscreen mode */
.cv-data-table__container--fullscreen .cv-data-table__top-actions {
    display: none;
}

.cv-data-table__grid-features-container {
    position: relative;
}

/* Toolbar actions: discreet ghost style */
.cv-data-table__grid-features-btn {
    width: 36px;
    height: 36px;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0;
    border: 1px solid var(--ag-border-color, #cbd5e1);
    border-radius: 8px;
    background: transparent;
    color: var(--ag-secondary-foreground-color, #475569);
    cursor: pointer;
    transition:
        color 0.2s ease,
        background 0.2s ease,
        border-color 0.2s ease,
        transform 0.2s ease;
    position: relative;
}

.cv-data-table__grid-features-btn::before {
    display: none;
}

.cv-data-table__grid-features-icon {
    width: 18px;
    height: 18px;
    flex-shrink: 0;
    position: relative;
    z-index: 1;
    transition: transform 0.2s ease;
}

.cv-data-table__grid-features-btn:hover {
    background: rgba(var(--accent-color-rgb, 59, 130, 246), 0.08);
    border-color: var(--accent-color, #3b82f6);
    color: var(--accent-color, #3b82f6);
    transform: scale(1.02);
}

.cv-data-table__grid-features-btn:hover .cv-data-table__grid-features-icon {
    transform: rotate(12deg);
}

.cv-data-table__grid-features-btn--active {
    background: rgba(var(--accent-color-rgb, 59, 130, 246), 0.12);
    border-color: var(--accent-color, #3b82f6);
    color: var(--accent-color, #3b82f6);
}

.cv-data-table__edit-toggle {
    width: 36px;
    height: 36px;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0;
    border: 1px solid var(--ag-border-color, #cbd5e1);
    border-radius: 8px;
    background: transparent;
    color: var(--ag-secondary-foreground-color, #475569);
    cursor: pointer;
    transition:
        color 0.2s ease,
        background 0.2s ease,
        border-color 0.2s ease,
        transform 0.2s ease;
    position: relative;
}

.cv-data-table__edit-toggle::before {
    display: none;
}

.cv-data-table__edit-toggle-icon {
    width: 18px;
    height: 18px;
    flex-shrink: 0;
    position: relative;
    z-index: 1;
    transition: transform 0.2s ease;
}

.cv-data-table__edit-toggle:hover {
    background: rgba(var(--accent-color-rgb, 59, 130, 246), 0.08);
    border-color: var(--accent-color, #3b82f6);
    color: var(--accent-color, #3b82f6);
    transform: scale(1.02);
}

.cv-data-table__edit-toggle:hover .cv-data-table__edit-toggle-icon {
    transform: scale(1.05);
}

.cv-data-table__edit-toggle--active {
    background: rgba(var(--accent-color-rgb, 59, 130, 246), 0.12);
    border-color: var(--accent-color, #3b82f6);
    color: var(--accent-color, #3b82f6);
}

.cv-data-table__edit-toggle:disabled {
    opacity: 0.5;
    cursor: not-allowed;
    transform: none;
}

.cv-data-table__edit-toggle:disabled:hover {
    transform: none;
    background: transparent;
    border-color: var(--ag-border-color, #cbd5e1);
    color: var(--ag-secondary-foreground-color, #475569);
}

/* Fullscreen Toggle Button */
/* Fullscreen Toggle Button – ghost style */
.cv-data-table__fullscreen-toggle {
    width: 36px;
    height: 36px;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0;
    border: 1px solid var(--ag-border-color, #cbd5e1);
    border-radius: 8px;
    background: transparent;
    color: var(--ag-secondary-foreground-color, #475569);
    cursor: pointer;
    transition:
        color 0.2s ease,
        background 0.2s ease,
        border-color 0.2s ease,
        transform 0.2s ease;
    position: relative;
}

.cv-data-table__fullscreen-toggle::before {
    display: none;
}

.cv-data-table__fullscreen-toggle-icon {
    width: 18px;
    height: 18px;
    flex-shrink: 0;
    position: relative;
    z-index: 1;
    transition: transform 0.2s ease;
}

.cv-data-table__fullscreen-toggle:hover {
    background: rgba(var(--accent-color-rgb, 59, 130, 246), 0.08);
    border-color: var(--accent-color, #3b82f6);
    color: var(--accent-color, #3b82f6);
    transform: scale(1.02);
}

.cv-data-table__fullscreen-toggle:hover .cv-data-table__fullscreen-toggle-icon {
    transform: scale(1.05);
}

.cv-data-table__fullscreen-toggle--active {
    background: rgba(var(--accent-color-rgb, 59, 130, 246), 0.12);
    border-color: var(--accent-color, #3b82f6);
    color: var(--accent-color, #3b82f6);
}

.cv-data-table__fullscreen-toggle--active .cv-data-table__fullscreen-toggle-icon {
    transform: rotate(180deg);
}

.cv-data-table__fullscreen-toggle:disabled {
    opacity: 0.5;
    cursor: not-allowed;
    transform: none;
}

.cv-data-table__fullscreen-toggle:disabled:hover {
    transform: none;
    background: transparent;
    border-color: var(--ag-border-color, #cbd5e1);
    color: var(--ag-secondary-foreground-color, #475569);
}

.cv-data-table__fullscreen-toggle:disabled:hover::before {
    opacity: 0;
}

/* Dark Mode Toggle Button – ghost style */
.cv-data-table__dark-mode-toggle {
    width: 36px;
    height: 36px;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0;
    border: 1px solid var(--ag-border-color, #cbd5e1);
    border-radius: 8px;
    background: transparent;
    color: var(--ag-secondary-foreground-color, #475569);
    cursor: pointer;
    transition:
        color 0.2s ease,
        background 0.2s ease,
        border-color 0.2s ease,
        transform 0.2s ease;
    position: relative;
}

.cv-data-table__dark-mode-toggle::before {
    display: none;
}

.cv-data-table__dark-mode-toggle-icon {
    width: 18px;
    height: 18px;
    flex-shrink: 0;
    position: relative;
    z-index: 1;
    transition: transform 0.3s ease;
}

.cv-data-table__dark-mode-toggle:hover {
    background: rgba(var(--accent-color-rgb, 59, 130, 246), 0.08);
    border-color: var(--accent-color, #3b82f6);
    color: var(--accent-color, #3b82f6);
    transform: scale(1.02);
}

.cv-data-table__dark-mode-toggle:hover .cv-data-table__dark-mode-toggle-icon {
    transform: rotate(15deg) scale(1.05);
}

/* ── Context menu ──────────────────────────────────────────────────────────── */
.cv-context-menu {
    position: fixed;
    z-index: 9999;
    min-width: 200px;
    border-radius: 8px;
    border: 1px solid #e2e8f0;
    background: #ffffff;
    padding: 4px 0;
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.12), 0 1px 4px rgba(0, 0, 0, 0.08);
}

.cv-context-menu__item {
    display: flex;
    align-items: center;
    gap: 10px;
    width: 100%;
    padding: 8px 16px;
    border: none;
    background: transparent;
    text-align: left;
    font-size: 13px;
    color: #374151;
    cursor: pointer;
    transition: background 0.1s ease;
}

.cv-context-menu__item:hover {
    background: #f8fafc;
    color: #111827;
}

.cv-context-menu__item-icon {
    font-size: 15px;
    color: #9ca3af;
    flex-shrink: 0;
}
/* Loading Overlay Transitions */
.edit-mode-loading-enter-active {
    transition:
        opacity 0.4s ease,
        transform 0.4s ease;
}

.edit-mode-loading-leave-active {
    transition:
        opacity 0.5s ease 0.1s,
        transform 0.5s ease 0.1s;
}

.edit-mode-loading-enter-from {
    opacity: 0;
    transform: scale(0.95);
}

.edit-mode-loading-leave-to {
    opacity: 0;
    transform: scale(1.02);
}

.edit-mode-loading-enter-to,
.edit-mode-loading-leave-from {
    opacity: 1;
    transform: scale(1);
}

/* Theme Builder transitions */
.theme-builder-slide-enter-active {
    transition:
        transform 0.4s cubic-bezier(0.4, 0, 0.2, 1),
        opacity 0.4s ease;
}

.theme-builder-slide-leave-active {
    transition:
        transform 0.3s ease,
        opacity 0.3s ease;
}

.theme-builder-slide-enter-from {
    transform: translateX(-100%);
    opacity: 0;
}

.theme-builder-slide-enter-to {
    transform: translateX(0);
    opacity: 1;
}

.theme-builder-slide-leave-from {
    transform: translateX(0);
    opacity: 1;
}

.theme-builder-slide-leave-to {
    transform: translateX(-100%);
    opacity: 0;
}

/* Preset Slider transitions */
.preset-slider-enter-active {
    transition:
        transform 0.3s ease,
        opacity 0.3s ease;
}

.preset-slider-leave-active {
    transition:
        transform 0.3s ease,
        opacity 0.3s ease;
}

.preset-slider-enter-from {
    transform: translateY(-100%);
    opacity: 0;
}

.preset-slider-enter-to {
    transform: translateY(0);
    opacity: 1;
}

.preset-slider-leave-from {
    transform: translateY(0);
    opacity: 1;
}

.preset-slider-leave-to {
    transform: translateY(-100%);
    opacity: 0;
}
/**
 * DataTable Tool Panels Styles
 * 
 * Styles for AG Grid Enterprise Side Bar tool panels (Columns, Filters, etc.)
 * These styles complement the base AG Grid theme.
 */

/* Hide only AG Grid's fake vertical scrollbar to prevent duplication */
.ag-body-vertical-scroll {
    display: none !important;
}

/* Style the horizontal fake scrollbar container - keep it visible for fixed position */
.ag-body-horizontal-scroll {
    height: 12px !important;
    min-height: 12px !important;
    max-height: 12px !important;
}

/* Style the horizontal scrollbar viewport inside the fake scrollbar */
.ag-body-horizontal-scroll-viewport {
    height: 12px !important;
    min-height: 12px !important;
    max-height: 12px !important;
}

/* Global scrollbar styling for AG Grid - target only real browser scrollbars */
/* Style vertical scrollbar on ag-body-viewport */
.ag-body-viewport::-webkit-scrollbar {
    width: 12px !important;
    height: 0 !important; /* Hide horizontal scrollbar completely */
}

/* Force vertical scrollbar only on ag-body-viewport */
.ag-body-viewport {
    /* Hide horizontal scrollbar but keep vertical */
    scrollbar-width: thin !important; /* Firefox - vertical only */
    scrollbar-color: var(--ag-accent-color, #3b82f6) var(--ag-background-color, rgba(241, 245, 249, 0.5)) !important;
}

/* Hide horizontal scrollbar on center cols viewport and container (they have native scrollbars) */
.ag-center-cols-viewport::-webkit-scrollbar,
.ag-center-cols-container::-webkit-scrollbar {
    width: 0 !important;
    height: 0 !important;
}

/* Style horizontal scrollbar ONLY on fake scrollbar viewport (the one that stays fixed) */
.ag-body-horizontal-scroll-viewport::-webkit-scrollbar,
.ag-side-bar::-webkit-scrollbar,
.ag-side-bar *::-webkit-scrollbar,
.ag-tool-panel::-webkit-scrollbar,
.ag-tool-panel *::-webkit-scrollbar,
.ag-columns-panel::-webkit-scrollbar,
.ag-columns-panel *::-webkit-scrollbar,
.ag-filters-panel::-webkit-scrollbar,
.ag-filters-panel *::-webkit-scrollbar {
    width: 12px !important;
    height: 12px !important;
}

/* Scrollbar track on ag-body-viewport (vertical only, horizontal is hidden) */
.ag-body-viewport::-webkit-scrollbar-track {
    background: var(--ag-background-color, rgba(241, 245, 249, 0.5)) !important;
    border-radius: 6px !important;
    margin: 2px !important;
}

/* Hide horizontal scrollbar track on center cols (they use fake scrollbar) */
.ag-center-cols-viewport::-webkit-scrollbar-track,
.ag-center-cols-container::-webkit-scrollbar-track {
    display: none !important;
}

/* Horizontal scrollbar track on fake scrollbar viewport */
.ag-body-horizontal-scroll-viewport::-webkit-scrollbar-track,
.ag-side-bar::-webkit-scrollbar-track,
.ag-side-bar *::-webkit-scrollbar-track,
.ag-tool-panel::-webkit-scrollbar-track,
.ag-tool-panel *::-webkit-scrollbar-track,
.ag-columns-panel::-webkit-scrollbar-track,
.ag-columns-panel *::-webkit-scrollbar-track,
.ag-filters-panel::-webkit-scrollbar-track,
.ag-filters-panel *::-webkit-scrollbar-track {
    background: var(--ag-background-color, rgba(241, 245, 249, 0.5)) !important;
    border-radius: 6px !important;
    margin: 2px !important;
}

/* Scrollbar thumb on ag-body-viewport (vertical only) */
.ag-body-viewport::-webkit-scrollbar-thumb {
    background: var(--ag-accent-color, #3b82f6) !important;
    border-radius: 6px !important;
    border: 2px solid var(--ag-background-color, rgba(241, 245, 249, 0.5)) !important;
    background-clip: padding-box !important;
    transition: all 0.2s ease !important;
    min-height: 30px !important;
}

/* Hide horizontal scrollbar thumb on center cols (they use fake scrollbar) */
.ag-center-cols-viewport::-webkit-scrollbar-thumb,
.ag-center-cols-container::-webkit-scrollbar-thumb {
    display: none !important;
}

/* Horizontal scrollbar thumb on fake scrollbar viewport */
.ag-body-horizontal-scroll-viewport::-webkit-scrollbar-thumb,
.ag-side-bar::-webkit-scrollbar-thumb,
.ag-side-bar *::-webkit-scrollbar-thumb,
.ag-tool-panel::-webkit-scrollbar-thumb,
.ag-tool-panel *::-webkit-scrollbar-thumb,
.ag-columns-panel::-webkit-scrollbar-thumb,
.ag-columns-panel *::-webkit-scrollbar-thumb,
.ag-filters-panel::-webkit-scrollbar-thumb,
.ag-filters-panel *::-webkit-scrollbar-thumb {
    background: var(--ag-accent-color, #3b82f6) !important;
    border-radius: 6px !important;
    border: 2px solid var(--ag-background-color, rgba(241, 245, 249, 0.5)) !important;
    background-clip: padding-box !important;
    transition: all 0.2s ease !important;
    min-height: 30px !important;
    min-width: 30px !important;
}

/* Scrollbar thumb hover on ag-body-viewport (vertical only) */
.ag-body-viewport::-webkit-scrollbar-thumb:hover {
    background: var(--ag-accent-color, #2563eb) !important;
    border-color: var(--ag-background-color, rgba(241, 245, 249, 0.8)) !important;
    box-shadow: 0 0 8px rgba(59, 130, 246, 0.4) !important;
}

.ag-body-viewport::-webkit-scrollbar-thumb:active {
    background: var(--ag-accent-color, #1d4ed8) !important;
}

/* Horizontal scrollbar thumb hover on fake scrollbar viewport */
.ag-body-horizontal-scroll-viewport::-webkit-scrollbar-thumb:hover,
.ag-side-bar::-webkit-scrollbar-thumb:hover,
.ag-side-bar *::-webkit-scrollbar-thumb:hover,
.ag-tool-panel::-webkit-scrollbar-thumb:hover,
.ag-tool-panel *::-webkit-scrollbar-thumb:hover,
.ag-columns-panel::-webkit-scrollbar-thumb:hover,
.ag-columns-panel *::-webkit-scrollbar-thumb:hover,
.ag-filters-panel::-webkit-scrollbar-thumb:hover,
.ag-filters-panel *::-webkit-scrollbar-thumb:hover {
    background: var(--ag-accent-color, #2563eb) !important;
    border-color: var(--ag-background-color, rgba(241, 245, 249, 0.8)) !important;
    box-shadow: 0 0 8px rgba(59, 130, 246, 0.4) !important;
}

.ag-body-horizontal-scroll-viewport::-webkit-scrollbar-thumb:active,
.ag-side-bar::-webkit-scrollbar-thumb:active,
.ag-side-bar *::-webkit-scrollbar-thumb:active,
.ag-tool-panel::-webkit-scrollbar-thumb:active,
.ag-tool-panel *::-webkit-scrollbar-thumb:active,
.ag-columns-panel::-webkit-scrollbar-thumb:active,
.ag-columns-panel *::-webkit-scrollbar-thumb:active,
.ag-filters-panel::-webkit-scrollbar-thumb:active,
.ag-filters-panel *::-webkit-scrollbar-thumb:active {
    background: var(--ag-accent-color, #1d4ed8) !important;
}

/* Hide scrollbar corner on ag-body-viewport (where horizontal and vertical meet) */
.ag-body-viewport::-webkit-scrollbar-corner {
    display: none !important;
}

/* Scrollbar corner on other elements */
.ag-body-horizontal-scroll-viewport::-webkit-scrollbar-corner,
.ag-side-bar::-webkit-scrollbar-corner,
.ag-side-bar *::-webkit-scrollbar-corner,
.ag-tool-panel::-webkit-scrollbar-corner,
.ag-tool-panel *::-webkit-scrollbar-corner,
.ag-columns-panel::-webkit-scrollbar-corner,
.ag-columns-panel *::-webkit-scrollbar-corner,
.ag-filters-panel::-webkit-scrollbar-corner,
.ag-filters-panel *::-webkit-scrollbar-corner {
    background: var(--ag-background-color, rgba(241, 245, 249, 0.5)) !important;
    border-radius: 6px !important;
}

/* Firefox scrollbar for AG Grid elements (exclude fake scrollbars) */
/* Note: .ag-body-viewport and .ag-center-cols-viewport/.ag-center-cols-container are handled separately above to hide horizontal scrollbar */
.ag-body-horizontal-scroll-viewport,
.ag-side-bar,
.ag-side-bar *,
.ag-tool-panel,
.ag-tool-panel *,
.ag-columns-panel,
.ag-columns-panel *,
.ag-filters-panel,
.ag-filters-panel * {
    scrollbar-width: thin !important;
    scrollbar-color: var(--ag-accent-color, #3b82f6) var(--ag-background-color, rgba(241, 245, 249, 0.5)) !important;
}

/* Ensure sideBar and tool panels react to theme changes */
/* Force background color update when theme changes */
.ag-side-bar,
.ag-tool-panel,
.ag-columns-panel,
.ag-filters-panel {
    /* Use chromeBackgroundColor from theme, fallback to background-color */
    background-color: var(--ag-chrome-background-color, var(--ag-background-color, #ffffff)) !important;
    transition:
        background-color 0.3s ease,
        color 0.3s ease;
}

/* Dark mode support for sideBar */
[data-ag-theme-mode='dark'] .ag-side-bar,
[data-ag-theme-mode='dark'] .ag-tool-panel,
[data-ag-theme-mode='dark'] .ag-columns-panel,
[data-ag-theme-mode='dark'] .ag-filters-panel,
.ag-theme-quartz-dark .ag-side-bar,
.ag-theme-quartz-dark .ag-tool-panel,
.ag-theme-quartz-dark .ag-columns-panel,
.ag-theme-quartz-dark .ag-filters-panel,
.ag-theme-alpine-dark .ag-side-bar,
.ag-theme-alpine-dark .ag-tool-panel,
.ag-theme-alpine-dark .ag-columns-panel,
.ag-theme-alpine-dark .ag-filters-panel,
.ag-theme-balham-dark .ag-side-bar,
.ag-theme-balham-dark .ag-tool-panel,
.ag-theme-balham-dark .ag-columns-panel,
.ag-theme-balham-dark .ag-filters-panel {
    background-color: var(--ag-chrome-background-color, var(--ag-background-color, #1e293b)) !important;
}

/* Hide horizontal scrollbar on center cols for Firefox */
.ag-center-cols-viewport,
.ag-center-cols-container {
    scrollbar-width: none !important; /* Hide horizontal scrollbar - use fake scrollbar instead */
}

    /* ── Wrapper ─────────────────────────────────────────────── */
.cv-data-table__skeleton[data-v-7714425f] {
        position: absolute;
        inset: 0;
        z-index: 10;
        background: var(--cv-ui-bg-primary, #fff);
        display: flex;
        flex-direction: column;
        overflow: hidden;
}

    /* ── Top progress bar ────────────────────────────────────── */
.cv-data-table__skeleton__bar[data-v-7714425f] {
        height: 3px;
        flex-shrink: 0;
        background: linear-gradient(
            90deg,
            transparent 0%,
            var(--sk-accent, #3b82f6) 40%,
            rgba(var(--sk-accent-rgb, 59, 130, 246), 0.35) 60%,
            transparent 100%
        );
        background-size: 200% 100%;
        animation: sk-progress-7714425f 1.4s ease-in-out infinite;
}
@keyframes sk-progress-7714425f {
0%   { background-position: 100% 0;
}
100% { background-position: -100% 0;
}
}

    /* ── Header ──────────────────────────────────────────────── */
.cv-data-table__skeleton__header[data-v-7714425f] {
        display: flex;
        align-items: center;
        gap: 12px;
        padding: 0 16px;
        height: 48px;
        border-bottom: 1px solid var(--cv-ui-border-color, #e2e8f0);
        background: var(--cv-ui-bg-secondary, #f8fafc);
        flex-shrink: 0;
}
.cv-data-table__skeleton__cell--header[data-v-7714425f] {
        height: 11px;
        border-radius: 4px;
        flex-shrink: 0;
        opacity: 0.6;
}

    /* ── Rows ────────────────────────────────────────────────── */
.cv-data-table__skeleton__row[data-v-7714425f] {
        display: flex;
        align-items: center;
        gap: 12px;
        padding: 0 16px;
        height: 48px;
        border-bottom: 1px solid var(--cv-ui-border-color, #e2e8f0);
        flex-shrink: 0;
        animation: sk-row-in-7714425f 0.25s ease both;
        animation-delay: calc(var(--sk-row, 0) * 35ms);
}
@keyframes sk-row-in-7714425f {
from { opacity: 0; transform: translateY(3px);
}
to   { opacity: 1; transform: none;
}
}

    /* ── Cells — shimmer ─────────────────────────────────────── */
.cv-data-table__skeleton__cell[data-v-7714425f] {
        height: 10px;
        border-radius: 4px;
        flex-shrink: 0;
        background: linear-gradient(
            90deg,
            var(--cv-ui-bg-tertiary, #f1f5f9) 25%,
            var(--cv-ui-bg-hover,    #f9fafb) 50%,
            var(--cv-ui-bg-tertiary, #f1f5f9) 75%
        );
        background-size: 600px 100%;
        animation: sk-shimmer-7714425f 1.6s ease-in-out infinite;
        animation-delay: calc((var(--sk-row, 0) * 50ms) + (var(--sk-cell, 0) * 20ms));
}
@keyframes sk-shimmer-7714425f {
0%   { background-position: -600px 0;
}
100% { background-position:  600px 0;
}
}

    /* ── Exit transition ─────────────────────────────────────── */
.cv-skeleton-fade-leave-active[data-v-7714425f] {
        transition: opacity 0.2s ease;
        pointer-events: none;
}
.cv-skeleton-fade-leave-to[data-v-7714425f] {
        opacity: 0;
}

.cv-data-table__grid-inner[data-v-78e897b3] .ag-root-wrapper {
        width: 100%;
        height: 100%;
        flex: 1;
        min-height: 0;
        min-width: 0;
        display: flex;
        flex-direction: column;
        overflow: visible; /* Allow scroll to work properly */
}

    /* When using autoHeight, AG Grid should adapt to content */
.cv-data-table__grid-inner[style*='height: auto'][data-v-78e897b3] .ag-root-wrapper {
        height: auto;
        flex: 0 1 auto;
}
.cv-data-table__grid-inner[data-v-78e897b3] .ag-root {
        width: 100%;
        height: 100%;
        flex: 1;
        min-height: 0;
        min-width: 0;
        display: flex;
        flex-direction: column;
        overflow: visible; /* Allow scroll to work properly */
}

    /* When using autoHeight, AG Grid root should adapt to content */
.cv-data-table__grid-inner[style*='height: auto'][data-v-78e897b3] .ag-root {
        height: auto;
        flex: 0 1 auto;
}
.cv-data-table__grid-inner[data-v-78e897b3] .ag-body-viewport {
        flex: 1;
        min-height: 0;
        min-width: 0;
        overflow-x: hidden; /* Hide horizontal scrollbar - use fake scrollbar instead */
        overflow-y: auto; /* Keep vertical scrollbar */
}

    /* When using autoHeight, body viewport should adapt */
.cv-data-table__grid-inner[style*='height: auto'][data-v-78e897b3] .ag-body-viewport {
        flex: 0 1 auto;
        overflow: visible;
}

    /* Theme transition animations - subtle and performant */
.cv-data-table__grid-wrapper[data-v-78e897b3] .ag-root-wrapper {
        transition:
            background-color 0.3s ease,
            color 0.3s ease,
            border-color 0.3s ease;
}

    /* Apply border radius to AG Grid root wrapper to match grid-inner */
.cv-data-table__grid-inner[data-v-78e897b3] .ag-root-wrapper {
        border-radius: inherit !important;
        /* Don't set overflow here - let children handle scrolling */
}

    /* Apply border radius to AG Grid root element */
.cv-data-table__grid-inner[data-v-78e897b3] .ag-root {
        border-radius: inherit !important;
        /* Don't set overflow here - let children handle scrolling */
}

    /* Apply border radius to header */
.cv-data-table__grid-inner[data-v-78e897b3] .ag-header {
        border-top-left-radius: inherit;
        border-top-right-radius: inherit;
        overflow: hidden;
}

    /* Apply border radius to body viewport */
.cv-data-table__grid-inner[data-v-78e897b3] .ag-body-viewport {
        border-bottom-left-radius: inherit;
        border-bottom-right-radius: inherit;
}

    /* Apply border radius to body horizontal scroll container */
.cv-data-table__grid-inner[data-v-78e897b3] .ag-body-horizontal-scroll {
        border-bottom-left-radius: inherit;
        border-bottom-right-radius: inherit;
}

    /* Ensure all AG Grid containers respect border radius */
.cv-data-table__grid-inner[data-v-78e897b3] .ag-body,
    .cv-data-table__grid-inner[data-v-78e897b3] .ag-center-cols-container,
    .cv-data-table__grid-inner[data-v-78e897b3] .ag-center-cols-clipper {
        border-radius: inherit;
}

    /* ── Wrapper ─────────────────────────────────────────────── */
.cv-data-table__quick-filter[data-v-dcff88a4] {
        position: relative;
        display: flex;
        align-items: center;
        width: 100%;
        max-width: 360px;
        background: var(--cv-ui-bg-primary, #fff);
        border: 1.5px solid var(--cv-ui-border-color, #e2e8f0);
        border-radius: var(--cv-ui-radius-lg, 8px);
        color: var(--cv-ui-text-primary, #1e293b);
        transition:
            border-color 0.15s ease,
            box-shadow 0.15s ease,
            background 0.15s ease;
}
.cv-data-table__quick-filter[data-v-dcff88a4]:focus-within {
        border-color: var(--qf-accent, var(--cv-ui-border-color-focus, #3b82f6));
        box-shadow: 0 0 0 3px rgba(var(--qf-accent-rgb, 59, 130, 246), 0.12);
}

    /* ── Variant: compact ────────────────────────────────────── */
.cv-data-table__quick-filter--compact[data-v-dcff88a4] {
        max-width: 200px;
        border-color: transparent;
        background: var(--cv-ui-bg-tertiary, #f1f5f9);
}
.cv-data-table__quick-filter--compact[data-v-dcff88a4]:focus-within {
        max-width: 320px;
        border-color: var(--qf-accent, var(--cv-ui-border-color-focus, #3b82f6));
        background: var(--cv-ui-bg-primary, #fff);
        box-shadow: 0 0 0 3px rgba(var(--qf-accent-rgb, 59, 130, 246), 0.12);
        transition:
            max-width 0.2s ease,
            border-color 0.15s ease,
            box-shadow 0.15s ease,
            background 0.15s ease;
}

    /* ── Variant: pill ───────────────────────────────────────── */
.cv-data-table__quick-filter--pill[data-v-dcff88a4] {
        border-radius: 9999px;
        background: var(--cv-ui-bg-tertiary, #f1f5f9);
        border-color: transparent;
}
.cv-data-table__quick-filter--pill[data-v-dcff88a4]:focus-within {
        border-color: var(--qf-accent, var(--cv-ui-border-color-focus, #3b82f6));
        background: var(--cv-ui-bg-primary, #fff);
}
.cv-data-table__quick-filter--pill .cv-data-table__quick-filter__clear[data-v-dcff88a4] {
        border-radius: 9999px;
        margin-right: 4px;
}

    /* ── Search icon ─────────────────────────────────────────── */
.cv-data-table__quick-filter__icon[data-v-dcff88a4] {
        flex-shrink: 0;
        display: flex;
        align-items: center;
        justify-content: center;
        width: 36px;
        color: var(--cv-ui-text-tertiary, #94a3b8);
        pointer-events: none;
        transition: color 0.15s ease;
}
.cv-data-table__quick-filter:focus-within .cv-data-table__quick-filter__icon[data-v-dcff88a4] {
        color: var(--qf-accent, var(--cv-ui-color-primary, #3b82f6));
}
.cv-data-table__quick-filter__icon svg[data-v-dcff88a4] {
        width: 15px;
        height: 15px;
}

    /* ── Input ───────────────────────────────────────────────── */
.cv-data-table__quick-filter__input[data-v-dcff88a4] {
        flex: 1;
        min-width: 0;
        padding: 0.45rem 0;
        border: none;
        outline: none;
        background: transparent;
        font-family: var(--cv-ui-font-family, system-ui, sans-serif);
        font-size: 0.875rem;
        color: var(--cv-ui-text-primary, #1e293b);
}
.cv-data-table__quick-filter__input[data-v-dcff88a4]::placeholder {
        color: var(--cv-ui-text-tertiary, #94a3b8);
}

    /* ── Result count ────────────────────────────────────────── */
.cv-data-table__quick-filter__count[data-v-dcff88a4] {
        flex-shrink: 0;
        font-size: 0.7rem;
        font-weight: 600;
        font-variant-numeric: tabular-nums;
        padding: 2px 7px;
        border-radius: 9999px;
        background: rgba(var(--qf-accent-rgb, 59, 130, 246), 0.1);
        color: var(--qf-accent, var(--cv-ui-color-primary, #3b82f6));
        white-space: nowrap;
        line-height: 1.6;
}

    /* ── Clear button ────────────────────────────────────────── */
.cv-data-table__quick-filter__clear[data-v-dcff88a4] {
        flex-shrink: 0;
        width: 26px;
        height: 26px;
        margin: 3px;
        display: flex;
        align-items: center;
        justify-content: center;
        padding: 0;
        border: none;
        border-radius: var(--cv-ui-radius-sm, 4px);
        background: transparent;
        color: var(--cv-ui-text-tertiary, #94a3b8);
        cursor: pointer;
        transition:
            color 0.15s ease,
            background 0.15s ease;
}
.cv-data-table__quick-filter__clear[data-v-dcff88a4]:hover {
        color: var(--cv-ui-color-danger, #ef4444);
        background: var(--cv-ui-color-danger-light, #fee2e2);
}
.cv-data-table__quick-filter__clear svg[data-v-dcff88a4] {
        width: 11px;
        height: 11px;
}

    /* ── Transitions ─────────────────────────────────────────── */
.quick-filter-enter-active[data-v-dcff88a4],
    .quick-filter-leave-active[data-v-dcff88a4] {
        transition: opacity 0.2s ease, transform 0.2s ease;
}
.quick-filter-enter-from[data-v-dcff88a4],
    .quick-filter-leave-to[data-v-dcff88a4] {
        opacity: 0;
        transform: translateY(-6px);
}
.qf-badge-enter-active[data-v-dcff88a4],
    .qf-badge-leave-active[data-v-dcff88a4] {
        transition: opacity 0.15s ease, transform 0.15s ease;
}
.qf-badge-enter-from[data-v-dcff88a4],
    .qf-badge-leave-to[data-v-dcff88a4] {
        opacity: 0;
        transform: scale(0.75);
}
.qf-clear-enter-active[data-v-dcff88a4],
    .qf-clear-leave-active[data-v-dcff88a4] {
        transition: opacity 0.1s ease, transform 0.1s ease;
}
.qf-clear-enter-from[data-v-dcff88a4],
    .qf-clear-leave-to[data-v-dcff88a4] {
        opacity: 0;
        transform: scale(0.6);
}

.cv-data-table__quick-filters[data-v-1121d0e1] {
        display: flex;
        justify-content: center;
        align-items: center;
        padding: 0.75rem 1rem;
}
.cv-data-table__quick-filters__container[data-v-1121d0e1] {
        display: flex;
        flex-wrap: wrap;
        gap: 0.5rem;
        justify-content: center;
        align-items: center;
        width: 100%;
        max-width: 100%;
}
.cv-data-table__quick-filters__button[data-v-1121d0e1] {
        padding: 0.5rem 1rem;
        font-size: 0.875rem;
        font-weight: 500;
        border: 1px solid rgba(226, 232, 240, 1);
        border-radius: 6px;
        background: #ffffff;
        color: #475569;
        cursor: pointer;
        transition: all 0.2s ease;
        white-space: nowrap;
}
.cv-data-table__quick-filters__button[data-v-1121d0e1]:hover {
        border-color: rgba(148, 163, 184, 1);
        background: #f8fafc;
}
.cv-data-table__quick-filters__button--active[data-v-1121d0e1] {
        background: rgba(var(--accent-color-rgb, 239, 68, 68), 0.1);
        border-color: var(--accent-color, #ef4444);
        color: var(--accent-color, #dc2626);
        font-weight: 600;
}
.cv-data-table__quick-filters__button--active[data-v-1121d0e1]:hover {
        background: rgba(var(--accent-color-rgb, 239, 68, 68), 0.15);
}

    /* Tablet & mobile: horizontal scroll (slider) instead of wrap */
@media (max-width: 1024px) {
.cv-data-table__quick-filters[data-v-1121d0e1] {
            overflow: hidden;
            justify-content: flex-start;
            padding-left: 1rem;
            padding-right: 1rem;
}
.cv-data-table__quick-filters__container[data-v-1121d0e1] {
            flex-wrap: nowrap;
            overflow-x: auto;
            -webkit-overflow-scrolling: touch;
            justify-content: flex-start;
            width: 100%;
            min-width: 0;
            padding-bottom: 2px;
            scrollbar-width: thin;
}
.cv-data-table__quick-filters__button[data-v-1121d0e1] {
            flex-shrink: 0;
}
}

    /* Transition */
.quick-filters-enter-active[data-v-1121d0e1],
    .quick-filters-leave-active[data-v-1121d0e1] {
        transition: all 0.3s ease;
}
.quick-filters-enter-from[data-v-1121d0e1] {
        opacity: 0;
        transform: translateY(-10px);
}
.quick-filters-leave-to[data-v-1121d0e1] {
        opacity: 0;
        transform: translateY(-10px);
}

.cv-form-renderer-field[data-v-a1775096] {
        width: 100%;
        position: relative;
        display: flex;
        align-items: flex-start;
        gap: 0.5rem;
        padding: 0.5rem;
        margin: 0.25rem 0;
        border-radius: 4px;
        transition:
            background-color 0.2s,
            border-color 0.2s;
}
.cv-form-renderer-field--dragging[data-v-a1775096] {
        opacity: 0.5;
        background-color: #f0f0f0;
}
.cv-form-renderer-field--drag-over[data-v-a1775096] {
        background-color: #e6f7ff;
        border: 2px dashed #18a058;
        padding: calc(0.5rem - 2px);
}
.cv-form-renderer-field-drag-handle[data-v-a1775096] {
        cursor: move;
        color: #999;
        padding: 0.5rem 0.25rem;
        margin-top: 0.5rem;
        display: flex;
        align-items: center;
        flex-shrink: 0;
        user-select: none;
        -webkit-user-drag: element;
}
.cv-form-renderer-field-drag-handle[data-v-a1775096]:hover {
        color: #666;
        background-color: #f5f5f5;
        border-radius: 4px;
}
.cv-form-renderer-field-drag-handle[data-v-a1775096]:active {
        cursor: grabbing;
        color: #333;
}
.cv-form-renderer-field-content[data-v-a1775096] {
        flex: 1;
        min-width: 0;
}
.cv-form-renderer-field__label[data-v-a1775096] {
        margin-bottom: var(--cv-ui-spacing-xs, 4px);
}
.cv-form-renderer-field__label label[data-v-a1775096] {
        font-size: var(--cv-ui-font-size-sm, 14px);
        font-weight: var(--cv-ui-font-weight-medium, 500);
        color: var(--cv-ui-text-primary);
}
.cv-form-renderer-field__required[data-v-a1775096] {
        color: var(--cv-ui-color-danger);
}
.cv-form-renderer-field__options[data-v-a1775096] {
        display: flex;
        flex-direction: column;
        gap: var(--cv-ui-spacing-xs, 4px);
}
.cv-form-renderer-field__native-input[data-v-a1775096] {
        width: 100%;
        padding: var(--cv-ui-spacing-xs, 4px) var(--cv-ui-spacing-sm, 8px);
        font-size: var(--cv-ui-font-size-sm, 14px);
        font-family: var(--cv-ui-font-family);
        border: 1px solid var(--cv-ui-border-color);
        border-radius: var(--cv-ui-radius-sm, 4px);
        background-color: var(--cv-ui-bg-primary);
        color: var(--cv-ui-text-primary);
}
.cv-form-renderer-field__native-input[data-v-a1775096]:focus {
        outline: none;
        border-color: var(--cv-ui-color-primary);
}
.cv-form-renderer-field__file[data-v-a1775096] {
        display: flex;
        align-items: center;
        gap: var(--cv-ui-spacing-sm);
}
.cv-form-renderer-field__file-input[data-v-a1775096] {
        position: absolute;
        width: 0;
        height: 0;
        opacity: 0;
        pointer-events: none;
}

.cv-form-renderer[data-v-3ad12d04] {
        width: 100%;
}
.cv-form-renderer-section[data-v-3ad12d04] {
        margin-bottom: 1.5rem;
}
.cv-form-renderer-section-header[data-v-3ad12d04] {
        display: flex;
        justify-content: space-between;
        align-items: center;
        cursor: pointer;
        padding: 0.75rem 0;
        border-bottom: 1px solid #e5e7eb;
        user-select: none;
}
.cv-form-renderer-section-title[data-v-3ad12d04] {
        font-size: 1.125rem;
        font-weight: 600;
        margin: 0;
        padding: 0.75rem 0;
        border-bottom: 1px solid #e5e7eb;
}
.cv-form-renderer-section-chevron[data-v-3ad12d04] {
        transition: transform 0.2s;
        font-size: 0.75rem;
        color: #6b7280;
}
.cv-form-renderer-section-chevron.open[data-v-3ad12d04] {
        transform: rotate(180deg);
}
.cv-form-renderer-section-content[data-v-3ad12d04] {
        padding-top: 1rem;
}
.cv-form-renderer-grid[data-v-3ad12d04] {
        display: grid;
        gap: 1rem;
}
.cv-form-renderer-loading[data-v-3ad12d04] {
        position: relative;
        min-height: 200px;
}
.cv-form-renderer-loading-spinner[data-v-3ad12d04] {
        position: absolute;
        top: 50%;
        left: 50%;
        transform: translate(-50%, -50%);
        padding: 1rem;
        background: rgba(255, 255, 255, 0.9);
        border-radius: 4px;
        box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
}
.cv-form-renderer-error[data-v-3ad12d04] {
        padding: 0.75rem 1rem;
        margin-bottom: 1rem;
        background-color: #fee;
        border: 1px solid #fcc;
        border-radius: 4px;
        color: #c33;
}

.cv-form-builder-canvas[data-v-070131bd] {
        display: flex;
        flex-direction: column;
        height: 100%;
        background: var(--cv-fb-bg-panel);
        flex: 1;
}
.cv-form-builder-canvas--preview[data-v-070131bd] {
        background: transparent;
}
.cv-form-builder-canvas__header[data-v-070131bd] {
        display: flex;
        justify-content: space-between;
        align-items: center;
        padding: 1rem 1.25rem;
        background: var(--cv-fb-bg-input);
        border-bottom: 1px solid var(--cv-fb-border);
}
.cv-form-builder-canvas__title[data-v-070131bd] {
        font-size: 0.8125rem;
        font-weight: 700;
        text-transform: uppercase;
        letter-spacing: 0.06em;
        margin: 0;
        color: var(--cv-fb-text-primary);
}
.cv-form-builder-canvas__actions[data-v-070131bd] {
        display: flex;
        gap: 0.5rem;
}
.cv-form-builder-canvas__btn[data-v-070131bd] {
        padding: 0.5rem 1rem;
        border: 1px solid var(--cv-fb-border);
        border-radius: 0.5rem;
        font-size: 0.8125rem;
        font-weight: 600;
        cursor: pointer;
        background: var(--cv-fb-bg-panel);
        color: var(--cv-fb-text-secondary);
        transition: all 0.2s;
        box-shadow: var(--cv-fb-shadow-sm);
}
.cv-form-builder-canvas__btn[data-v-070131bd]:hover {
        background: var(--cv-fb-bg-hover);
        border-color: var(--cv-fb-border-hover);
        box-shadow: var(--cv-fb-shadow-md);
}
.cv-form-builder-canvas__btn--primary[data-v-070131bd] {
        background: var(--cv-fb-accent);
        color: #fff;
        border-color: var(--cv-fb-accent-hover);
        box-shadow: 0 2px 4px var(--cv-fb-accent-ring);
}
.cv-form-builder-canvas__btn--primary[data-v-070131bd]:hover {
        background: var(--cv-fb-accent-hover);
        box-shadow: 0 4px 8px var(--cv-fb-accent-ring);
}
.cv-form-builder-canvas__content[data-v-070131bd] {
        flex: 1;
        overflow-y: auto;
        padding: 1.25rem;
}
.cv-form-builder-canvas__content--edit[data-v-070131bd] {
        background: var(--cv-fb-bg-base);
        min-height: 100%;
}
.cv-form-builder-canvas__content--preview[data-v-070131bd] {
        background: transparent;
        min-height: 0;
}
.cv-form-builder-canvas__empty[data-v-070131bd] {
        display: flex;
        flex-direction: column;
        align-items: center;
        justify-content: center;
        min-height: 400px;
        text-align: center;
        padding: 2rem;
        background: var(--cv-fb-bg-panel);
        border: 2px dashed var(--cv-fb-border);
        border-radius: 1rem;
        color: var(--cv-fb-text-secondary);
}
.cv-form-builder-canvas__empty-icon[data-v-070131bd] {
        font-size: 3.5rem;
        margin-bottom: 1.25rem;
        opacity: 0.8;
}
.cv-form-builder-canvas__empty-text[data-v-070131bd] {
        font-size: 1.125rem;
        font-weight: 600;
        margin-bottom: 0.5rem;
        color: var(--cv-fb-text-primary);
}
.cv-form-builder-canvas__empty-hint[data-v-070131bd] {
        font-size: 0.875rem;
        color: var(--cv-fb-text-tertiary);
        font-weight: 500;
}
.cv-form-builder-canvas__section[data-v-070131bd] {
        margin-bottom: 1.5rem;
        background: var(--cv-fb-bg-panel);
        border: 1px solid var(--cv-fb-border);
        border-radius: 0.75rem;
        overflow: hidden;
        box-shadow: var(--cv-fb-shadow-sm);
}
.cv-form-builder-canvas__section-header[data-v-070131bd] {
        display: flex;
        align-items: center;
        padding: 0.875rem 1.25rem;
        background: var(--cv-fb-bg-input);
        border-bottom: 1px solid var(--cv-fb-border);
}
.cv-form-builder-canvas__section-title-input[data-v-070131bd] {
        flex: 1;
        padding: 0.5rem 0.75rem;
        border: 1px solid var(--cv-fb-border);
        border-radius: 0.5rem;
        font-size: 0.875rem;
        font-weight: 600;
        color: var(--cv-fb-text-primary);
        background: var(--cv-fb-bg-panel);
        transition:
            border-color 0.15s,
            box-shadow 0.15s;
}
.cv-form-builder-canvas__section-title-input[data-v-070131bd]:focus {
        outline: none;
        border-color: var(--cv-fb-accent);
        box-shadow: 0 0 0 2px var(--cv-fb-accent-ring);
}
.cv-form-builder-canvas__section-remove[data-v-070131bd] {
        margin-left: 0.5rem;
        padding: 0.3rem 0.6rem;
        background: var(--cv-fb-danger);
        color: #fff;
        border: none;
        border-radius: 0.375rem;
        cursor: pointer;
        font-size: 1.125rem;
        line-height: 1;
        font-weight: 600;
        transition: box-shadow 0.2s;
}
.cv-form-builder-canvas__section-remove[data-v-070131bd]:hover {
        background: var(--cv-fb-danger-hover);
        box-shadow: var(--cv-fb-shadow-md);
}
.cv-form-builder-canvas__section-content[data-v-070131bd] {
        padding: 1.25rem;
}
.cv-form-builder-canvas__field[data-v-070131bd] {
        display: flex;
        align-items: center;
        gap: 0.75rem;
        padding: 0.75rem 1rem;
        margin-bottom: 0.5rem;
        background: var(--cv-fb-bg-panel);
        border: 1px solid var(--cv-fb-border);
        border-radius: 0.5rem;
        cursor: pointer;
        transition: all 0.2s;
        box-shadow: var(--cv-fb-shadow-sm);
}
.cv-form-builder-canvas__field[data-v-070131bd]:hover {
        background: var(--cv-fb-bg-hover);
        border-color: var(--cv-fb-border-hover);
        box-shadow: var(--cv-fb-shadow-md);
}
.cv-form-builder-canvas__field--selected[data-v-070131bd] {
        background: var(--cv-fb-accent-light);
        border-color: var(--cv-fb-accent);
        box-shadow: 0 0 0 2px var(--cv-fb-accent-ring);
}
.cv-form-builder-canvas__field--dragging[data-v-070131bd] {
        opacity: 0.6;
        transform: scale(0.98);
}
.cv-form-builder-canvas__drop-indicator[data-v-070131bd] {
        height: 6px;
        min-height: 6px;
        margin: 4px 0;
        background: var(--cv-fb-accent);
        border-radius: 3px;
        flex-shrink: 0;
        box-shadow: 0 0 0 2px var(--cv-fb-accent-ring);
}
.cv-form-builder-canvas__field-handle[data-v-070131bd] {
        color: var(--cv-fb-text-tertiary);
        cursor: grab;
        font-size: 1rem;
        user-select: none;
}
.cv-form-builder-canvas__field-handle[data-v-070131bd]:active {
        cursor: grabbing;
}
.cv-form-builder-canvas__field-content[data-v-070131bd] {
        flex: 1;
        min-width: 0;
}
.cv-form-builder-canvas__field-label[data-v-070131bd] {
        font-size: 0.875rem;
        font-weight: 600;
        color: var(--cv-fb-text-primary);
        margin-bottom: 0.2rem;
}
.cv-form-builder-canvas__field-preview[data-v-070131bd] {
        font-size: 0.75rem;
        color: var(--cv-fb-text-secondary);
        font-style: italic;
}
.cv-form-builder-canvas__field-remove[data-v-070131bd] {
        padding: 0.25rem 0.5rem;
        background: var(--cv-fb-danger);
        color: #fff;
        border: none;
        border-radius: 0.375rem;
        cursor: pointer;
        font-size: 1rem;
        line-height: 1;
        font-weight: 600;
        transition: box-shadow 0.2s;
}
.cv-form-builder-canvas__field-remove[data-v-070131bd]:hover {
        background: var(--cv-fb-danger-hover);
        box-shadow: var(--cv-fb-shadow-md);
}
.cv-form-builder-canvas__section-dropzone[data-v-070131bd] {
        padding: 2rem;
        text-align: center;
        border: 2px dashed var(--cv-fb-border-hover);
        border-radius: 0.75rem;
        color: var(--cv-fb-text-secondary);
        font-size: 0.875rem;
        font-weight: 500;
        transition: all 0.2s;
        background: var(--cv-fb-bg-input);
}
.cv-form-builder-canvas__section-dropzone--active[data-v-070131bd] {
        border-color: var(--cv-fb-accent);
        background: var(--cv-fb-accent-light);
        color: var(--cv-fb-accent-hover);
        box-shadow: 0 0 0 2px var(--cv-fb-accent-ring);
}

.cv-form-builder-palette[data-v-cb03c79c] {
        display: flex;
        flex-direction: column;
        height: 100%;
        background: var(--cv-fb-bg-panel);
        border-right: 1px solid var(--cv-fb-border);
        box-shadow: 2px 0 8px var(--cv-fb-shadow-sm);
}
.cv-form-builder-palette__header[data-v-cb03c79c] {
        display: flex;
        justify-content: space-between;
        align-items: center;
        padding: 1rem 1.25rem;
        background: var(--cv-fb-bg-input);
        border-bottom: 1px solid var(--cv-fb-border);
}
.cv-form-builder-palette__title[data-v-cb03c79c] {
        font-size: 0.8125rem;
        font-weight: 700;
        text-transform: uppercase;
        letter-spacing: 0.06em;
        margin: 0;
        color: var(--cv-fb-text-primary);
}
.cv-form-builder-palette__count[data-v-cb03c79c] {
        font-size: 0.6875rem;
        font-weight: 600;
        color: var(--cv-fb-text-tertiary);
        background: var(--cv-fb-bg-active);
        padding: 0.2rem 0.5rem;
        border-radius: 9999px;
}
.cv-form-builder-palette__search[data-v-cb03c79c] {
        padding: 0.75rem 1rem;
        border-bottom: 1px solid var(--cv-fb-border);
}
.cv-form-builder-palette__search-input[data-v-cb03c79c] {
        width: 100%;
        padding: 0.5rem 0.75rem;
        border: 1px solid var(--cv-fb-border);
        border-radius: 0.5rem;
        font-size: 0.8125rem;
        background: var(--cv-fb-bg-input);
        color: var(--cv-fb-text-primary);
        transition:
            border-color 0.15s,
            box-shadow 0.15s;
}
.cv-form-builder-palette__search-input[data-v-cb03c79c]::placeholder {
        color: var(--cv-fb-text-tertiary);
}
.cv-form-builder-palette__search-input[data-v-cb03c79c]:focus {
        outline: none;
        border-color: var(--cv-fb-accent);
        background: var(--cv-fb-bg-panel);
        box-shadow: 0 0 0 2px var(--cv-fb-accent-ring);
}
.cv-form-builder-palette__list[data-v-cb03c79c] {
        flex: 1;
        overflow-y: auto;
        padding: 0.75rem;
}
.cv-form-builder-palette__item[data-v-cb03c79c] {
        display: flex;
        align-items: center;
        gap: 0.75rem;
        padding: 0.75rem 1rem;
        margin-bottom: 0.5rem;
        background: var(--cv-fb-bg-panel);
        border: 1px solid var(--cv-fb-border);
        border-radius: 0.5rem;
        cursor: grab;
        transition: all 0.2s;
        box-shadow: var(--cv-fb-shadow-sm);
}
.cv-form-builder-palette__item[data-v-cb03c79c]:hover {
        background: var(--cv-fb-bg-hover);
        border-color: var(--cv-fb-border-hover);
        box-shadow: var(--cv-fb-shadow-md);
}
.cv-form-builder-palette__item[data-v-cb03c79c]:active {
        cursor: grabbing;
}
.cv-form-builder-palette__item--dragging[data-v-cb03c79c] {
        opacity: 0.6;
        transform: scale(0.98);
        box-shadow: var(--cv-fb-shadow-lg);
}
.cv-form-builder-palette__item--used[data-v-cb03c79c] {
        opacity: 0.85;
        background: var(--cv-fb-accent-light);
        border-color: var(--cv-fb-accent);
}
.cv-form-builder-palette__item-icon[data-v-cb03c79c] {
        font-size: 1.25rem;
        flex-shrink: 0;
        width: 2rem;
        height: 2rem;
        display: flex;
        align-items: center;
        justify-content: center;
        background: var(--cv-fb-bg-active);
        border-radius: 0.375rem;
}
.cv-form-builder-palette__item-content[data-v-cb03c79c] {
        flex: 1;
        min-width: 0;
}
.cv-form-builder-palette__item-label[data-v-cb03c79c] {
        font-size: 0.875rem;
        font-weight: 600;
        color: var(--cv-fb-text-primary);
        margin-bottom: 0.2rem;
}
.cv-form-builder-palette__item-name[data-v-cb03c79c] {
        font-size: 0.6875rem;
        color: var(--cv-fb-text-secondary);
        font-family: ui-monospace, monospace;
        margin-bottom: 0.125rem;
}
.cv-form-builder-palette__item-type[data-v-cb03c79c] {
        font-size: 0.625rem;
        font-weight: 600;
        color: var(--cv-fb-text-tertiary);
        text-transform: uppercase;
        letter-spacing: 0.05em;
}
.cv-form-builder-palette__item-badge[data-v-cb03c79c] {
        flex-shrink: 0;
        width: 1.5rem;
        height: 1.5rem;
        display: flex;
        align-items: center;
        justify-content: center;
        background: var(--cv-fb-success);
        color: #fff;
        border-radius: 50%;
        font-size: 0.6875rem;
        font-weight: 700;
        box-shadow: var(--cv-fb-shadow-sm);
}
.cv-form-builder-palette__empty[data-v-cb03c79c] {
        padding: 2rem 1rem;
        text-align: center;
        color: var(--cv-fb-text-tertiary);
        font-size: 0.8125rem;
        font-weight: 500;
}

.cv-form-builder-properties[data-v-1066c78a] {
        display: flex;
        flex-direction: column;
        height: 100%;
        background: var(--cv-fb-bg-panel);
        border-left: 1px solid var(--cv-fb-border);
        box-shadow: -2px 0 8px var(--cv-fb-shadow-sm);
}
.cv-form-builder-properties__header[data-v-1066c78a] {
        display: flex;
        justify-content: space-between;
        align-items: center;
        padding: 1rem 1.25rem;
        background: var(--cv-fb-bg-input);
        border-bottom: 1px solid var(--cv-fb-border);
}
.cv-form-builder-properties__title[data-v-1066c78a] {
        font-size: 0.8125rem;
        font-weight: 700;
        text-transform: uppercase;
        letter-spacing: 0.06em;
        margin: 0;
        color: var(--cv-fb-text-primary);
}
.cv-form-builder-properties__close[data-v-1066c78a] {
        padding: 0.25rem 0.5rem;
        background: var(--cv-fb-bg-active);
        border: none;
        border-radius: 0.375rem;
        cursor: pointer;
        font-size: 1.25rem;
        line-height: 1;
        color: var(--cv-fb-text-secondary);
        transition: all 0.2s;
}
.cv-form-builder-properties__close[data-v-1066c78a]:hover {
        background: var(--cv-fb-border-hover);
        color: var(--cv-fb-text-primary);
}
.cv-form-builder-properties__empty[data-v-1066c78a] {
        display: flex;
        flex-direction: column;
        align-items: center;
        justify-content: center;
        flex: 1;
        padding: 2rem;
        text-align: center;
        color: var(--cv-fb-text-tertiary);
        background: var(--cv-fb-bg-input);
        margin: 1rem;
        border-radius: 0.75rem;
        border: 2px dashed var(--cv-fb-border);
}
.cv-form-builder-properties__empty-icon[data-v-1066c78a] {
        font-size: 3rem;
        margin-bottom: 1rem;
        opacity: 0.7;
}
.cv-form-builder-properties__empty-text[data-v-1066c78a] {
        font-size: 0.875rem;
        font-weight: 600;
        color: var(--cv-fb-text-secondary);
}
.cv-form-builder-properties__content[data-v-1066c78a] {
        flex: 1;
        overflow-y: auto;
        padding: 1.25rem;
}
.cv-form-builder-properties__section[data-v-1066c78a] {
        margin-bottom: 1.5rem;
}
.cv-form-builder-properties__section-title[data-v-1066c78a] {
        font-size: 0.6875rem;
        font-weight: 700;
        text-transform: uppercase;
        color: var(--cv-fb-text-secondary);
        margin: 0 0 0.75rem 0;
        letter-spacing: 0.08em;
}
.cv-form-builder-properties__field[data-v-1066c78a] {
        margin-bottom: 0.75rem;
}
.cv-form-builder-properties__field-group[data-v-1066c78a] {
        display: grid;
        grid-template-columns: 1fr 1fr;
        gap: 0.75rem;
}
.cv-form-builder-properties__label[data-v-1066c78a] {
        display: block;
        font-size: 0.75rem;
        font-weight: 600;
        color: var(--cv-fb-text-secondary);
        margin-bottom: 0.25rem;
}
.cv-form-builder-properties__input[data-v-1066c78a],
    .cv-form-builder-properties__textarea[data-v-1066c78a],
    .cv-form-builder-properties__select[data-v-1066c78a] {
        width: 100%;
        padding: 0.5rem 0.75rem;
        border: 1px solid var(--cv-fb-border);
        border-radius: 0.5rem;
        font-size: 0.8125rem;
        font-family: inherit;
        background: var(--cv-fb-bg-input);
        color: var(--cv-fb-text-primary);
        transition:
            border-color 0.15s,
            box-shadow 0.15s;
}
.cv-form-builder-properties__input[data-v-1066c78a]:focus,
    .cv-form-builder-properties__textarea[data-v-1066c78a]:focus,
    .cv-form-builder-properties__select[data-v-1066c78a]:focus {
        outline: none;
        border-color: var(--cv-fb-accent);
        background: var(--cv-fb-bg-panel);
        box-shadow: 0 0 0 2px var(--cv-fb-accent-ring);
}
.cv-form-builder-properties__input--disabled[data-v-1066c78a] {
        background: var(--cv-fb-bg-active);
        color: var(--cv-fb-text-secondary);
        cursor: not-allowed;
}
.cv-form-builder-properties__textarea[data-v-1066c78a] {
        resize: vertical;
        min-height: 4rem;
}
.cv-form-builder-properties__checkbox-label[data-v-1066c78a] {
        display: flex;
        align-items: center;
        gap: 0.5rem;
        font-size: 0.8125rem;
        font-weight: 500;
        color: var(--cv-fb-text-secondary);
        cursor: pointer;
}
.cv-form-builder-properties__checkbox[data-v-1066c78a] {
        width: 1rem;
        height: 1rem;
        cursor: pointer;
        accent-color: var(--cv-fb-accent);
}

    /* --- Theme variables (light = default) --- */
.cv-form-builder[data-v-37af015e] {
        --cv-fb-bg-base: linear-gradient(160deg, #f8fafc 0%, #f1f5f9 100%);
        --cv-fb-bg-toolbar: #fff;
        --cv-fb-bg-panel: #fff;
        --cv-fb-bg-input: #f8fafc;
        --cv-fb-bg-hover: #f8fafc;
        --cv-fb-bg-active: #f1f5f9;
        --cv-fb-bg-empty: #f8fafc;
        --cv-fb-text-primary: #0f172a;
        --cv-fb-text-secondary: #64748b;
        --cv-fb-text-tertiary: #94a3b8;
        --cv-fb-border: #e2e8f0;
        --cv-fb-border-hover: #cbd5e1;
        --cv-fb-accent: #3b82f6;
        --cv-fb-accent-hover: #2563eb;
        --cv-fb-accent-light: #eff6ff;
        --cv-fb-accent-ring: rgba(59, 130, 246, 0.2);
        --cv-fb-danger: #ef4444;
        --cv-fb-danger-hover: #dc2626;
        --cv-fb-success: #10b981;
        --cv-fb-shadow-sm: 0 1px 2px rgba(0, 0, 0, 0.04);
        --cv-fb-shadow-md: 0 2px 6px rgba(0, 0, 0, 0.06);
        --cv-fb-shadow-lg: 0 25px 50px -12px rgba(0, 0, 0, 0.25);
        --cv-fb-overlay: rgba(15, 23, 42, 0.4);
}
.cv-form-builder--dark[data-v-37af015e] {
        --cv-fb-bg-base: linear-gradient(160deg, #0f172a 0%, #1e293b 100%);
        --cv-fb-bg-toolbar: #1e293b;
        --cv-fb-bg-panel: #1e293b;
        --cv-fb-bg-input: #334155;
        --cv-fb-bg-hover: #334155;
        --cv-fb-bg-active: #475569;
        --cv-fb-bg-empty: #0f172a;
        --cv-fb-text-primary: #f8fafc;
        --cv-fb-text-secondary: #94a3b8;
        --cv-fb-text-tertiary: #64748b;
        --cv-fb-border: #334155;
        --cv-fb-border-hover: #475569;
        --cv-fb-accent: #60a5fa;
        --cv-fb-accent-hover: #3b82f6;
        --cv-fb-accent-light: #1e3a5f;
        --cv-fb-accent-ring: rgba(96, 165, 250, 0.25);
        --cv-fb-danger: #f87171;
        --cv-fb-danger-hover: #ef4444;
        --cv-fb-success: #34d399;
        --cv-fb-shadow-sm: 0 1px 2px rgba(0, 0, 0, 0.2);
        --cv-fb-shadow-md: 0 2px 6px rgba(0, 0, 0, 0.3);
        --cv-fb-shadow-lg: 0 25px 50px -12px rgba(0, 0, 0, 0.5);
        --cv-fb-overlay: rgba(0, 0, 0, 0.6);
}
.cv-form-builder[data-v-37af015e] {
        display: flex;
        flex-direction: column;
        height: 100%;
        background: var(--cv-fb-bg-base);
}
.cv-form-builder__toolbar[data-v-37af015e] {
        display: flex;
        justify-content: space-between;
        align-items: center;
        padding: 1rem 1.5rem;
        background: var(--cv-fb-bg-toolbar);
        border-bottom: 1px solid var(--cv-fb-border);
        box-shadow: var(--cv-fb-shadow-sm);
}
.cv-form-builder__toolbar-left[data-v-37af015e] {
        display: flex;
        flex-direction: column;
        gap: 0.25rem;
}
.cv-form-builder__title[data-v-37af015e] {
        font-size: 1.35rem;
        font-weight: 700;
        margin: 0;
        color: var(--cv-fb-text-primary);
        letter-spacing: -0.02em;
}
.cv-form-builder__subtitle[data-v-37af015e] {
        font-size: 0.8125rem;
        color: var(--cv-fb-text-secondary);
}
.cv-form-builder__toolbar-right[data-v-37af015e] {
        display: flex;
        align-items: center;
        gap: 0.5rem;
}
.cv-form-builder__theme-toggle[data-v-37af015e] {
        padding: 0.4rem 0.6rem;
        border: 1px solid var(--cv-fb-border);
        border-radius: 0.5rem;
        background: var(--cv-fb-bg-input);
        color: var(--cv-fb-text-secondary);
        font-size: 1rem;
        cursor: pointer;
        transition: all 0.2s;
        margin-right: 0.25rem;
}
.cv-form-builder__theme-toggle[data-v-37af015e]:hover {
        background: var(--cv-fb-bg-hover);
        color: var(--cv-fb-text-primary);
        border-color: var(--cv-fb-border-hover);
}
.cv-form-builder__layout-select[data-v-37af015e] {
        display: flex;
        align-items: center;
        gap: 0.5rem;
        margin-right: 0.75rem;
        padding-right: 0.75rem;
        border-right: 1px solid var(--cv-fb-border);
}
.cv-form-builder__layout-label[data-v-37af015e] {
        font-size: 0.6875rem;
        font-weight: 600;
        text-transform: uppercase;
        letter-spacing: 0.06em;
        color: var(--cv-fb-text-secondary);
        white-space: nowrap;
}
.cv-form-builder__layout-select-input[data-v-37af015e],
    .cv-form-builder__layout-columns-input[data-v-37af015e] {
        padding: 0.4rem 0.6rem;
        border: 1px solid var(--cv-fb-border);
        border-radius: 0.5rem;
        font-size: 0.8125rem;
        font-weight: 500;
        background: var(--cv-fb-bg-input);
        color: var(--cv-fb-text-primary);
        transition:
            border-color 0.15s,
            box-shadow 0.15s;
}
.cv-form-builder__layout-select-input[data-v-37af015e]:focus,
    .cv-form-builder__layout-columns-input[data-v-37af015e]:focus {
        outline: none;
        border-color: var(--cv-fb-accent);
        box-shadow: 0 0 0 2px var(--cv-fb-accent-ring);
}
.cv-form-builder__layout-columns-input[data-v-37af015e] {
        width: 3rem;
        text-align: center;
}
.cv-form-builder__dto-loading[data-v-37af015e],
    .cv-form-builder__dto-error[data-v-37af015e] {
        padding: 1rem 1.5rem;
        text-align: center;
        font-size: 0.875rem;
        font-weight: 500;
}
.cv-form-builder__dto-loading[data-v-37af015e] {
        background: var(--cv-fb-accent-light);
        color: var(--cv-fb-accent-hover);
}
.cv-form-builder__dto-error[data-v-37af015e] {
        background: #fef2f2;
        color: var(--cv-fb-danger);
}
.cv-form-builder--dark .cv-form-builder__dto-error[data-v-37af015e] {
        background: #450a0a;
}
.cv-form-builder__btn[data-v-37af015e] {
        padding: 0.5rem 1rem;
        border: 1px solid var(--cv-fb-border);
        border-radius: 0.5rem;
        font-size: 0.8125rem;
        font-weight: 600;
        cursor: pointer;
        background: var(--cv-fb-bg-toolbar);
        color: var(--cv-fb-text-secondary);
        transition: all 0.2s;
        box-shadow: var(--cv-fb-shadow-sm);
}
.cv-form-builder__btn[data-v-37af015e]:hover {
        background: var(--cv-fb-bg-hover);
        border-color: var(--cv-fb-border-hover);
        box-shadow: var(--cv-fb-shadow-md);
}
.cv-form-builder__btn--toggle[data-v-37af015e] {
        background: var(--cv-fb-bg-active);
        color: var(--cv-fb-text-secondary);
}
.cv-form-builder__btn--toggle.cv-form-builder__btn--active[data-v-37af015e] {
        background: var(--cv-fb-accent);
        color: #fff;
        border-color: var(--cv-fb-accent-hover);
        box-shadow: 0 2px 4px var(--cv-fb-accent-ring);
}
.cv-form-builder__btn--primary[data-v-37af015e] {
        background: var(--cv-fb-accent);
        color: #fff;
        border-color: var(--cv-fb-accent-hover);
        box-shadow: 0 2px 4px var(--cv-fb-accent-ring);
}
.cv-form-builder__btn--primary[data-v-37af015e]:hover {
        background: var(--cv-fb-accent-hover);
        box-shadow: 0 4px 8px var(--cv-fb-accent-ring);
}
.cv-form-builder__btn--secondary[data-v-37af015e] {
        background: var(--cv-fb-bg-toolbar);
        color: var(--cv-fb-text-secondary);
}
.cv-form-builder__btn--danger[data-v-37af015e] {
        background: var(--cv-fb-danger);
        color: #fff;
        border-color: var(--cv-fb-danger-hover);
        box-shadow: 0 2px 4px rgba(220, 38, 38, 0.25);
}
.cv-form-builder__btn--danger[data-v-37af015e]:hover {
        background: var(--cv-fb-danger-hover);
        box-shadow: 0 4px 8px rgba(220, 38, 38, 0.3);
}
.cv-form-builder__content[data-v-37af015e] {
        display: flex;
        flex: 1;
        overflow: hidden;
}
.cv-form-builder__palette[data-v-37af015e] {
        width: 280px;
        flex-shrink: 0;
        overflow: hidden;
}
.cv-form-builder__canvas[data-v-37af015e] {
        flex: 1;
        overflow: hidden;
        min-width: 0;
}
.cv-form-builder__properties[data-v-37af015e] {
        width: 320px;
        flex-shrink: 0;
        overflow: hidden;
}
.cv-form-builder__import-dialog[data-v-37af015e] {
        position: fixed;
        inset: 0;
        background: var(--cv-fb-overlay);
        backdrop-filter: blur(4px);
        display: flex;
        align-items: center;
        justify-content: center;
        z-index: 1000;
}
.cv-form-builder__import-dialog-content[data-v-37af015e] {
        background: var(--cv-fb-bg-toolbar);
        border-radius: 1rem;
        padding: 1.5rem;
        width: 90%;
        max-width: 600px;
        max-height: 80vh;
        overflow-y: auto;
        box-shadow: var(--cv-fb-shadow-lg);
        border: 1px solid var(--cv-fb-border);
}
.cv-form-builder__import-dialog-title[data-v-37af015e] {
        font-size: 1.125rem;
        font-weight: 700;
        margin: 0 0 1rem 0;
        color: var(--cv-fb-text-primary);
        letter-spacing: -0.02em;
}
.cv-form-builder__import-dialog-textarea[data-v-37af015e] {
        width: 100%;
        padding: 0.75rem 1rem;
        border: 1px solid var(--cv-fb-border);
        border-radius: 0.5rem;
        font-family: ui-monospace, monospace;
        font-size: 0.8125rem;
        margin-bottom: 1rem;
        resize: vertical;
        min-height: 200px;
        background: var(--cv-fb-bg-input);
        color: var(--cv-fb-text-primary);
        transition:
            border-color 0.15s,
            box-shadow 0.15s;
}
.cv-form-builder__import-dialog-textarea[data-v-37af015e]:focus {
        outline: none;
        border-color: var(--cv-fb-accent);
        background: var(--cv-fb-bg-panel);
        box-shadow: 0 0 0 2px var(--cv-fb-accent-ring);
}
.cv-form-builder__import-dialog-actions[data-v-37af015e] {
        display: flex;
        gap: 0.5rem;
        justify-content: flex-end;
}

.ui-story[data-v-02143bf8] { padding: 24px; font-family: var(--cv-ui-font-family);
}
.ui-story__block[data-v-02143bf8] { margin-bottom: 24px;
}
.ui-story__subtitle[data-v-02143bf8] { font-size: 0.875rem; font-weight: 500; margin-bottom: 10px; color: var(--cv-ui-text-secondary);
}
.ui-story__row[data-v-02143bf8] { display: flex; flex-wrap: wrap; gap: 16px; align-items: center;
}
.ui-story__item[data-v-02143bf8] { display: flex; flex-direction: column; align-items: center; gap: 6px;
}
.ui-story__label[data-v-02143bf8] { font-size: 0.75rem; font-weight: 500; color: var(--cv-ui-text-secondary); text-transform: uppercase; letter-spacing: 0.04em;
}

.ui-story[data-v-a032712e] { padding: 24px; font-family: var(--cv-ui-font-family);
}
.ui-story__block[data-v-a032712e] { margin-bottom: 24px;
}
.ui-story__subtitle[data-v-a032712e] { font-size: 0.875rem; font-weight: 500; margin-bottom: 10px; color: var(--cv-ui-text-secondary);
}
.ui-story__row[data-v-a032712e] { display: flex; flex-wrap: wrap; gap: 24px; align-items: center;
}
.ui-story__grid[data-v-a032712e] { display: flex; flex-direction: column; gap: 16px;
}
.ui-story__item[data-v-a032712e] { display: flex; flex-direction: column; gap: 8px;
}
.ui-story__label[data-v-a032712e] { font-size: 0.75rem; font-weight: 500; color: var(--cv-ui-text-secondary); text-transform: uppercase; letter-spacing: 0.04em;
}

.ui-story[data-v-cf6393d0] { padding: 24px; font-family: var(--cv-ui-font-family);
}
.ui-story__grid[data-v-cf6393d0] { display: flex; flex-direction: column; gap: 20px;
}
.ui-story__item[data-v-cf6393d0] { display: flex; flex-direction: column; gap: 6px;
}
.ui-story__label[data-v-cf6393d0] { font-size: 0.75rem; font-weight: 500; color: var(--cv-ui-text-secondary); text-transform: uppercase; letter-spacing: 0.04em;
}

.ui-story[data-v-d110efe3] {
        padding: 24px;
        font-family: var(--cv-ui-font-family);
}
.ui-story__block[data-v-d110efe3] {
        margin-bottom: 24px;
}
.ui-story__subtitle[data-v-d110efe3] {
        font-size: 0.875rem;
        font-weight: 500;
        margin-bottom: 10px;
        color: var(--cv-ui-text-secondary);
}
.ui-story__row[data-v-d110efe3] {
        display: flex;
        flex-wrap: wrap;
        gap: 10px;
}

.ui-story[data-v-e4d9896c] { padding: 24px; font-family: var(--cv-ui-font-family);
}
.ui-story__row[data-v-e4d9896c] { display: flex; flex-wrap: wrap; gap: 16px; align-items: flex-start;
}
.ui-story__item[data-v-e4d9896c] { display: flex; flex-direction: column; gap: 8px;
}
.ui-story__label[data-v-e4d9896c] { font-size: 0.75rem; font-weight: 500; color: var(--cv-ui-text-secondary); text-transform: uppercase; letter-spacing: 0.04em;
}

.ui-story[data-v-4d09fd6e] {
        padding: 24px;
        font-family: var(--cv-ui-font-family);
}
.ui-story__grid[data-v-4d09fd6e] {
        display: flex;
        flex-direction: column;
        gap: 16px;
}

.ui-story[data-v-5726043a] { padding: 24px; font-family: var(--cv-ui-font-family);
}
.ui-story__desc[data-v-5726043a] { margin: 0 0 12px; font-size: 0.875rem; color: var(--cv-ui-text-secondary);
}

.ui-story[data-v-bd1dad34] {
    padding: 48px;
    min-height: 200px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 16px;
    font-family: var(--cv-ui-font-family);
}
.ui-story__row[data-v-bd1dad34] {
    flex-direction: row;
    flex-wrap: wrap;
}
.ui-story__value[data-v-bd1dad34] {
    margin: 0;
    font-size: var(--cv-ui-font-size-sm);
    color: var(--cv-ui-text-secondary);
}

.ui-story[data-v-c8a21da8] {
        padding: 24px;
        font-family: var(--cv-ui-font-family);
}
.ui-story__grid[data-v-c8a21da8] {
        display: flex;
        flex-direction: column;
        gap: 16px;
}
.ui-story__item[data-v-c8a21da8] {
        display: flex;
        flex-direction: column;
        gap: 6px;
        max-width: 320px;
}
.ui-story__label[data-v-c8a21da8] {
        font-size: 0.75rem;
        font-weight: 500;
        color: var(--cv-ui-text-secondary);
        text-transform: uppercase;
        letter-spacing: 0.04em;
}
.ui-story__hint[data-v-c8a21da8] {
        font-size: 0.75rem;
        color: var(--cv-ui-text-tertiary);
        margin: 4px 0 0;
}

.ui-story[data-v-76c7f1df] {
        padding: 24px;
        font-family: var(--cv-ui-font-family);
}
.ui-story__block[data-v-76c7f1df] {
        margin-bottom: 24px;
}
.ui-story__subtitle[data-v-76c7f1df] {
        font-size: 0.875rem;
        font-weight: 500;
        margin-bottom: 10px;
        color: var(--cv-ui-text-secondary);
}

    /* Vertical demo row */
.row-demo[data-v-76c7f1df] {
        display: flex;
        align-items: center;
        gap: 10px;
        height: 32px;
}
.row-demo--toolbar[data-v-76c7f1df] {
        height: 36px;
        gap: 4px;
}
.demo-text[data-v-76c7f1df] {
        font-size: 0.875rem;
        color: var(--cv-ui-text-primary);
        white-space: nowrap;
}
.demo-text--muted[data-v-76c7f1df] {
        color: var(--cv-ui-text-secondary);
}
.toolbar-btn[data-v-76c7f1df] {
        display: inline-flex;
        align-items: center;
        padding: 4px 10px;
        border: 1px solid var(--cv-ui-border-color);
        border-radius: var(--cv-ui-radius-sm);
        background: transparent;
        font-family: var(--cv-ui-font-family);
        font-size: 0.8125rem;
        color: var(--cv-ui-text-primary);
        cursor: pointer;
}
.toolbar-btn[data-v-76c7f1df]:hover {
        background-color: var(--cv-ui-bg-hover);
}
.toolbar-btn--danger[data-v-76c7f1df] {
        color: var(--cv-ui-color-danger, #ef4444);
}

    /* Icon label */
.icon-label[data-v-76c7f1df] {
        display: inline-flex;
        align-items: center;
        gap: 5px;
}

.ui-story[data-v-74887b11] { padding: 24px; font-family: var(--cv-ui-font-family); min-height: 200px;
}

.ui-story[data-v-0f6fc959] { padding: 24px; font-family: var(--cv-ui-font-family);
}
.ui-story__grid[data-v-0f6fc959] { display: flex; flex-direction: column; gap: 16px;
}
.ui-story__item[data-v-0f6fc959] { display: flex; flex-direction: column; gap: 4px;
}
.ui-story__label[data-v-0f6fc959] { font-size: 0.75rem; font-weight: 500; color: var(--cv-ui-text-secondary); text-transform: uppercase; letter-spacing: 0.04em;
}

.ui-story[data-v-ab85aa09] {
        padding: 24px;
        max-width: 560px;
        font-family: var(--cv-ui-font-family);
}
.ui-story__debug[data-v-ab85aa09] {
        margin-top: 16px;
        padding: 12px;
        background: var(--cv-ui-bg-tertiary);
        border-radius: var(--cv-ui-radius-md);
        font-size: var(--cv-ui-font-size-xs);
        color: var(--cv-ui-text-secondary);
        white-space: pre-wrap;
}
.ui-story__help[data-v-ab85aa09] {
        margin-top: 12px;
        font-size: var(--cv-ui-font-size-xs);
        color: var(--cv-ui-text-tertiary);
}
.ui-story__exceed[data-v-ab85aa09] {
        margin-top: 12px;
        font-size: var(--cv-ui-font-size-sm);
        color: var(--cv-ui-color-danger);
        font-weight: 500;
}

.ui-story[data-v-b069b0c3] {
        padding: 24px;
        font-family: var(--cv-ui-font-family);
}
.ui-story__grid[data-v-b069b0c3] {
        display: flex;
        flex-direction: column;
        gap: 16px;
}
.ui-story__item[data-v-b069b0c3] {
        display: flex;
        flex-direction: column;
        gap: 6px;
        max-width: 320px;
}
.ui-story__label[data-v-b069b0c3] {
        font-size: 0.75rem;
        font-weight: 500;
        color: var(--cv-ui-text-secondary);
        text-transform: uppercase;
        letter-spacing: 0.04em;
}

.ui-story[data-v-3091960f] { padding: 24px; font-family: var(--cv-ui-font-family);
}
.ui-story__row[data-v-3091960f] { display: flex; flex-wrap: wrap; gap: 6px; align-items: center;
}
.ui-story__grid[data-v-3091960f] { display: flex; flex-direction: column; gap: 12px;
}
.ui-story__item[data-v-3091960f] { display: flex; flex-direction: column; gap: 8px;
}
.ui-story__label[data-v-3091960f] { font-size: 0.75rem; font-weight: 500; color: var(--cv-ui-text-secondary); text-transform: uppercase; letter-spacing: 0.04em;
}
.ui-story__prose[data-v-3091960f] { display: flex; flex-direction: column; gap: 10px; max-width: 480px;
}
.ui-story__prose p[data-v-3091960f] { margin: 0; font-size: 0.875rem; color: var(--cv-ui-text-primary); line-height: 1.8;
}
.shortcut-row[data-v-3091960f] { display: flex; align-items: center; justify-content: space-between; max-width: 340px; padding: 6px 0; border-bottom: 1px solid var(--cv-ui-border-color);
}
.shortcut-row[data-v-3091960f]:last-child { border-bottom: none;
}
.shortcut-desc[data-v-3091960f] { font-size: 0.875rem; color: var(--cv-ui-text-secondary);
}
.shortcut-keys[data-v-3091960f] { display: flex; align-items: center; gap: 4px;
}
.shortcut-sep[data-v-3091960f] { font-size: 0.75rem; color: var(--cv-ui-text-tertiary);
}

.ui-story[data-v-1954d0fe] {
        padding: 24px;
        font-family: var(--cv-ui-font-family);
}
.ui-story__hint[data-v-1954d0fe] {
        font-size: 0.875rem;
        color: var(--cv-ui-text-secondary);
}
.ui-story__hint--block[data-v-1954d0fe] {
        margin-bottom: 16px;
}

.ui-story[data-v-acdd8fb7] { padding: 24px; font-family: var(--cv-ui-font-family);
}
.ui-story__block[data-v-acdd8fb7] { margin-bottom: 24px;
}
.ui-story__grid[data-v-acdd8fb7] { display: flex; flex-direction: column; gap: 20px;
}
.ui-story__item[data-v-acdd8fb7] { display: flex; flex-direction: column; gap: 8px;
}
.ui-story__desc[data-v-acdd8fb7] { margin: 0 0 12px; font-size: 0.875rem; color: var(--cv-ui-text-secondary);
}
.ui-story__hint[data-v-acdd8fb7] { margin: 8px 0 0; font-size: 0.75rem; color: var(--cv-ui-text-tertiary);
}
.ui-story__success[data-v-acdd8fb7] { margin: 8px 0 0; font-size: 0.875rem; color: var(--cv-ui-color-success); font-weight: 500;
}
.ui-story__label[data-v-acdd8fb7] { font-size: 0.75rem; font-weight: 500; color: var(--cv-ui-text-secondary); text-transform: uppercase; letter-spacing: 0.04em;
}

.ui-story[data-v-34aac496] { padding: 24px; font-family: var(--cv-ui-font-family);
}
.ui-story__info[data-v-34aac496] { margin: 0 0 12px; font-size: 0.875rem; color: var(--cv-ui-text-secondary);
}
.ui-story__grid[data-v-34aac496] { display: flex; flex-direction: column; gap: 20px;
}
.ui-story__item[data-v-34aac496] { display: flex; flex-direction: column; gap: 8px;
}
.ui-story__label[data-v-34aac496] { font-size: 0.75rem; font-weight: 500; color: var(--cv-ui-text-secondary); text-transform: uppercase; letter-spacing: 0.04em;
}

.cv-password-story__username[data-v-1b462ddb] {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}

.ui-story[data-v-eea566f2] {
    padding: 48px;
    min-height: 200px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    font-family: var(--cv-ui-font-family);
}
.ui-story__result[data-v-eea566f2] {
    margin-top: 12px;
    font-size: var(--cv-ui-font-size-sm);
    color: var(--cv-ui-text-secondary);
}

.ui-story[data-v-c5c34942] {
    padding: 48px;
    min-height: 200px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-family: var(--cv-ui-font-family);
}
.ui-story--placements[data-v-c5c34942] {
    padding: 48px;
    min-height: 220px;
    align-items: center;
    justify-content: center;
}
.ui-story__p[data-v-c5c34942] {
    margin: 0;
    font-size: var(--cv-ui-font-size-sm);
    color: var(--cv-ui-text-secondary);
}
.ui-story__hover-trigger[data-v-c5c34942] {
    padding: var(--cv-ui-spacing-sm) var(--cv-ui-spacing-md);
    background: var(--cv-ui-bg-tertiary);
    border-radius: var(--cv-ui-radius-md);
    cursor: pointer;
}
.ui-story--placements[data-v-c5c34942] {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    align-items: center;
}

.ui-story[data-v-d65e321c] {
    padding: 48px;
    min-height: 120px;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    justify-content: center;
    gap: 16px;
    font-family: var(--cv-ui-font-family);
}
.ui-story__row[data-v-d65e321c] {
    width: 100%;
    max-width: 280px;
}
.ui-story--circle[data-v-d65e321c] {
    flex-direction: row;
    flex-wrap: wrap;
    gap: 24px;
}

.ui-story[data-v-9380d57a] {
        padding: 24px;
        font-family: var(--cv-ui-font-family);
}
.ui-story__block[data-v-9380d57a] {
        margin-bottom: 16px;
}
.ui-story__label[data-v-9380d57a] {
        display: block;
        font-size: 0.75rem;
        font-weight: 500;
        color: var(--cv-ui-text-secondary);
        text-transform: uppercase;
        letter-spacing: 0.04em;
        margin-bottom: 6px;
}
.ui-story__hint[data-v-9380d57a] {
        font-size: 0.875rem;
        color: var(--cv-ui-text-secondary);
        margin-top: 8px;
}

.ui-story[data-v-b1d465f0] { padding: 24px; font-family: var(--cv-ui-font-family);
}
.ui-story__block[data-v-b1d465f0] { margin-bottom: 24px;
}
.ui-story__grid[data-v-b1d465f0] { display: flex; flex-direction: column; gap: 16px;
}
.ui-story__item[data-v-b1d465f0] { display: flex; flex-direction: column; gap: 8px;
}
.ui-story__desc[data-v-b1d465f0] { margin: 0 0 12px; font-size: 0.875rem; color: var(--cv-ui-text-secondary);
}
.ui-story__hint[data-v-b1d465f0] { margin: 8px 0 0; font-size: 0.75rem; color: var(--cv-ui-text-tertiary);
}
.ui-story__label[data-v-b1d465f0] { font-size: 0.75rem; font-weight: 500; color: var(--cv-ui-text-secondary); text-transform: uppercase; letter-spacing: 0.04em;
}

.ui-story[data-v-c53de5e7] {
        padding: 24px;
        font-family: var(--cv-ui-font-family);
}
.ui-story__grid[data-v-c53de5e7] {
        display: flex;
        flex-direction: column;
        gap: 16px;
}
.ui-story__item[data-v-c53de5e7] {
        display: flex;
        flex-direction: column;
        gap: 6px;
        max-width: 320px;
}
.ui-story__label[data-v-c53de5e7] {
        font-size: 0.75rem;
        font-weight: 500;
        color: var(--cv-ui-text-secondary);
        text-transform: uppercase;
        letter-spacing: 0.04em;
}

.ui-story[data-v-fd6aa4c9] {
        padding: 24px;
        font-family: var(--cv-ui-font-family);
}
.ui-story__hint[data-v-fd6aa4c9] {
        font-size: 0.875rem;
        color: var(--cv-ui-text-secondary);
        margin-bottom: 16px;
        line-height: 1.5;
}

    /* Trigger button */
.story-btn[data-v-fd6aa4c9] {
        display: inline-flex;
        align-items: center;
        gap: 6px;
        padding: 8px 16px;
        border: 1px solid var(--cv-ui-border-color);
        border-radius: var(--cv-ui-radius-md);
        background-color: var(--cv-ui-color-primary);
        color: #fff;
        font-family: var(--cv-ui-font-family);
        font-size: 0.875rem;
        font-weight: 500;
        cursor: pointer;
        transition: opacity 0.15s ease;
}
.story-btn[data-v-fd6aa4c9]:hover {
        opacity: 0.9;
}

    /* Sidebar inner content */
.sidebar-body[data-v-fd6aa4c9] {
        display: flex;
        flex-direction: column;
        gap: 4px;
}
.sidebar-section-title[data-v-fd6aa4c9] {
        font-size: 0.6875rem;
        font-weight: 600;
        text-transform: uppercase;
        letter-spacing: 0.06em;
        color: var(--cv-ui-text-tertiary);
        padding: 12px 0 6px;
        margin: 0;
}
.sidebar-nav[data-v-fd6aa4c9] {
        list-style: none;
        margin: 0;
        padding: 0;
        display: flex;
        flex-direction: column;
        gap: 2px;
}
.sidebar-nav__item[data-v-fd6aa4c9] {
        display: flex;
        align-items: center;
        gap: 10px;
        padding: 8px 10px;
        border-radius: var(--cv-ui-radius-md);
        font-size: 0.875rem;
        font-weight: 500;
        color: var(--cv-ui-text-secondary);
        cursor: pointer;
        transition: background-color 0.15s ease, color 0.15s ease;
}
.sidebar-nav__item[data-v-fd6aa4c9]:hover {
        background-color: var(--cv-ui-bg-hover);
        color: var(--cv-ui-text-primary);
}
.sidebar-nav__item--active[data-v-fd6aa4c9] {
        background-color: color-mix(in srgb, var(--cv-ui-color-primary) 10%, transparent);
        color: var(--cv-ui-color-primary);
}

    /* Badges */
.sidebar-badge[data-v-fd6aa4c9] {
        margin-left: auto;
        display: inline-flex;
        align-items: center;
        justify-content: center;
        min-width: 20px;
        height: 20px;
        padding: 0 6px;
        border-radius: 10px;
        background-color: var(--cv-ui-color-primary);
        color: #fff;
        font-size: 0.6875rem;
        font-weight: 600;
}
.sidebar-badge--secondary[data-v-fd6aa4c9] {
        background-color: var(--cv-ui-bg-hover);
        color: var(--cv-ui-text-secondary);
}

    /* Custom header */
.sidebar-custom-header[data-v-fd6aa4c9] {
        display: flex;
        align-items: center;
        justify-content: space-between;
        width: 100%;
}
.sidebar-logo[data-v-fd6aa4c9] {
        display: flex;
        align-items: center;
        gap: 8px;
        color: var(--cv-ui-color-primary);
        font-weight: 700;
        font-size: 1rem;
}
.sidebar-logo__name[data-v-fd6aa4c9] {
        color: var(--cv-ui-text-primary);
}
.sidebar-close-btn[data-v-fd6aa4c9] {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        width: 32px;
        height: 32px;
        border: none;
        border-radius: var(--cv-ui-radius-md);
        background: transparent;
        color: var(--cv-ui-text-secondary);
        cursor: pointer;
}
.sidebar-close-btn[data-v-fd6aa4c9]:hover {
        background-color: var(--cv-ui-bg-hover);
        color: var(--cv-ui-text-primary);
}

    /* User profile footer */
.sidebar-user-profile[data-v-fd6aa4c9] {
        display: flex;
        align-items: center;
        gap: 10px;
        width: 100%;
}
.sidebar-avatar[data-v-fd6aa4c9] {
        flex-shrink: 0;
        width: 36px;
        height: 36px;
        border-radius: 50%;
        background-color: var(--cv-ui-color-primary);
        color: #fff;
        display: flex;
        align-items: center;
        justify-content: center;
        font-size: 0.75rem;
        font-weight: 700;
}
.sidebar-user-info[data-v-fd6aa4c9] {
        flex: 1;
        min-width: 0;
        display: flex;
        flex-direction: column;
        gap: 1px;
}
.sidebar-user-name[data-v-fd6aa4c9] {
        font-size: 0.875rem;
        font-weight: 600;
        color: var(--cv-ui-text-primary);
        overflow: hidden;
        text-overflow: ellipsis;
        white-space: nowrap;
}
.sidebar-user-role[data-v-fd6aa4c9] {
        font-size: 0.75rem;
        color: var(--cv-ui-text-secondary);
}
.sidebar-logout-btn[data-v-fd6aa4c9] {
        flex-shrink: 0;
        display: inline-flex;
        align-items: center;
        justify-content: center;
        width: 32px;
        height: 32px;
        border: none;
        border-radius: var(--cv-ui-radius-md);
        background: transparent;
        color: var(--cv-ui-text-tertiary);
        cursor: pointer;
}
.sidebar-logout-btn[data-v-fd6aa4c9]:hover {
        background-color: var(--cv-ui-bg-hover);
        color: var(--cv-ui-text-primary);
}

.ui-story[data-v-5f8d925a] { padding: 24px; font-family: var(--cv-ui-font-family); max-width: 480px;
}
.ui-story__block[data-v-5f8d925a] { margin-bottom: 24px;
}
.ui-story__subtitle[data-v-5f8d925a] { font-size: 0.875rem; font-weight: 500; margin-bottom: 10px; color: var(--cv-ui-text-secondary);
}
.ui-story__row[data-v-5f8d925a] { display: flex; flex-wrap: wrap; gap: 12px; align-items: center;
}
.skeleton-card[data-v-5f8d925a] { border: 1px solid var(--cv-ui-border-color); border-radius: var(--cv-ui-radius-lg); overflow: hidden; width: 320px;
}
.skeleton-card__body[data-v-5f8d925a] { padding: 16px; display: flex; flex-direction: column; gap: 12px;
}
.skeleton-card__header[data-v-5f8d925a] { display: flex; gap: 12px; align-items: center;
}
.skeleton-card__meta[data-v-5f8d925a] { display: flex; flex-direction: column; gap: 6px; flex: 1;
}
.skeleton-card__footer[data-v-5f8d925a] { display: flex; gap: 8px;
}
.skeleton-list[data-v-5f8d925a] { display: flex; flex-direction: column; gap: 0;
}
.skeleton-list__item[data-v-5f8d925a] { display: flex; align-items: center; gap: 12px; padding: 12px 0; border-bottom: 1px solid var(--cv-ui-border-color);
}
.skeleton-list__item[data-v-5f8d925a]:last-child { border-bottom: none;
}
.skeleton-list__content[data-v-5f8d925a] { display: flex; flex-direction: column; gap: 6px; flex: 1;
}

.ui-story[data-v-a1d0d7a5] { padding: 24px; font-family: var(--cv-ui-font-family); max-width: 480px;
}
.ui-story__block[data-v-a1d0d7a5] { margin-bottom: 28px;
}
.ui-story__value[data-v-a1d0d7a5] { font-size: 0.875rem; color: var(--cv-ui-text-secondary); margin-bottom: 12px;
}
.ui-story__label[data-v-a1d0d7a5] { font-size: 0.75rem; font-weight: 500; color: var(--cv-ui-text-secondary); text-transform: uppercase; letter-spacing: 0.04em; display: block; margin-bottom: 12px;
}

.ui-story[data-v-ae27f0a4] {
    padding: 24px;
    font-family: var(--cv-ui-font-family);
}
.ui-story__row[data-v-ae27f0a4] {
    display: flex;
    flex-wrap: wrap;
    gap: 16px;
    align-items: center;
}
.ui-story__row--align[data-v-ae27f0a4] {
    align-items: flex-end;
}
.ui-story__cell[data-v-ae27f0a4] {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 8px;
}
.ui-story__label[data-v-ae27f0a4] {
    font-size: var(--cv-ui-font-size-xs);
    color: var(--cv-ui-text-secondary);
}
.ui-story__subtitle[data-v-ae27f0a4] {
    font-size: var(--cv-ui-font-size-sm);
    color: var(--cv-ui-text-secondary);
    margin: 0 0 8px 0;
}

.ui-story[data-v-689cd85c] { padding: 24px; font-family: var(--cv-ui-font-family);
}
.ui-story__row[data-v-689cd85c] { display: flex; flex-wrap: wrap; gap: 16px;
}

.ui-story[data-v-4ad6d1b4] {
        padding: 24px;
        font-family: var(--cv-ui-font-family);
}
.ui-story__row[data-v-4ad6d1b4] {
        display: flex;
        gap: 16px;
}
.ui-story__row--wrap[data-v-4ad6d1b4] {
        flex-wrap: wrap;
        align-items: center;
        gap: 20px;
}
.ui-story__item-row[data-v-4ad6d1b4] {
        display: flex;
        align-items: center;
        gap: 10px;
}
.ui-story__hint[data-v-4ad6d1b4] {
        font-size: 0.875rem;
        color: var(--cv-ui-text-secondary);
}
.ui-story__hint--block[data-v-4ad6d1b4] {
        margin-bottom: 12px;
}
.ui-story__hint code[data-v-4ad6d1b4] {
        font-size: 0.8em;
        padding: 2px 6px;
        background: var(--cv-ui-bg-tertiary);
        border-radius: var(--cv-ui-radius-sm);
}
.ui-story__grid[data-v-4ad6d1b4] {
        display: flex;
        flex-direction: column;
        gap: 16px;
}

.ui-story[data-v-0d4c6f35] {
    padding: 48px;
    font-family: var(--cv-ui-font-family);
}
.ui-story--narrow[data-v-0d4c6f35] {
    max-width: 320px;
}
.ui-story__segmented-list[data-v-0d4c6f35] {
    max-width: 280px;
}
.ui-tab-card-content[data-v-0d4c6f35] {
    display: inline-flex;
    min-width: 0;
    align-items: center;
    gap: var(--cv-ui-spacing-xs);
}
.ui-tab-card-label[data-v-0d4c6f35] {
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.ui-story[data-v-4aa5ec5f] {
        padding: 24px;
        font-family: var(--cv-ui-font-family);
}
.ui-story__row[data-v-4aa5ec5f] {
        display: flex;
        gap: 16px;
}
.ui-story__row--wrap[data-v-4aa5ec5f] {
        flex-wrap: wrap;
        align-items: center;
        gap: 12px;
}
.ui-story__grid[data-v-4aa5ec5f] {
        display: flex;
        flex-direction: column;
        gap: 16px;
}
.ui-story__item[data-v-4aa5ec5f] {
        display: flex;
        flex-direction: column;
        gap: 6px;
}
.ui-story__label[data-v-4aa5ec5f] {
        font-size: 0.75rem;
        font-weight: 500;
        color: var(--cv-ui-text-secondary);
        text-transform: uppercase;
        letter-spacing: 0.04em;
}

.ui-story[data-v-9ab28bbf] { padding: 24px; font-family: var(--cv-ui-font-family); max-width: 560px;
}

.ui-story[data-v-74463d61] {
        padding: 24px;
        font-family: var(--cv-ui-font-family);
}
.ui-story__hint[data-v-74463d61] {
        font-size: 0.875rem;
        color: var(--cv-ui-text-secondary);
}
.ui-story__hint--block[data-v-74463d61] {
        margin-bottom: 16px;
}
.ui-story__row[data-v-74463d61] {
        display: flex;
        gap: 8px;
}
.ui-story__row--wrap[data-v-74463d61] {
        flex-wrap: wrap;
}
.ui-story__stack[data-v-74463d61] {
        display: flex;
        flex-direction: column;
        gap: var(--cv-ui-spacing-sm);
        max-width: 360px;
}

.ui-story[data-v-28c38aa8] {
    display: grid;
    gap: 16px;
    padding: 48px;
    font-family: var(--cv-ui-font-family);
}
.ui-story[data-v-28c38aa8] .cv-tree {
    max-width: 420px;
}
.ui-story__label[data-v-28c38aa8] {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    min-width: 0;
}
.ui-story__icon[data-v-28c38aa8] {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 16px;
    height: 16px;
    border-radius: 4px;
    background: var(--cv-ui-color-warning-light);
    color: var(--cv-ui-color-warning-dark);
    font-size: 10px;
    font-weight: var(--cv-ui-font-weight-bold);
}
.ui-story__icon--file[data-v-28c38aa8] {
    background: var(--cv-ui-color-primary-light);
    color: var(--cv-ui-color-primary-dark);
}
.ui-story__kind[data-v-28c38aa8] {
    flex-shrink: 0;
    padding: 2px 6px;
    border-radius: var(--cv-ui-radius-full);
    background: var(--cv-ui-color-primary-light);
    color: var(--cv-ui-color-primary-dark);
    font-size: 11px;
    font-weight: var(--cv-ui-font-weight-semibold);
}
.ui-story__text[data-v-28c38aa8] {
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.ui-story__text--selected[data-v-28c38aa8] {
    font-weight: var(--cv-ui-font-weight-semibold);
}
.ui-story__meta[data-v-28c38aa8] {
    margin: 0;
    color: var(--cv-ui-text-secondary);
    font-size: var(--cv-ui-font-size-sm);
}

.theme-story[data-v-11526c2b] {
        padding: 24px;
        max-width: 480px;
        margin: 0 auto;
        font-family: var(--cv-ui-font-family);
        background: var(--cv-ui-bg-primary);
        color: var(--cv-ui-text-primary);
}
.theme-story__note[data-v-11526c2b] {
        font-size: 0.875rem;
        color: var(--cv-ui-text-secondary);
        margin-bottom: 20px;
        line-height: 1.5;
}
.theme-story__note code[data-v-11526c2b],
    .theme-story__hint code[data-v-11526c2b] {
        font-size: 0.8em;
        padding: 2px 6px;
        background: var(--cv-ui-bg-tertiary);
        border-radius: var(--cv-ui-radius-sm);
}
.theme-story__block[data-v-11526c2b] {
        display: flex;
        flex-direction: column;
        gap: 16px;
}
.theme-story__hint[data-v-11526c2b] {
        font-size: 0.75rem;
        color: var(--cv-ui-text-tertiary);
        margin-top: 20px;
        line-height: 1.4;
}

.cv-dt-story-persistence[data-v-07edeefd] {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
}
.cv-dt-story-persistence__hint[data-v-07edeefd] {
    margin: 0;
    font-size: 0.875rem;
    color: var(--ag-foreground-color, #334155);
}
.cv-dt-story-persistence__saved[data-v-07edeefd] {
    margin: 0;
    font-size: 0.8125rem;
    color: var(--ag-foreground-color, #475569);
}
.cv-dt-story-persistence__table[data-v-07edeefd] {
    min-height: 400px;
}
.cv-dt-story-persistence__hint code[data-v-07edeefd],
.cv-dt-story-persistence__saved code[data-v-07edeefd] {
    font-size: 0.8125rem;
    padding: 0.125rem 0.25rem;
    background: var(--ag-background-color, #f1f5f9);
    border-radius: 4px;
}

.cv-dt-story__viewport[data-v-6009ccc4] {
    max-width: 375px;
    margin: 0 auto;
    border: 1px solid var(--ag-border-color, #e2e8f0);
    border-radius: 8px;
    overflow: hidden;
}

.dt-search-showcase[data-v-220d02cb] {
    display: flex;
    flex-direction: column;
    gap: 40px;
    padding: 24px;
    font-family: var(--cv-ui-font-family, system-ui, sans-serif);
}
.dt-search-showcase__label[data-v-220d02cb] {
    margin: 0 0 10px;
    font-size: 13px;
    color: #64748b;
}
.dt-search-showcase__label strong[data-v-220d02cb] {
    color: #1e293b;
    font-size: 14px;
}

.af-story-box[data-v-0e2adca7] {
        padding: 16px;
}
.af-story-actions[data-v-0e2adca7] {
        margin-top: 16px;
        display: flex;
        gap: 8px;
}
.af-story-btn[data-v-0e2adca7] {
        padding: 8px 16px;
        border: none;
        border-radius: 6px;
        color: #fff;
        cursor: pointer;
        font: inherit;
}
.af-story-btn--blue[data-v-0e2adca7] {
        background: #3b82f6;
}
.af-story-btn--blue[data-v-0e2adca7]:hover {
        background: #2563eb;
}
.af-story-btn--gray[data-v-0e2adca7] {
        background: #6b7280;
}
.af-story-btn--gray[data-v-0e2adca7]:hover {
        background: #4b5563;
}
.af-story-btn--green[data-v-0e2adca7] {
        background: #22c55e;
}
.af-story-btn--green[data-v-0e2adca7]:hover {
        background: #16a34a;
}
.af-story-alert[data-v-0e2adca7] {
        margin-top: 8px;
        padding: 8px;
        border-radius: 6px;
}
.af-story-alert--yellow[data-v-0e2adca7] {
        background: #fef9c3;
}
.af-story-alert--blue[data-v-0e2adca7] {
        background: #dbeafe;
}
.af-story-output[data-v-0e2adca7] {
        margin-top: 16px;
        padding: 16px;
        background: #f3f4f6;
        border-radius: 6px;
}
.af-story-title[data-v-0e2adca7] {
        font-weight: 700;
        margin: 0 0 8px;
}
.af-story-hint[data-v-0e2adca7] {
        margin-bottom: 16px;
        font-size: 14px;
        color: #4b5563;
}
.af-story-pre[data-v-0e2adca7] {
        font-size: 14px;
        margin: 0;
        white-space: pre-wrap;
}

.h-screen[data-v-3057092f] {
        height: 100vh;
}
