:root {
  --e-font-size-ref: 18px;
  font-size: var(--e-font-size-ref);

  --e-font-interface: Inter, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, sans-serif;
  --e-font-typography: serif;
  --e-font-mono: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;

  --e-font-size-3xs: 0.5rem;
  --e-font-size-2xs: 0.625rem;
  --e-font-size-xs: 0.75rem;
  --e-font-size-sm: 0.875rem;
  --e-font-size-md: 1rem;
  --e-font-size-lg: 1.125rem;
  --e-font-size-xl: 1.25rem;
  --e-font-size-2xl: 1.5rem;
  --e-font-size-3xl: 1.875rem;

  --e-font-h1: 2.75rem;
  --e-font-h2: 2.125rem;
  --e-font-h3: 1.625rem;
  --e-font-h4: 1.3125rem;
  --e-font-h5: 1.0625rem;
  --e-font-h6: 0.875rem;

  --e-spacing-3xs: 0.0625rem;
  --e-spacing-2xs: 0.125rem;
  --e-spacing-xs: 0.25rem;
  --e-spacing-sm: 0.5rem;
  --e-spacing-md: 0.75rem;
  --e-spacing-lg: 1rem;
  --e-spacing-xl: 1.5rem;
  --e-spacing-2xl: 2rem;
  --e-spacing-3xl: 3rem;

  --e-radius-3xs: 0.0625rem;
  --e-radius-2xs: 0.125rem;
  --e-radius-xs: 0.1875rem;
  --e-radius-sm: 0.25rem;
  --e-radius-md: 0.375rem;
  --e-radius-lg: 0.5rem;
  --e-radius-xl: 0.75rem;
  --e-radius-2xl: 1rem;
  --e-radius-3xl: 1.5rem;

  --e-img-3xs: 1.25rem;   /* tiny icons / inline avatars */
  --e-img-2xs: 1.5rem;   /* tiny icons / inline avatars */
  --e-img-xs:  2rem;     /* small avatar / badge */
  --e-img-sm:  3rem;     /* list avatar */
  --e-img-md:  4rem;     /* card image / profile */
  --e-img-lg:  6rem;     /* feature image */
  --e-img-xl:  8rem;     /* hero thumbnail */
  --e-img-2xl: 12rem;    /* large media */
  --e-img-3xl: 16rem;    /* banners / previews */

  --e-shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, 0.05);
  --e-shadow-md: 0 4px 6px -1px rgba(0, 0, 0, 0.1), 0 2px 4px -2px rgba(0, 0, 0, 0.1);
  --e-shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -2px rgba(0, 0, 0, 0.05);

  --e-bg: #f6f7fb;
  --e-fg: #0f172a;
  --e-fg-contrast: #fafafa;
  --e-surface-bg: #ffffff;
  --e-primary: #3551A4;
  --e-primary-fg: #ffffff;
  --e-muted: #36454F;
  --e-light: #fcfcfc;
  --e-muted-bg: #f9fafc;
  --e-border: #C0C0C0;
  --e-divider: #DCDCDC;
  --e-error: #C40233;
  --e-success: #009F6B;
  --e-danger: #C40233;
  --e-primary-transparent-accent-bg: color-mix(in srgb, var(--e-primary), transparent 90%);

  --e-tooltip-bg: #1a1a1b;
  --e-tooltip-fg: #ffffff;
  --e-tooltip-radius: var(--e-radius-sm); 
  --e-tooltip-font-size: var(--e-font-size-sm);

  --e-sidebar-collapsed: 4.5rem;
  --e-sidebar-expanded: 20rem; 
  --e-sidebar-bg: var(--e-surface-bg);
  --e-sidebar-transition: 0.3s cubic-bezier(0.2, 0, 0.2, 1);

  --e-main-max-width: 64rem;
  --e-main-gutter: 1rem;

  --e-font-regular: 400;
  --e-font-medium: 500;
  --e-font-bold: 700;

  --e-width-xs: 28rem;   /* forms, narrow panels */
  --e-width-sm: 32rem;   /* readable blocks */
  --e-width-md: 48rem;   /* app content */
  --e-width-lg: 64rem;   /* dashboards */
  --e-width-xl: 80rem;   /* wide layouts */
  --e-width-full: 100%;   /* 100% */

  --e-blur-sm: 1rem;
  --e-blur-md: 2.5rem;
  --e-blur-lg: 5rem;
}

@media (max-width: 640px) {
  :root {
    --e-font-size-ref: 16px;

    --e-font-size-3xs: 0.5625rem;
    --e-font-size-2xs: 0.6875rem;
    --e-font-size-xs: 0.8125rem;
    --e-font-size-sm: 0.9375rem;
    --e-font-size-md: 1rem;
    --e-font-size-lg: 1.0625rem;
    --e-font-size-xl: 1.125rem;
    --e-font-size-2xl: 1.3125rem;
    --e-font-size-3xl: 1.5rem;

    --e-font-h1: 2.125rem;
    --e-font-h2: 1.75rem;
    --e-font-h3: 1.375rem;
    --e-font-h4: 1.125rem;
    --e-font-h5: 1rem;
    --e-font-h6: 0.875rem;

    --e-spacing-3xs: 0.125rem;
    --e-spacing-2xs: 0.25rem;
    --e-spacing-xs: 0.375rem;
    --e-spacing-sm: 0.5rem;
    --e-spacing-md: 0.75rem;
    --e-spacing-lg: 1rem;
    --e-spacing-xl: 1.25rem;
    --e-spacing-2xl: 1.5rem;
    --e-spacing-3xl: 2rem;

    --e-img-2xs: 1.25rem;
    --e-img-xs: 1.75rem;
    --e-img-sm: 2.5rem;
    --e-img-md: 3rem;
    --e-img-lg: 4.5rem;
    --e-img-xl: 6rem;
    --e-img-2xl: 9rem;
    --e-img-3xl: 12rem;

    --e-main-gutter: 0.75rem;
    --e-main-max-width: 100%;

    --e-sidebar-collapsed: 3.5rem;
    --e-sidebar-expanded: 16rem;
  }
}

@media (min-width: 641px) and (max-width: 980px) {
  :root {
    --e-font-size-ref: 17px;

    /* Headings */
    --e-font-h1: 2.5rem;
    --e-font-h2: 2rem;
    --e-font-h3: 1.5625rem;
    --e-font-h4: 1.25rem;
    --e-font-h5: 1.0625rem;
    --e-font-h6: 0.9375rem;

    /* Spacing */
    --e-spacing-3xs: 0.125rem;
    --e-spacing-2xs: 0.1875rem;
    --e-spacing-xs: 0.375rem;
    --e-spacing-sm: 0.5rem;
    --e-spacing-md: 0.75rem;
    --e-spacing-lg: 1rem;
    --e-spacing-xl: 1.5rem;
    --e-spacing-2xl: 2rem;
    --e-spacing-3xl: 2.5rem;

    /* Images */
    --e-img-sm: 2.75rem;
    --e-img-md: 3.5rem;
    --e-img-lg: 5rem;
    --e-img-xl: 7rem;
    --e-img-2xl: 10rem;

    /* Layout */
    --e-main-gutter: 1.25rem;
    --e-main-max-width: 56rem;

    /* Sidebar */
    --e-sidebar-collapsed: 4rem;
    --e-sidebar-expanded: 18rem;
  }
}

*, *::before, *::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

/* Utilities */
*[data-padding="0"], [is^="e-"][data-padding="0"] {padding: 0; }
*[data-padding="3xs"], [is^="e-"][data-padding="3xs"] {padding: var(--e-spacing-3xs); }
*[data-padding="2xs"], [is^="e-"][data-padding="2xs"] { padding: var(--e-spacing-2xs); }
*[data-padding="xs"], [is^="e-"][data-padding="xs"] { padding: var(--e-spacing-xs); }
*[data-padding="sm"], [is^="e-"][data-padding="sm"] { padding: var(--e-spacing-sm); }
*[data-padding="md"], [is^="e-"][data-padding="md"] { padding: var(--e-spacing-md); }
*[data-padding="lg"], [is^="e-"][data-padding="lg"] { padding: var(--e-spacing-lg); }
*[data-padding="xl"], [is^="e-"][data-padding="xl"] { padding: var(--e-spacing-xl); }
*[data-padding="2xl"], [is^="e-"][data-padding="2xl"] { padding: var(--e-spacing-2xl); }
*[data-padding="3xl"], [is^="e-"][data-padding="3xl"] { padding: var(--e-spacing-3xl); }

*[data-padding-top="0"], [is^="e-"][data-padding-top="0"] { padding-top: 0; }
*[data-padding-top="3xs"], [is^="e-"][data-padding-top="3xs"] { padding-top: var(--e-spacing-3xs); }
*[data-padding-top="2xs"], [is^="e-"][data-padding-top="2xs"] { padding-top: var(--e-spacing-2xs); }
*[data-padding-top="xs"], [is^="e-"][data-padding-top="xs"] { padding-top: var(--e-spacing-xs); }
*[data-padding-top="sm"], [is^="e-"][data-padding-top="sm"] { padding-top: var(--e-spacing-sm); }
*[data-padding-top="md"], [is^="e-"][data-padding-top="md"] { padding-top: var(--e-spacing-md); }
*[data-padding-top="lg"], [is^="e-"][data-padding-top="lg"] { padding-top: var(--e-spacing-lg); }
*[data-padding-top="xl"], [is^="e-"][data-padding-top="xl"] { padding-top: var(--e-spacing-xl); }
*[data-padding-top="2xl"], [is^="e-"][data-padding-top="2xl"] { padding-top: var(--e-spacing-2xl); }
*[data-padding-top="3xl"], [is^="e-"][data-padding-top="3xl"] { padding-top: var(--e-spacing-3xl); }

*[data-padding-bottom="0"], [is^="e-"][data-padding-bottom="0"] { padding-bottom: 0; }
*[data-padding-bottom="3xs"], [is^="e-"][data-padding-bottom="3xs"] { padding-bottom: var(--e-spacing-3xs); }
*[data-padding-bottom="2xs"], [is^="e-"][data-padding-bottom="2xs"] { padding-bottom: var(--e-spacing-2xs); }
*[data-padding-bottom="xs"], [is^="e-"][data-padding-bottom="xs"] { padding-bottom: var(--e-spacing-xs); }
*[data-padding-bottom="sm"], [is^="e-"][data-padding-bottom="sm"] { padding-bottom: var(--e-spacing-sm); }
*[data-padding-bottom="md"], [is^="e-"][data-padding-bottom="md"] { padding-bottom: var(--e-spacing-md); }
*[data-padding-bottom="lg"], [is^="e-"][data-padding-bottom="lg"] { padding-bottom: var(--e-spacing-lg); }
*[data-padding-bottom="xl"], [is^="e-"][data-padding-bottom="xl"] { padding-bottom: var(--e-spacing-xl); }
*[data-padding-bottom="2xl"], [is^="e-"][data-padding-bottom="2xl"] { padding-bottom: var(--e-spacing-2xl); }
*[data-padding-bottom="3xl"], [is^="e-"][data-padding-bottom="3xl"] { padding-bottom: var(--e-spacing-3xl); }

*[data-padding-left="0"], [is^="e-"][data-padding-left="0s"] { padding-left: 0; }
*[data-padding-left="3xs"], [is^="e-"][data-padding-left="3xs"] { padding-left: var(--e-spacing-3xs); }
*[data-padding-left="2xs"], [is^="e-"][data-padding-left="2xs"] { padding-left: var(--e-spacing-2xs); }
*[data-padding-left="xs"], [is^="e-"][data-padding-left="xs"] { padding-left: var(--e-spacing-xs); }
*[data-padding-left="sm"], [is^="e-"][data-padding-left="sm"] { padding-left: var(--e-spacing-sm); }
*[data-padding-left="md"], [is^="e-"][data-padding-left="md"] { padding-left: var(--e-spacing-md); }
*[data-padding-left="lg"], [is^="e-"][data-padding-left="lg"] { padding-left: var(--e-spacing-lg); }
*[data-padding-left="xl"], [is^="e-"][data-padding-left="xl"] { padding-left: var(--e-spacing-xl); }
*[data-padding-left="2xl"], [is^="e-"][data-padding-left="2xl"] { padding-left: var(--e-spacing-2xl); }
*[data-padding-left="3xl"], [is^="e-"][data-padding-left="3xl"] { padding-left: var(--e-spacing-3xl); }

*[data-padding-right="0"], [is^="e-"][data-padding-right=0] { padding-right: 0; }
*[data-padding-right="3xs"], [is^="e-"][data-padding-right="3xs"] { padding-right: var(--e-spacing-3xs); }
*[data-padding-right="2xs"], [is^="e-"][data-padding-right="2xs"] { padding-right: var(--e-spacing-2xs); }
*[data-padding-right="xs"], [is^="e-"][data-padding-right="xs"] { padding-right: var(--e-spacing-xs); }
*[data-padding-right="sm"], [is^="e-"][data-padding-right="sm"] { padding-right: var(--e-spacing-sm); }
*[data-padding-right="md"], [is^="e-"][data-padding-right="md"] { padding-right: var(--e-spacing-md); }
*[data-padding-right="lg"], [is^="e-"][data-padding-right="lg"] { padding-right: var(--e-spacing-lg); }
*[data-padding-right="xl"], [is^="e-"][data-padding-right="xl"] { padding-right: var(--e-spacing-xl); }
*[data-padding-right="2xl"], [is^="e-"][data-padding-right="2xl"] { padding-right: var(--e-spacing-2xl); }
*[data-padding-right="3xl"], [is^="e-"][data-padding-right="3xl"] { padding-right: var(--e-spacing-3xl); }

*[data-margin-top="0"], [is^="e-"][data-margin-top="0"] { margin-top: 0; }
*[data-margin-top="3xs"], [is^="e-"][data-margin-top="3xs"] { margin-top: var(--e-spacing-3xs); }
*[data-margin-top="2xs"], [is^="e-"][data-margin-top="2xs"] { margin-top: var(--e-spacing-2xs); }
*[data-margin-top="xs"], [is^="e-"][data-margin-top="xs"] { margin-top: var(--e-spacing-xs); }
*[data-margin-top="sm"], [is^="e-"][data-margin-top="sm"] { margin-top: var(--e-spacing-sm); }
*[data-margin-top="md"], [is^="e-"][data-margin-top="md"] { margin-top: var(--e-spacing-md); }
*[data-margin-top="lg"], [is^="e-"][data-margin-top="lg"] { margin-top: var(--e-spacing-lg); }
*[data-margin-top="xl"], [is^="e-"][data-margin-top="xl"] { margin-top: var(--e-spacing-xl); }
*[data-margin-top="2xl"], [is^="e-"][data-margin-top="2xl"] { margin-top: var(--e-spacing-2xl); }
*[data-margin-top="3xl"], [is^="e-"][data-margin-top="3xl"] { margin-top: var(--e-spacing-3xl); }

*[data-margin-bottom="0"], [is^="e-"][data-margin-bottom="0"] { margin-bottom: 0; }
*[data-margin-bottom="3xs"], [is^="e-"][data-margin-bottom="3xs"] { margin-bottom: var(--e-spacing-3xs); }
*[data-margin-bottom="2xs"], [is^="e-"][data-margin-bottom="2xs"] { margin-bottom: var(--e-spacing-2xs); }
*[data-margin-bottom="xs"], [is^="e-"][data-margin-bottom="xs"] { margin-bottom: var(--e-spacing-xs); }
*[data-margin-bottom="sm"], [is^="e-"][data-margin-bottom="sm"] { margin-bottom: var(--e-spacing-sm); }
*[data-margin-bottom="md"], [is^="e-"][data-margin-bottom="md"] { margin-bottom: var(--e-spacing-md); }
*[data-margin-bottom="lg"], [is^="e-"][data-margin-bottom="lg"] { margin-bottom: var(--e-spacing-lg); }
*[data-margin-bottom="xl"], [is^="e-"][data-margin-bottom="xl"] { margin-bottom: var(--e-spacing-xl); }
*[data-margin-bottom="2xl"], [is^="e-"][data-margin-bottom="2xl"] { margin-bottom: var(--e-spacing-2xl); }
*[data-margin-bottom="3xl"], [is^="e-"][data-margin-bottom="3xl"] { margin-bottom: var(--e-spacing-3xl); }

*[data-gap="0"], [is^="e-"][data-gap="0"] { gap: 0; }
*[data-gap="3xs"], [is^="e-"][data-gap="3xs"] { gap: var(--e-spacing-3xs); }
*[data-gap="2xs"], [is^="e-"][data-gap="2xs"] { gap: var(--e-spacing-2xs); }
*[data-gap="xs"], [is^="e-"][data-gap="xs"] { gap: var(--e-spacing-xs); }
*[data-gap="sm"], [is^="e-"][data-gap="sm"] { gap: var(--e-spacing-sm); }
*[data-gap="md"], [is^="e-"][data-gap="md"] { gap: var(--e-spacing-md); }
*[data-gap="lg"], [is^="e-"][data-gap="lg"] { gap: var(--e-spacing-lg); }
*[data-gap="xl"], [is^="e-"][data-gap="xl"] { gap: var(--e-spacing-xl); }
*[data-gap="2xl"], [is^="e-"][data-gap="2xl"] { gap: var(--e-spacing-2xl); }
*[data-gap="3xl"], [is^="e-"][data-gap="3xl"] { gap: var(--e-spacing-3xl); }

*[data-align-items="start"], [is^="e-"][data-align-items="start"] { align-items: flex-start; }
*[data-align-items="center"], [is^="e-"][data-align-items="center"] { align-items: center; }
*[data-align-items="end"], [is^="e-"][data-align-items="end"] { align-items: flex-end; }
*[data-align-self="start"], [is^="e-"][data-align-self="start"] { align-self: flex-start; }
*[data-align-self="center"], [is^="e-"][data-align-self="center"] { align-self: center; }
*[data-align-self="end"], [is^="e-"][data-align-self="end"] { align-self: flex-end; }
*[data-justify-content="start"], [is^="e-"][data-justify-content="start"] { justify-content: flex-start; }
*[data-justify-content="center"], [is^="e-"][data-justify-content="center"] { justify-content: center; }
*[data-justify-content="end"], [is^="e-"][data-justify-content="end"] { justify-content: flex-end; }
*[data-justify-self="start"], [is^="e-"][data-justify-self="start"] { justify-self: flex-start; }
*[data-justify-self="center"], [is^="e-"][data-justify-self="center"] { justify-self: center; }
*[data-justify-self="end"], [is^="e-"][data-justify-self="end"] { justify-self: flex-end; }
*[data-justify-content="space-between"], [is^="e-"][data-justify-content="space-between"] { justify-content: space-between; }
*[data-justify-content="stretch"], [is^="e-"][data-justify-content="stretch"] { justify-content: stretch; }
*[data-flex-direction="column"], [is^="e-"][data-flex-direction="column"] { flex-direction: column; }
*[data-flex-direction="row"], [is^="e-"][data-flex-direction="row"] { flex-direction: row; }
*[data-flex-wrap="nowrap"], [is^="e-"][data-flex-wrap="nowrap"] { flex-wrap: nowrap; }
*[data-flex-wrap="wrap"], [is^="e-"][data-flex-wrap="wrap"] { flex-wrap: wrap; }
*[data-width="full"], [is^="e-"][data-width="full"] { width: 100%; }
*[data-height="full"], [is^="e-"][data-height="full"] { height: 100%; }

*[data-shrink="0"], [is^="e-"][data-shrink="0"] {
  flex-shrink: 0;
}

*[data-width="xs"], [is^="e-"][data-width="xs"] {
  width: var(--e-width-xs);
  max-width: 100%;
}
*[data-width="sm"], [is^="e-"][data-width="sm"] {
  width: var(--e-width-sm);
  max-width: 100%;
}
*[data-width="md"], [is^="e-"][data-width="md"] {
  width: var(--e-width-md);
  max-width: 100%;
}
*[data-width="lg"], [is^="e-"][data-width="lg"] {
  width: var(--e-width-lg);
  max-width: 100%;
}
*[data-width="xl"], [is^="e-"][data-width="xl"] {
  width: var(--e-width-xl);
  max-width: 100%;
}
*[data-width="max-content"], [is^="e-"][data-width="max-content"] {
  width: max-content;
}
*[data-height="max-content"], [is^="e-"][data-height="max-content"] {
  height: max-content;
}

*[data-font-size="3xs"], [is^="e-"][data-font-size="3xs"] { font-size: var(--e-font-size-3xs); }
*[data-font-size="2xs"], [is^="e-"][data-font-size="2xs"] { font-size: var(--e-font-size-2xs); }
*[data-font-size="xs"], [is^="e-"][data-font-size="xs"] { font-size: var(--e-font-size-xs); }
*[data-font-size="sm"], [is^="e-"][data-font-size="sm"] { font-size: var(--e-font-size-sm); }
*[data-font-size="md"], [is^="e-"][data-font-size="md"] { font-size: var(--e-font-size-md); }
*[data-font-size="lg"], [is^="e-"][data-font-size="lg"] { font-size: var(--e-font-size-lg); }
*[data-font-size="xl"], [is^="e-"][data-font-size="xl"] { font-size: var(--e-font-size-xl); }
*[data-font-size="2xl"], [is^="e-"][data-font-size="2xl"] { font-size: var(--e-font-size-2xl); }
*[data-font-size="3xl"], [is^="e-"][data-font-size="3xl"] { font-size: var(--e-font-size-3xl); }

*[data-background="surface"], [is^="e-"][data-background="surface"] { background-color: var(--e-surface-bg); }
*[data-background="muted"], [is^="e-"][data-background="muted"] { background-color: var(--e-muted-bg); }
*[data-background="primary"], [is^="e-"][data-background="primary"] { background-color: var(--e-primary); }
*[data-background="danger"], [is^="e-"][data-background="danger"] { background-color: var(--e-error); }
*[data-background="success"], [is^="e-"][data-background="sueccess"] { background: var(--e-success); }
*[data-background="danger-transparent"], [is^="e-"][data-background="danger"] { background: color-mix(in srgb, var(--e-error), transparent 90%); }
*[data-background="success-transparent"], [is^="e-"][data-background="success-transparent"] { background-color: color-mix(in srgb, var(--e-success), transparent 90%); }
*[data-background="blurred"], [is^="e-"][data-background="blurred"] { background-color: transparent; backdrop-filter: blur(var(--e-blur-lg)); -webkit-backdrop-filter: blur(var(--e-blur-lg)); }
*[data-background-blur="sm"], [is^="e-"][data-background-blur="sm"] { background-color: transparent; backdrop-filter: blur(var(--e-blur-sm)); -webkit-backdrop-filter: blur(var(--e-blur-sm)); }
*[data-background-blur="md"], [is^="e-"][data-background-blur="md"] { background-color: transparent; backdrop-filter: blur(var(--e-blur-md)); -webkit-backdrop-filter: blur(var(--e-blur-md)); }
*[data-background-blur="lg"], [is^="e-"][data-background-blur="lg"] { background-color: transparent; backdrop-filter: blur(var(--e-blur-lg)); -webkit-backdrop-filter: blur(var(--e-blur-lg)); }

*[data-color="text"], [is^="e-"][data-color="text"] { color: var(--e-fg); }
*[data-color="muted"], [is^="e-"][data-color="muted"] { color: var(--e-muted); }
*[data-color="light"], [is^="e-"][data-color="light"] { color: var(--e-light); }
*[data-color="primary"], [is^="e-"][data-color="primary"] { color: var(--e-primary); }
*[data-color="danger"], [is^="e-"][data-color="danger"] { color: var(--e-error); }
*[data-color="success"], [is^="e-"][data-color="sueccess"] { color: var(--e-success); }

*[data-border-color="default"], [is^="e-"][data-border-color="default"] { border-color: var(--e-color-border) !important; }
*[data-border-color="muted"], [is^="e-"][data-border-color="muted"]   { border-color: var(--e-divider) !important; }
*[data-border-color="focus"], [is^="e-"][data-border-color="focus"]   { border-color: var(--e-color-focus) !important; }
*[data-border-color="danger"], [is^="e-"][data-border-color="danger"] { border-color: var(--e-error) !important; }
*[data-border-color="success"], [is^="e-"][data-border-color="sueccess"] { border-color: var(--e-success) !important; }

*[data-border-radius="0"], [is^="e-"][data-border-radius="0"] { border-radius: 0; }
*[data-border-radius="2xs"], [is^="e-"][data-border-radius="2xs"] { border-radius: var(--e-radius-2xs); }
*[data-border-radius="xs"], [is^="e-"][data-border-radius="xs"] { border-radius: var(--e-radius-xs); }
*[data-border-radius="sm"], [is^="e-"][data-border-radius="sm"] { border-radius: var(--e-radius-sm); }
*[data-border-radius="md"], [is^="e-"][data-border-radius="md"] { border-radius: var(--e-radius-md); }
*[data-border-radius="lg"], [is^="e-"][data-border-radius="lg"] { border-radius: var(--e-radius-lg); }
*[data-border-radius="xl"], [is^="e-"][data-border-radius="xl"] { border-radius: var(--e-radius-xl); }
*[data-border-radius="2xl"], [is^="e-"][data-border-radius="2xl"] { border-radius: var(--e-radius-2xl); }
*[data-border-radius="3xl"], [is^="e-"][data-border-radius="3xl"] { border-radius: var(--e-radius-3xl); }
*[data-border-radius="circle"], [is^="e-"][data-border-radius="circle"] { border-radius: 50%; }

*[data-flex-grow], [is^="e-"][data-flex-grow] { flex-grow: 1; }
*[data-flex-shrink="0"], [is^="e-"][data-flex-shrink="0"] { flex-shrink: 0; }

*[data-columns="1"], [is^="e-"][data-columns="1"] { grid-template-columns: repeat(1, 1fr); }
*[data-columns="2"], [is^="e-"][data-columns="2"] { grid-template-columns: repeat(2, 1fr); }
*[data-columns="3"], [is^="e-"][data-columns="3"] { grid-template-columns: repeat(3, 1fr); }
*[data-columns="auto"], [is^="e-"][data-columns="auto"] { grid-auto-flow: column; }

*[data-font-weight="regular"], [is^="e-"][data-font-weight="regular"] { font-weight: var(--e-font-regular); }
*[data-font-weight="medium"], [is^="e-"][data-font-weight="medium"]  { font-weight: var(--e-font-medium); }
*[data-font-weight="bold"], [is^="e-"][data-font-weight="bold"] { font-weight: var(--e-font-bold); }

*[data-text-align="center"], [is^="e-"][data-text-align="center"] { text-align: center; }
*[data-text-align="right"], [is^="e-"][data-text-align="right"]  { text-align: right; }
*[data-text-align="left"], [is^="e-"][data-text-align="left"]  { text-align: left !important; }

*[data-hidden="true"], [is^="e-"][data-hidden="true"] {
  display: none;
}

*[data-diabled="true"], [is^="e-"][data-disabled="true"] {
  opacity: 0.6;
}

e-form-dynamic-value {
  display: none;
}

*[data-disabled], [is^="e-"][data-disabled] {
  opacity: 0.5;
  pointer-events: none;
}

*[data-clickable], [is^="e-"][data-clickable] {
  cursor: pointer;
  user-select: none;
}

*[data-scroll="y"], [is^="e-"][data-scroll="y"] { overflow-y: auto; }
*[data-scroll="x"], [is^="e-"][data-scroll="x"] { overflow-x: auto; }

*[data-truncate], [is^="e-"][data-truncate] {
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

*[data-scroll="hidden"], [is^="e-"][data-scroll="hidden"] {
  overflow: auto;
  scrollbar-width: none;
  -ms-overflow-style: none;
}

*[data-scroll="hidden"], [is^="e-"][data-scroll="hidden"]::-webkit-scrollbar {
  width: 0;
  height: 0;
}

img[data-size="2xs"],
div[is="e-user-avatar"][data-size="2xs"],
button[is="e-with-icon"] img[data-size="2xs"] {
  width: var(--e-img-2xs);
  height: var(--e-img-2xs);
}
img[data-size="xs"],
div[is="e-user-avatar"][data-size="xs"],
button[is="e-with-icon"] img[data-size="xs"] {
  width: var(--e-img-xs);
  height: var(--e-img-xs);
}
img[data-size="sm"],
div[is="e-user-avatar"][data-size="sm"],
button[is="e-with-icon"] img[data-size="sm"] {
  width: var(--e-img-sm);
  height: var(--e-img-sm);
}
img[data-size="md"],
div[is="e-user-avatar"][data-size="md"],
button[is="e-with-icon"] img[data-size="md"] {
  width: var(--e-img-md);
  height: var(--e-img-md);
}
img[data-size="lg"],
div[is="e-user-avatar"][data-size="lg"],
button[is="e-with-icon"] img[data-size="lg"] {
  width: var(--e-img-lg);
  height: var(--e-img-lg);
}
img[data-size="xl"],
div[is="e-user-avatar"][data-size="xl"],
button[is="e-with-icon"] img[data-size="xl"] {
  width: var(--e-img-xl);
  height: var(--e-img-xl);
}
img[data-size="2xl"],
div[is="e-user-avatar"][data-size="2xl"],
button[is="e-with-icon"] img[data-size="2xl"]] {
  width: var(--e-img-2xl);
  height: var(--e-img-2xl);
}
img[data-size="3xl"],
div[is="e-user-avatar"][data-size="3xl"],
button[is="e-with-icon"] img[data-size="3xl"] {
  width: var(--e-img-3xl);
  height: var(--e-img-3xl);
}
img[data-width="2xs"],
div[is="e-user-avatar"][data-width="2xs"],
button[is="e-with-icon"] img[data-width="2xs"] {
  width: var(--e-img-2xs);
}
img[data-width="xs"],
div[is="e-user-avatar"][data-width="xs"],
button[is="e-with-icon"] img[data-width="xs"] {
  width: var(--e-img-xs);
}
img[data-width="sm"],
div[is="e-user-avatar"][data-width="sm"],
button[is="e-with-icon"] img[data-width="xs"] {
  width: var(--e-img-sm);
}
img[data-width="md"],
div[is="e-user-avatar"][data-width="md"],
button[is="e-with-icon"] img[data-width="md"] {
  width: var(--e-img-md);
}
img[data-width="lg"],
div[is="e-user-avatar"][data-width="lg"],
button[is="e-with-icon"] img[data-width="lg"] {
  width: var(--e-img-lg);
}
img[data-width="xl"],
div[is="e-user-avatar"][data-width="xl"],
button[is="e-with-icon"] img[data-width="xl"] {
  width: var(--e-img-xl);
}
img[data-width="2xl"],
div[is="e-user-avatar"][data-width="2xl"],
button[is="e-with-icon"] img[data-width="2xl"] {
  width: var(--e-img-2xl);
}
img[data-width="3xl"],
div[is="e-user-avatar"][data-width="3xl"],
button[is="e-with-icon"] img[data-width="3xl"] {
  width: var(--e-img-3xl);
}
img[data-width="full"],
div[is="e-user-avatar"][data-width="full"],
button[is="e-with-icon"] img[data-width="full"] {
  width: 100%;
  height: auto;
}
img[data-height="2xs"],
div[is="e-user-avatar"][data-height="2xs"],
button[is="e-with-icon"] img[data-height="2xs"] {
  height: var(--e-img-2xs);
}
img[data-height="xs"],
div[is="e-user-avatar"][data-height="xs"],
button[is="e-with-icon"] img[data-height="xs"] {
  height: var(--e-img-xs);
}
img[data-height="sm"],
div[is="e-user-avatar"][data-height="sm"],
button[is="e-with-icon"] img[data-height="sm"] {
  height: var(--e-img-sm);
}
img[data-height="md"],
div[is="e-user-avatar"][data-height="md"],
button[is="e-with-icon"] img[data-height="md"] {
  height: var(--e-img-md);
}
img[data-height="lg"],
div[is="e-user-avatar"][data-height="lg"],
button[is="e-with-icon"] img[data-height="lg"] {
  height: var(--e-img-lg);
}
img[data-height="xl"],
div[is="e-user-avatar"][data-height="xl"],
button[is="e-with-icon"] img[data-height="xl"] {
  height: var(--e-img-xl);
}
img[data-height="2xl"],
div[is="e-user-avatar"][data-height="2xl"],
button[is="e-with-icon"] img[data-height="2xl"] {
  height: var(--e-img-2xl);
}
img[data-height="3xl"],
div[is="e-user-avatar"][data-height="3xl"],
button[is="e-with-icon"] img[data-height="3xl"] {
  height: var(--e-img-3xl);
}

img[data-skeleton] {
  background:
    linear-gradient(
      90deg,
      var(--e-color-muted) 25%,
      var(--e-color-surface) 37%,
      var(--e-color-muted) 63%
    );
  background-size: 400% 100%;
  animation: e-skeleton 1.4s ease infinite;
}

@keyframes e-skeleton {
  0%   { background-position: 100% 0; }
  100% { background-position: 0 0; }
}

img[data-muted] {
  filter: grayscale(1);
  opacity: 0.85;
}
img[data-blur] {
  filter: blur(var(--e-blur-md));
}
img[data-dim] {
  filter: brightness(0.85);
}
img[data-hover="zoom"] {
  transition: transform 0.2s ease;
}
img[data-hover="zoom"]:hover {
  transform: scale(1.03);
}
img[data-clickable] {
  cursor: pointer;
}
img[data-loading] {
  background-color: var(--e-color-muted);
}

*[data-block-center], [is^="e-"][data-block-center] {
  margin-left: auto;
  margin-right: auto;
}
*[data-default-main-width], [is^="e-"][data-default-main-width] {
  width: 1280px;
  max-width: 100%;
}
*[data-inline-center], [is^="e-"][data-inline-center] {
  text-align: center;
}
*[data-flex-center], [is^="e-"][data-flex-center] {
  display: flex;
  justify-content: center;
}
*[data-flex-center-cross], [is^="e-"][data-flex-center-cross] {
  display: flex;
  align-items: center;
}
*[data-flex-center-both], [is^="e-"][data-flex-center-both] {
  display: flex;
  justify-content: center;
  align-items: center;
}
*[data-grid-center], [is^="e-"][data-grid-center] {
  display: grid;
  place-items: center;
}
*[data-grid-center-x], [is^="e-"][data-grid-center-x] {
  display: grid;
  justify-items: center;
}
*[data-grid-center-y], [is^="e-"][data-grid-center-y] {
  display: grid;
  align-items: center;
}

*[data-absolute-center], [is^="e-"][data-absolute-center] {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}
*[data-absolute-horizontal-center], [is^="e-"][data-absolute-horizontal-center] {
  position: absolute;
  transform: translate(-50%, 0);
  left: 50%;
}
*[data-vertical-center], [is^="e-"][data-vertical-center] {
  position: absolute;
  top: 50%;
  transform: translate(0, -50%);
}
*[data-absolute-bottom], [is^="e-"][data-absolute-bottom] {
  position: absolute;
  bottom: 0;
}
*[data-absolute-bottom="3xs"], [is^="e-"][data-absolute-bottom="3xs"] {
  position: absolute;
  bottom: var(--e-spacing-3xs);
}
*[data-absolute-bottom="2xs"], [is^="e-"][data-absolute-bottom="2xs"] {
  position: absolute;
  bottom: var(--e-spacing-2xs);
}
*[data-absolute-bottom="xs"], [is^="e-"][data-absolute-bottom="xs"] {
  position: absolute;
  bottom: var(--e-spacing-xs);
}
*[data-absolute-bottom="sm"], [is^="e-"][data-absolute-bottom="sm"] {
  position: absolute;
  bottom: var(--e-spacing-sm);
}
*[data-absolute-bottom="md"], [is^="e-"][data-absolute-bottom="md"] {
  position: absolute;
  bottom: var(--e-spacing-md);
}
*[data-absolute-bottom="lg"], [is^="e-"][data-absolute-bottom="lg"] {
  position: absolute;
  bottom: var(--e-spacing-lg);
}
*[data-absolute-bottom="xl"], [is^="e-"][data-absolute-bottom="xl"] {
  position: absolute;
  bottom: var(--e-spacing-xl);
}
*[data-absolute-bottom="2xl"], [is^="e-"][data-absolute-bottom="2xl"] {
  position: absolute;
  bottom: var(--e-spacing-2xl);
}
*[data-absolute-bottom="3xl"], [is^="e-"][data-absolute-bottom="3xl"] {
  position: absolute;
  bottom: var(--e-spacing-3xl);
}

[data-relative] {
  position: relative;
}
[data-absolute] {
  position: absolute;
}

[data-absolute-top="3xs"] {
  position: absolute;
  top: var(--e-spacing-3xs);
}
[data-absolute-top="2xs"] {
  position: absolute;
  top: var(--e-spacing-2xs);
}
[data-absolute-top="xs"] {
  position: absolute;
  top: var(--e-spacing-xs);
}
[data-absolute-top="sm"] {
  position: absolute;
  top: var(--e-spacing-sm);
}
[data-absolute-top="md"] {
  position: absolute;
  top: var(--e-spacing-md);
}
[data-absolute-top="lg"] {
  position: absolute;
  top: var(--e-spacing-lg);
}
[data-absolute-top="xl"] {
  position: absolute;
  top: var(--e-spacing-xl);
}
[data-absolute-top="2xl"] {
  position: absolute;
  top: var(--e-spacing-2xl);
}
[data-absolute-top="3xl"] {
  position: absolute;
  top: var(--e-spacing-3xl);
}

[data-table-center] {
  display: table-cell;
  vertical-align: middle;
  text-align: center;
}
[data-center-content] {
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

[data-vertical-align="middle"] {
  vertical-align: middle;
}

*[data-border=""], [is^="e-"][data-border=""] {
  border: 1px solid var(--e-border);
}

*[data-border="top"], [is^="e-"][data-border="top"] { border-top: 1px solid var(--e-border); }
*[data-border="right"], [is^="e-"][data-border="right"] { border-right: 1px solid var(--e-border); }
*[data-border="bottom"], [is^="e-"][data-border="bottom"] { border-bottom: 1px solid var(--e-border); }
*[data-border="left"], [is^="e-"][data-border="left"] { border-left: 1px solid var(--e-border); }
*[data-border="none"], [is^="e-"][data-border="none"] { border: none; }

*[data-box-shadow="sm"], [is^="e-"][data-box-shadow="sm"] {
  box-shadow: var(--e-shadow-sm);
}
*[data-box-shadow="md"], [is^="e-"][data-box-shadow="md"] {
  box-shadow: var(--e-shadow-md);
}
*[data-box-shadow="lg"], [is^="e-"][data-box-shadow="lg"] {
  box-shadow: var(--e-shadow-lg);
}

*[data-text-wrap], [is^="e-"][data-text-wrap] {
  white-space: normal;
  overflow-wrap: break-word;
  word-break: break-word;
}

*[data-text-break-all], [is^="e-"][data-text-break-all] {
  word-break: break-all;
}

*[data-text-nowrap], [is^="e-"][data-text-nowrap] {
  white-space: nowrap;
}

*[data-text-ellipsis], [is^="e-"][data-text-ellipsis] {
  min-width: 0;          /* flex/grid fix */
  overflow: hidden;
  white-space: nowrap;
  text-overflow: ellipsis;
}

*[data-text-pre], [is^="e-"][data-text-pre] {
  white-space: pre-wrap;
}

*[data-text-case="capitalize"], [is^="e-"][data-text-case="capitalize"] {
  text-transform: capitalize;
}
*[data-text-case="upper"], [is^="e-"][data-text-case="upper"] {
  text-transform: uppercase;
}
*[data-text-case="lower"], [is^="e-"][data-text-case="lower"] {
  text-transform: lowercase;
}
*[data-text-case="normal"], [is^="e-"][data-text-case="normal"] {
  text-transform: none;
}

*[data-cursor="pointer"], [is^="e-"][data-cursor="pointer"] {
  cursor: pointer;
}

img[data-wrapped-in-circle] {
  border: 3px solid var(--e-primary);
  border-radius: 50%;
  padding: var(--e-spacing-xs);
}

*[data-box-shadow-none], [is^="e-"][data-box-shadow-none] {
  box-shadow: none;
}

/* --- Normalization & Base --- */
html {
  -webkit-text-size-adjust: 100%;
  -moz-tab-size: 4;
  tab-size: 4;
  scroll-behavior: smooth;
  height: max-content;
}

body {
  min-height: 100vh;
  width: 100%;
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  font-family: var(--e-font-interface);
  color: var(--e-fg);
  background-color: var(--e-bg);
  text-rendering: optimizeLegibility;
  height: max-content;
}

@property --neon-clr {
  syntax: '<color>';
  initial-value: #4285f4;
  inherits: false;
}

/* The Top Border Beam */
[data-loading]::before {
  content: '';
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 3px;
  
  background: var(--neon-clr);

  box-shadow: 
    0 2px 10px var(--neon-clr),
    0 5px 25px var(--neon-clr),
    0 10px 50px var(--neon-clr);

  animation: 
    neonColors 2s infinite linear,
    beamPulse 1s infinite ease-in-out;
    
  z-index: 9999;
}

/* Smoothly cycle the variable through neon hues */
@keyframes neonColors {
  0%   { --neon-clr: #4285f4; } /* Blue */
  25%  { --neon-clr: #ea4335; } /* Red */
  50%  { --neon-clr: #fbbc05; } /* Yellow */
  75%  { --neon-clr: #34a853; } /* Green */
  100% { --neon-clr: #4285f4; } /* Back to Blue */
}

/* Makes the glow breathe */
@keyframes beamPulse {
  0%, 100% { opacity: 0.8; filter: brightness(1); }
  50%      { opacity: 1; filter: brightness(1.4); }
}

h1, h2, h3, h4, h5, h6 {
  font-size: inherit;
  font-weight: inherit;
}

ul, ol {
  list-style: none;
}

img, svg, video, canvas, audio, iframe, embed, object {
  display: block;
  max-width: 100%;
}

button, input, optgroup, select, textarea {
  font-family: inherit;
  font-size: 100%;
  line-height: inherit;
  color: inherit;
  background: transparent;
  border: none;
  outline: none;
}

select {
  cursor: pointer;
}

textarea {
  min-height: 6rem;
}

button, [role="button"] {
  cursor: pointer;
}

form[is="e-form"] label:has(input[type="file"]) {
  border: 2px dashed var(--e-border);
  border-radius: 8px;
  padding: var(--e-spacing-lg);
  text-align: center;
  color: #555;
  cursor: pointer;
  transition: border-color 0.3s, background-color 0.3s;
}

form[is="e-form"] label:has(input[type="file"])[data-set-height] {
  height: calc(var(--e-img-xl) + 2 * var(--e-spacing-lg) + 4rem);
  justify-content: center;
}

form[is="e-form"] label:has(input[type="file"]) > img {
  width: auto;
  height: var(--e-img-xl);
  margin: 0 auto;
  border-radius: 1rem;
}

form[is="e-form"] label input[type="file"] {
  display: none;
}

form[is="e-form"] input[type="color"] {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  border: 1px solid #cdcdcd;
  height: 3.6rem;
  width: 100%;
  border-radius: var(--e-radius-lg);
  padding: 0;
  cursor: pointer;
  background: none;
}

form[is="e-form"] input[type="color"]::-webkit-color-swatch-wrapper {
  padding: 0;
  border: none;
}

form[is="e-form"] input[type="color"]::-webkit-color-swatch {
  border: none;
  border-radius: var(--e-radius-md);
}

form[is="e-form"] input[type="color"]::-moz-color-swatch {
  border: none;
  border-radius: 50%;
}

a {
  color: inherit;
  text-decoration: inherit;
}

table {
  text-indent: 0;
  border-color: inherit;
  border-collapse: collapse;
}

textarea {
  resize: vertical;
}

details {
  display: block;
  border: 1px solid var(--e-divider);
  border-radius: 0.75rem;
  cursor: pointer;
  break-inside: avoid;
  width: 100%;
  box-sizing: border-box;
}

details > p,
details > div {
  overflow: hidden;
  padding-left: var(--e-spacing-md);
  padding-right: var(--e-spacing-md);
  padding-bottom: var(--e-spacing-md);
  max-width: 100%;
  word-break: break-word;
}

details[open] {
  background: var(--e-surface);
}

details > summary {
  padding: var(--e-spacing-sm) var(--e-spacing-md);
}

details > summary {
  list-style: none;
  cursor: pointer;
  outline: none;
  position: relative;
  padding-right: var(--e-spacing-md);
  align-items: center;
}

details summary::-webkit-details-marker {
  display: none;
}

details:not([open]) > summary::after  {
  content: "›";
  position: absolute;
  right: var(--e-spacing-md);
  top: 50%;
  transform: translateY(-50%) translateY(-0.1rem) rotate(0deg);
  color: var(--e-primary);
}

details[open] > summary::after {
  content: "›";
  position: absolute;
  right: var(--e-spacing-md);
  top: 50%;
  color: var(--e-primary);
  transform: translateY(-50%) rotate(90deg);
}

[hidden] {
  display: none !important;
}

:focus-visible {
  outline: 2px solid var(--e-primary);
  outline-offset: 2px;
}

body:has(> img[is="backdrop"]) {
  position: relative;
}

img[is="backdrop"] {
  position: absolute;
  display: inline-block;
  z-index: -1;
  height: 100%;
  width: 100%;
  object-fit: cover;
}

/* --- Typography Elements --- */
span[is="e-text"] {
  font-size: var(--e-font-size-md);
  color: var(--e-fg);
}

span[is="e-muted"] {
  font-size: var(--e-font-size-md);
  color: var(--e-muted);
}

span[is="e-light"] {
  font-size: var(--e-font-size-md);
  color: var(--e-light);
}

span[is="e-bold"] {
  font-size: var(--e-font-size-md);
  font-weight: bold;
  color: var(--e-fg);
}

span[is="e-caption"] {
  font-size: var(--e-font-size-xs);
  color: var(--e-muted);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  font-weight: 600;
  display: inline-block;
}

span[is="e-error"] {
  color: var(--e-error);
  font-size: var(--e-font-size-sm);
  font-weight: 500;
}

span[is="e-danger"] {
  color: var(--e-error);
  font-size: var(--e-font-size-sm);
  font-weight: 500;
}

span[is="e-helper"] {
  display: block;
  font-size: var(--e-font-size-xs);
  color: var(--e-muted);
  margin-top: var(--e-spacing-xs);
}

span[is="e-badge"] {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0 var(--e-spacing-xs);
  height: 1.25rem;
  min-width: 1.25rem;
  border-radius: 9999px;
  background-color: var(--e-primary);
  color: var(--e-primary-fg);
  font-size: var(--e-font-size-3xs);
  font-weight: 700;
  line-height: 1;
  white-space: nowrap;
}

span[is="e-tag"] {
  display: inline-flex;
  align-items: center;
  padding: 0 var(--e-spacing-sm);
  height: 1.5rem;
  border-radius: var(--e-radius-sm);
  background-color: var(--e-muted-bg);
  color: var(--e-muted);
  font-size: var(--e-font-size-xs);
  font-weight: 500;
  border: 1px solid var(--e-border);
  white-space: nowrap;
}

span[is="e-chip"] {
  display: inline-flex;
  gap: var(--e-spacing-md);
  align-items: center;
  padding: 0 var(--e-spacing-md);
  height: 2rem;
  width: max-content;
  border-radius: var(--e-radius-3xl);
  background-color: var(--e-primary-transparent-accent-bg);
  color: var(--e-fg);
  font-size: var(--e-font-size-sm);
  font-weight: 500;
  border: 1px solid var(--e-primary);
  white-space: nowrap;
  transition: background-color 0.2s;
}

span[is="e-chip"] img {
  justify-self: end;
  height: 1rem;
  cursor: pointer;
}

span[is="e-chip"]:hover {
  background-color: var(--e-muted-bg);
}

span[is="stack"] {
  display: inline-flex;
  flex-direction: column;
  font-size: var(--e-font-size-xs);
  line-height: 1;
  vertical-align: middle;
  text-align: left;
}

e-selectable-chip {
  display: flex;
  justify-content: center;
  align-items: center;
  width: max-content;
  padding: var(--e-spacing-sm);
  height: max-content;
  line-height: 1rem;
  border-radius: var(--e-radius-3xl);
  background-color: var(--e-surface-bg);
  font-size: var(--e-font-size-sm);
  font-weight: 500;
  color: var(--e-muted);
  cursor: pointer;
  border: 1px solid var(--e-border);
  box-shadow: var(--e-shadow-lg);
  transition: background-color 0.2s;
  user-select: none;
  word-break: break-word;
  flex-wrap: wrap;
}

e-selectable-chip:hover {
  background-color: var(--e-muted-bg);
}

e-selectable-chip[data-selected='true'] {
  background-color: var(--e-primary-transparent-accent-bg);
  border: 1px solid var(--e-primary);
  font-weight: 650;
  color: var(--e-text);
}

mark[is="e-mark"] {
  background-color: rgba(37, 99, 235, 0.15);
  color: inherit;
  padding: 0 var(--e-spacing-3xs);
  border-radius: var(--e-radius-3xs);
}

code[is="e-code"] {
  font-family: var(--e-font-mono);
  font-size: var(--e-font-size-sm);
  background-color: var(--e-muted-bg);
  color: var(--e-fg);
  padding: var(--e-spacing-3xs) var(--e-spacing-2xs);
  border-radius: var(--e-radius-sm);
  border: 1px solid var(--e-border);
  word-break: break-word;
}

kbd[is="e-kbd"] {
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol";
  font-size: var(--e-font-size-2xs);
  font-weight: 600;
  background-color: var(--e-muted-bg);
  color: var(--e-fg);
  padding: var(--e-spacing-3xs) var(--e-spacing-xs);
  border-radius: var(--e-radius-sm);
  border: 1px solid var(--e-border);
  border-bottom-width: 2px;
  box-shadow: var(--e-shadow-sm);
  white-space: nowrap;
  cursor: default;
  user-select: none;
  display: inline-flex;
  align-items: center;
  justify-items: center;
  line-height: 1;
}

kbd[is="e-kbd"][data-absolute] {
  position: absolute;
  top: 0.25rem;
  right: 0.25rem;
}

/* --- Links & Buttons --- */
a[is="e-link"] {
  color: var(--e-primary);
  text-decoration: none;
  font-weight: 500;
  transition: color 0.2s ease;
  cursor: pointer;
}

a[is="e-link"][data-underlined] {
  text-decoration: underline;
}

a[is="e-link"]:hover {
  text-decoration: underline;
  filter: brightness(0.9);
}

a[is="e-link-button"] {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: var(--e-spacing-sm) var(--e-spacing-lg);
  background-color: var(--e-primary);
  color: var(--e-primary-fg);
  border-radius: var(--e-radius-2xl);
  text-decoration: none;
  font-size: var(--e-font-size-sm);
  font-weight: var(--e-font-bold);
  line-height: 1;
  border: 1px solid transparent;
  transition: background-color 0.2s ease, transform 0.1s ease, box-shadow 0.2s ease;
  cursor: pointer;
  user-select: none;
}

a[is="e-link-button"]:hover {
  filter: brightness(0.9);
  box-shadow: var(--e-shadow-md);
}

a[is="e-link-button"]:not(*[data-absolute-top]):not([is^="e-"][data-absolute-bottom], [is^="e-"][data-absolute-top]):not([is^="e-"][data-absolute-bottom]):hover {
  transform: translateY(-1px);
}

a[is="e-link-button"]:active {
  box-shadow: var(--e-shadow-sm);
}

a[is="e-link-button"]:not(*[data-absolute-top]):not([is^="e-"][data-absolute-bottom], [is^="e-"][data-absolute-top]):not([is^="e-"][data-absolute-bottom]):active {
  transform: translateY(1px);
}

a[is="e-link-button"][data-variant="outline"] {
  background-color: transparent;
  color: var(--e-fg);
  border-color: var(--e-border);
}

a[is="e-link-button"][data-variant="outline"]:hover {
  background-color: var(--e-muted-bg);
}

/* --- Headings & Content --- */
form[is="e-form"] label {
  display: flex;
  flex-direction: column;
  font-size: var(--e-font-size-xs);
  font-weight: var(--e-font-regular);
  color: var(--e-muted);
  gap: var(--e-spacing-sm);
  line-height: 1;
}

form[is="e-form"] label[data-flex-direction="row"] {
  flex-direction: row;
}

form[is="e-form"] label input,
form[is="e-form"] label select,
form[is="e-form"] label textarea {
  width: 100%;
  font-family: inherit;
  font-size: var(--e-font-size-md);
  padding: var(--e-spacing-sm) var(--e-spacing-md);
  border-radius: var(--e-radius-xl);
  border: 1px solid var(--e-border);
  background: var(--e-muted-bg);
  color: var(--e-fg);
  outline: none;
  box-sizing: border-box;

  transition:
    border-color 0.15s ease,
    box-shadow 0.15s ease,
    background 0.15s ease;
}

form[is="e-form"] label select {
  height: 2.25rem;
}

form[is="e-form"] label #calendar-week-picker {
  height: 2.25rem;
}

form[is="e-form"] label {
  width: 100%;
}

form[is="e-form"] label input:focus,
form[is="e-form"] label select:focus,
form[is="e-form"] label textarea:focus {
  border-color: var(--e-primary);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--e-primary) 20%, transparent);
}


form[is="e-form"] label:has(input[type="checkbox"]) {
  flex-direction: row;
  align-items: center;
}

form[is="e-form"] label input[type="checkbox"] {
  appearance: none; /* Remove native styling */
  width: 2rem;
  height: 2rem;
  border: 2px solid var(--e-primary);
  border-radius: var(--e-radius-sm);
  background-color: white;
  cursor: pointer;
  position: relative;
  transition: all 0.2s ease;
  flex: 0 0 auto;
}

form[is="e-form"] label input[type="checkbox"]:checked {
  background-color: var(--e-primary);
}

form[is="e-form"] label input[type="checkbox"]:after {
  content: "";
  position: absolute;
  display: none;
  left: 0.6rem;
  top: 0.25rem;
  width: 0.6rem;
  height: 1.0rem;
  border: solid white;
  border-width: 0 3px 3px 0;
  transform: rotate(45deg);
}

form[is="e-form"] label input[type="checkbox"]:after {
  display: block;
}

h1[is="e-h"], h2[is="e-h"], h3[is="e-h"], h4[is="e-h"], h5[is="e-h"], h6[is="e-h"] {
  font-family: var(--e-font-interface);
  font-weight: 600;
  line-height: 1.2;
  color: var(--e-fg);
  margin-top: 0;
  margin-bottom: var(--e-spacing-lg);
}

[is="e-h"]:has(+ [is="e-h"]),
[is="e-h"]:has(+ span[is^="e-"]) {
  margin-bottom: var(--e-spacing-xs);
}

h1[is="e-h"] { font-size: var(--e-font-h1); letter-spacing: -0.025em; font-weight: 700; }
h2[is="e-h"] { font-size: var(--e-font-h2); letter-spacing: -0.025em; font-weight: 700; }
h3[is="e-h"] { font-size: var(--e-font-h3); }
h4[is="e-h"] { font-size: var(--e-font-h4); }
h5[is="e-h"] { font-size: var(--e-font-h5); font-weight: 550; }
h6[is="e-h"] { font-size: var(--e-font-h6); font-weight: 550; }

p[is="e-p"] {
  font-family: var(--e-font-typography);
  font-size: var(--e-font-size-md);
  line-height: 1.6;
  color: var(--e-fg);
  margin-top: 0;
  margin-bottom: var(--e-spacing-xl);
}

blockquote[is="e-quote"] {
  margin: var(--e-spacing-xl) 0;
  padding: var(--e-spacing-sm) 0 var(--e-spacing-sm) var(--e-spacing-xl);
  border-left: 4px solid var(--e-border);
  font-style: italic;
  color: var(--e-muted);
}

pre[is="e-pre"] {
  font-family: var(--e-font-mono);
  font-size: var(--e-font-size-sm);
  background-color: var(--e-muted-bg);
  color: var(--e-fg);
  padding: var(--e-spacing-lg);
  border-radius: var(--e-radius-md);
  border: 1px solid var(--e-border);
  overflow-x: auto;
  margin-bottom: var(--e-spacing-xl);
}

hr[is="e-divider"] {
  border: 0;
  border-top: 1px solid var(--e-divider);
  width: 100%;
  margin: var(--e-spacing-md) 0;
}

hr[is="e-divider"][data-dashed] {
  border-top: 1px dashed var(--e-divider);
}

hr[is="e-divider"][data-primary-color] {
  border-top-color: var(--e-primary);
}

hr[is="e-divider-text"] {
  border: 0;
  border-top: 1px solid var(--e-border);
  margin: var(--e-spacing-md) 0;
  overflow: visible;
  text-align: center;
  position: relative;
}

hr[is="e-divider-text"]::after {
  content: attr(data-text);
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  background-color: var(--e-bg);
  padding: 0 var(--e-spacing-md);
  font-size: var(--e-font-size-xs);
  font-weight: 600;
  color: var(--e-muted);
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

/* --- Layout Elements (Divs) --- */
div[is="e-box"] { display: block; }
div[is="e-stack"] { display: flex; flex-direction: column; }
div[is="e-row"] { display: flex; flex-direction: row; align-items: center; }
div[is="e-grid"] {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  align-items: stretch;
}
@media(max-width: 980px) {
  div[is="e-grid"] {
    grid-template-columns: repeat(1, 1fr) !important;
  }
}
div[is="e-spacer"] { flex: 1 1 auto; }
div[is="e-card"] {
  background-color: var(--e-surface-bg);
  border: 1px solid var(--e-border);
  border-radius: var(--e-radius-lg);
  box-shadow: var(--e-shadow-sm);
  width: max-content;
}
div[is="e-panel"] {
  background-color: var(--e-surface-bg);
  border-radius: var(--e-radius-md);
  box-shadow: var(--e-shadow-lg);
  width: 100%;
  min-height: 1rem;
}
div[is="e-info"] {
  background-color: var(--e-muted-bg);
  border: 1px solid var(--e-border);
  border-radius: var(--e-radius-lg);
  padding: var(--e-spacing-md);
  width: 100%;
}
div[is="e-info"]:has(template[is="e-json-map"])::before {
  content: attr(data-loading-info);
}
div[is="e-user-avatar"] {
  text-align: center;
  display: flex;
  align-items: center;
  justify-content: center;
  color: white;
  border-radius: 50%;
  width: var(--e-img-xs);
  height: var(--e-img-xs);
  flex-shrink: 0;
  user-select: none;
  text-transform: uppercase;
  font-weight: 600;
  font-size: var(--e-font-size-lg);
}

div[data-generated-by-e-dropdown-multiselect-template] {
  position: relative;
  width: 100%;
  gap: var(--e-spacing-xs);
}
div[data-generated-by-e-dropdown-multiselect-template] input {
  width: 100%;
  box-sizing: border-box;
}
div[data-generated-by-e-dropdown-multiselect-template] div:has(span[is="e-chip"]) {
  width: 100%;
  flex-wrap: wrap; 
  gap: var(--e-spacing-xs);
  display: none;
  max-height: 12rem;
  overflow-y: auto;
}
div[data-generated-by-e-dropdown-multiselect-template] e-scrollable {
  max-height: 15rem;
  width: 100%;
  overflow-y: auto;
  border: 1px solid var(--e-border);
  border-radius: var(--e-radius-lg);
  margin-top: var(--e-spacing-xs);
  position: relative;
  z-index: 10;
  background-color: var(--e-surface-bg);
}
div[data-generated-by-e-dropdown-multiselect-template] e-scrollable [data-elm="close-link"] {
  justify-content: end;
  width: max-content;
  text-align: right;
  padding: 0.6rem 0.6rem 0 0;
  cursor: pointer;
  position: absolute;
  right: 0;
  top: 0;
  background-color: transparent;
  user-select: none;
}
div[data-generated-by-e-dropdown-multiselect-template] e-scrollable div:nth-child(2) {
  gap: var(--e-spacing-sm);
}
div[data-generated-by-e-dropdown-multiselect-template] e-scrollable [data-elm="close-link"] kbd[is="e-kbd"] {
  width: max-content;
  align-self: end;
  text-decoration: none;
}
div[data-generated-by-e-dropdown-multiselect-template] e-scrollable [data-elm="close-link"] span {
  width: max-content;
  align-self: end;
  font-size: var(--e-font-size-xs);
  text-decoration: underline;
}
div[data-generated-by-e-dropdown-multiselect-template] e-scrollable div:has(label:not([style='display: none;'])) {
  gap: var(--e-spacing-sm);
  padding: var(--e-spacing-sm) 0;
}
div[data-generated-by-e-dropdown-multiselect-template] e-scrollable div:nth-child(3) {
  width: 100%;
  font-size: var(--e-font-size-lg); 
  cursor: pointer;
  padding: var(--e-spacing-lg);
  box-sizing: border-box; 
  font-weight: bold; 
  text-align: center;
  display: none;
}
div[data-generated-by-e-dropdown-multiselect-template] e-scrollable div label {
  align-items: center;
  width: 100%;
  font-size: 1.4rem;
  font-weight: normal;
  cursor: pointer;
  padding: 0 var(--e-spacing-sm);
  box-sizing: border-box;
}


/* --- Semantic Elements --- */
header[is="e-header"] {
  position: fixed;
  top: 0;
  left: 0;
  z-index: 98;
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  height: max-content;
  box-sizing: border-box;
  background-color: var(--e-surface-bg);
  padding: var(--e-spacing-md);
  box-shadow: 0px 3px 5px 2px rgba(0, 0, 0, 0.1);
}

/* --- Semantic Elements (Continued) --- */
main[is="e-main"] {
  display: block;
  width: 100%;
  box-sizing: border-box;
}

main[is="e-main"][data-centralized] {
  max-width: var(--e-main-max-width, 64rem);
  margin-inline: auto;
  padding-inline: var(--e-main-gutter, 1rem);
}

section[is="e-section"] {
  display: block;
  width: 100%;
  box-sizing: border-box;
}

footer[is="e-footer"] {
  display: flex;
  flex-direction: row;
  align-items: center;
  width: 100%;
  box-sizing: border-box;
  background-color: var(--e-bg);
  padding: var(--e-spacing-3xl);
}

/* --- Responsive Layout Overrides --- */
@media (max-width: 980px) {
  div[is="e-row"]:not([data-keep-flex-direction-row-in-mobile]) {
    flex-direction: column;
  }

  div[is="e-grid"],
  [data-columns="1"],
  [data-columns="2"],
  [data-columns="3"] {
    grid-template-columns: 1fr;
  }
}

/* --- Button Component --- */
button[data-primary] {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: var(--e-spacing-sm) var(--e-spacing-lg);
  font-family: var(--e-font-interface);
  font-size: var(--e-font-size-md);
  font-weight: var(--e-font-bold);
  line-height: 1;
  border-radius: var(--e-radius-2xl);
  border: 1px solid transparent;
  cursor: pointer;
  user-select: none;
  transition: all 0.2s ease;
  white-space: nowrap;
  box-sizing: border-box;
}

/* Fill Variants */
button[data-primary],
button[data-primary][data-fill="solid"] {
  background-color: var(--e-primary);
  color: var(--e-primary-fg);
}

button[data-primary][data-fill="danger"] {
  background-color: var(--e-danger);
}

button[data-primary][data-fill="outlined"] {
  background-color: transparent;
  color: var(--e-primary);
  border-color: var(--e-primary);
}

/* States */
button[data-primary]:hover {
  filter: brightness(0.90);
  box-shadow: var(--e-shadow-md);
}

button[data-primary]:not([data-absolute-top]):not(*[data-absolute-bottom], [is^="e-"][data-absolute-bottom]):hover {
  transform: translateY(-1px);
}

button[data-primary][data-fill="outlined"]:hover {
  background-color: var(--e-primary);
  color: var(--e-primary-fg);
}

button[data-primary]:active {
  transform: translateY(1px);
}

button[data-primary]:not([data-absolute-top]):not(*[data-absolute-bottom], [is^="e-"][data-absolute-bottom]):active {
  transform: translateY(1px);
}

button[data-primary]:disabled,
input:disabled,
select:disabled,
textarea:disabled {
  opacity: 0.5;
  cursor: not-allowed;
  pointer-events: none;
  box-shadow: none;
  transform: none;
  filter: grayscale(0.5);
}

div[is="e-row"]:has(button[is="e-with-icon"]) {
  flex-shrink: 0;
}

button[is="e-with-icon"] {
  background: var(--e-surface-bg);
  border: 1px solid var(--e-border);
  border-radius: var(--e-radius-md);
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  box-shadow: var(--e-shadow-sm);
  padding: var(--e-spacing-sm);
  flex-shrink: 0;
  width: max-content;
}

button[is="e-with-icon"] img {
  width: var(--e-img-3xs);
  height: var(--e-img-3xs);
  flex-shrink: 0;
}

button[is="e-with-icon"]:hover {
  background: var(--e-muted-bg);
}

/* --- Form Component --- */
form[is="e-form"] {
  display: flex;
  flex-direction: column;
  box-sizing: border-box;
  width: max-content;
  height: max-content;
}

form[is="e-form"]:not([data-no-style]) {
  max-width: 100%;
  box-shadow: var(--e-shadow-lg);
  border-radius: var(--e-radius-lg);
  padding: var(--e-spacing-lg);
  background-color: var(--e-surface-bg);
}

form[is="e-form"] [is="e-h"]:not(:has(+ [is="e-h"])):not(:has(+ span[is^="e-"])) {
  margin-bottom: var(--e-spacing-md);
}

form[is="e-form"] a[is="e-link"] {
  text-align: center;
}

/* --- Fieldset & Legend --- */
fieldset[is="e-fieldset"] {
  border: 1px solid var(--e-border);
  border-radius: var(--e-radius-md);
  display: flex;
  flex-direction: column;
  min-width: 0;
  margin: 0;
  padding: 0;
}

legend[is="e-legend"] {
  font-family: var(--e-font-interface);
  font-size: var(--e-font-size-sm);
  font-weight: 600;
  color: var(--e-fg);
  padding: 0 var(--e-spacing-xs);
  margin-left: var(--e-spacing-sm);
  line-height: 1;
}

/* --- Form Validation --- */
form[is="e-form"] label [data-no-valid="true"] {
  border-color: var(--e-error);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--e-error) 20%, transparent);
}

form[is="e-form"] label [data-no-valid="true"] + span {
  margin-top: var(--e-spacing-2xs);
  width: 100%;
  border: 1px solid var(--e-error);
  background-color: color-mix(in srgb, var(--e-error) 20%, transparent);
  padding: var(--e-spacing-sm);
  color: var(--e-error);
  font-size: var(--e-font-size-xs);
  border-radius: var(--e-radius-lg);
  font-weight: bold;
}

form[is="e-form"] label:has(input[type="file"][data-no-valid="true"]) span:last-child {
  color: var(--e-error);
  font-weight: bold;
}

/* --- Form Trigger --- */
form[is="e-form"] [data-request-in-progress="true"] {
  opacity: 0.6;
}

/* --- Tooltip Component --- */
e-tooltip {
  display: inline-block;
  overflow: visible;
}

e-tooltip:hover {
  position: relative;
}

/* The Tooltip Box */
e-tooltip:hover::after {
  content: attr(data-tip);
  position: absolute;
  bottom: 125%;
  left: 50%;
  
  /* Styling using dedicated variables */
  background-color: var(--e-tooltip-bg);
  color: var(--e-tooltip-fg);
  padding: var(--e-spacing-xs) var(--e-spacing-sm);
  border-radius: var(--e-tooltip-radius);
  font-family: var(--e-font-interface);
  font-size: var(--e-tooltip-font-size);
  font-weight: 500;
  line-height: 1.2;
  white-space: nowrap;
  height: max-content;
  z-index: 2000;
  
  /* Animation/Visibility */
  opacity: 0;
  visibility: visible;
  pointer-events: none;
  box-shadow: var(--e-shadow-md);

  transform: translateX(-50%) translateY(0);
}

/* The Arrow */
e-tooltip:hover::before {
  content: "";
  position: absolute;
  bottom: 125%;
  left: 50%;
  margin-bottom: -8px;
  
  /* Arrow color matches tooltip background */
  border: 4px solid transparent;
  border-top-color: var(--e-tooltip-bg);
  
  opacity: 0;
  visibility: visible;
  pointer-events: none;
  z-index: 1000;

  transform: translateX(-50%) translateY(0);
}

e-tooltip[data-direction="to-right"]:hover::after {
  top: 50%;
  left: 100%;
  margin-bottom: 0;
  transform: translateX(8px) translateY(-50%);
}
e-tooltip[data-direction="to-right"]:hover::before {
  top: 50%;
  left: 100%;
  border-right-color: var(--e-tooltip-bg);
  border-top-color: transparent;
  transform: translateX(0px) translateY(-50%);
}

e-tooltip[data-direction="to-top-left"]:hover::after {
  transform: translateX(calc(-100% + 24px)) translateY(0);
}
e-tooltip[data-direction="to-top-left"]:hover::before {
  transform: translateX(-50%) translateY(0);
}

/* Hover States */
e-tooltip:hover::after,
e-tooltip:hover::before {
  opacity: 1;
  visibility: visible;
}

e-sidebar[data-state="open"] e-tooltip:hover::after,
e-sidebar[data-state="open"] e-tooltip:hover::before {
  opacity: 0;
  visibility: hidden;
}

@media (max-width: 980px) {
  e-tooltip:hover::after,
  e-tooltip:hover::before {
    opacity: 0;
    visibility: hidden;
  }
}

/* --- Toast Element --- */
e-toast {
  display: none; /* Hidden by default */
  position: fixed;
  z-index: 9999;
  align-items: center;
  gap: var(--e-spacing-sm);
  padding: var(--e-spacing-sm) var(--e-spacing-md);
  background-color: var(--e-surface-bg);
  color: var(--e-fg);
  border-radius: var(--e-radius-md);
  box-shadow: var(--e-shadow-lg);
  border: 1px solid var(--e-border);
  width: calc(100% - (var(--e-spacing-md) * 2));
  max-width: 400px;
  pointer-events: auto;
}

/* Visibility State */
e-toast[data-state="opening"],
e-toast[data-state="closing"] {
  display: flex;
}

/* Position Variants */
e-toast[data-position="top-left"] { top: var(--e-spacing-md); left: var(--e-spacing-md); }
e-toast[data-position="top-right"] { top: var(--e-spacing-md); right: var(--e-spacing-md); }
e-toast[data-position="bottom-left"] { bottom: var(--e-spacing-md); left: var(--e-spacing-md); }
e-toast[data-position="bottom-right"] { bottom: var(--e-spacing-md); right: var(--e-spacing-md); }

/* Animations */
e-toast[data-state="opening"] {
  animation: e-toast-in 0.3s cubic-bezier(0.16, 1, 0.3, 1) forwards;
}

e-toast[data-state="closing"] {
  animation: e-toast-out 0.2s ease-in forwards;
}

@keyframes e-toast-in {
  from { opacity: 0; }
  to { opacity: 1; }
}

@keyframes e-toast-out {
  from { opacity: 1; transform: scale(1); }
  to { opacity: 0; transform: scale(0.9); }
}

/* Type Variants */
e-toast {
  color: var(--e-fg-contrast);
}
e-toast[data-type="success"] { background: var(--e-success); }
e-toast[data-type="error"] { background: var(--e-error); }
e-toast[data-type="warning"] { background: #f59e0b; }
e-toast[data-type="info"] { background: #3b82f6; }

/* Native Element Styling via > */
e-toast > img {
  width: var(--e-img-3xs);
  height: var(--e-img-3xs);
  flex-shrink: 0;
  object-fit: contain;
}

e-toast > div {
  flex-grow: 1;
  font-family: var(--e-font-interface);
  font-size: var(--e-font-size-sm);
  line-height: 1.4;
}

e-toast > button {
  flex-shrink: 0;
  appearance: none;
  background: none;
  border: none;
  cursor: pointer;
  padding: var(--e-spacing-3xs);
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: var(--e-radius-sm);
  transition: background-color 0.2s;
}

e-toast > button > img {
  width: var(--e-img-3xs);
  height: var(--e-img-3xs);
  opacity: 0.7;
}

e-toast > button:hover > img {
  opacity: 1.0;
}

e-toast a {
  color: var(--e-light);
  text-decoration: underline;
}

/* --- Tabs --- */
e-tabs {
  display: flex;
  flex-direction: column;
  width: 100%;
}

e-tabs > nav {
  display: flex;
  gap: var(--e-spacing-md);
  flex-wrap: wrap;
  overflow-x: auto;
  scrollbar-width: none;
  padding-top: var(--e-spacing-sm);
  padding-bottom: var(--e-spacing-sm);
  padding-left: var(--e-spacing-3xs);
}

e-tabs > nav::-webkit-scrollbar {
  display: none;
}

e-tabs > nav > button {
  appearance: none;
  background: none;
  border: 1px solid var(--e-border);
  font-family: var(--e-font-interface);
  font-size: var(--e-font-size-xs);
  font-weight: 500;
  color: var(--e-muted);
  cursor: pointer;
  white-space: nowrap;
  transition: color 0.2s, border-color 0.2s;
  position: relative;
  padding: var(--e-spacing-sm);
  border-radius: var(--e-spacing-lg);
  box-shadow: var(--e-shadow-md);
}

e-tabs > nav > button:hover {
  color: var(--e-fg);
  border: 1px solid var(--e-primary);
  background-color: var(--e-primary-transparent-accent-bg);
}

e-tabs > nav > button[data-active="true"] {
  border: 1px solid var(--e-primary);
  background-color: var(--e-primary-transparent-accent-bg);
  font-weight: 700;
}

dialog[is="e-dialog"] e-tabs nav {
  background-color: var(--e-surface-bg);
  box-shadow: 0px +1px 5px 2px rgba(0, 0, 0, 0.15);
  border-top-left-radius: var(--e-radius-md);
  border-top-right-radius: var(--e-radius-md);
  padding: var(--e-spacing-lg);
  gap: var(--e-spacing-md);
}

e-tab {
  display: none;
  width: 100%;
}

e-tab[data-active="true"] {
  display: block;
  animation: e-tab-fade 0.2s ease-in;
}

@keyframes e-tab-fade {
  from { opacity: 0; transform: translateY(4px); }
  to { opacity: 1; transform: translateY(0); }
}

/* --- Sidebar --- */
e-sidebar {
  position: fixed;
  top: 0;
  bottom: 0;
  z-index: 100;
  background-color: var(--e-surface-bg);
  box-shadow: var(--e-shadow-lg);
  width: var(--e-sidebar-collapsed);
  transition: width var(--e-sidebar-transition), transform var(--e-sidebar-transition);
  overflow: visible;
  display: flex;
  flex-direction: column;
  padding: 0 var(--e-spacing-sm) var(--e-spacing-xl) var(--e-spacing-sm);
}

/* Side Alignment */
e-sidebar[data-side="left"] {
  left: 0;
}
e-sidebar[data-side="right"] {
  right: 0;
}

/* Open State (Desktop Hover) */
e-sidebar[data-state="open"] {
  width: var(--e-sidebar-expanded);
}

e-sidebar[data-state="open"] header img {
  max-height: var(--e-img-xl);
}

slot:has(e-sidebar[data-side="left"]) + main {
  transform: translateX(var(--e-sidebar-collapsed));
  transition: width var(--e-sidebar-transition), transform var(--e-sidebar-transition);
  width: calc(100% - var(--e-sidebar-collapsed));
}

@media (min-width: 980px) {
  slot:has(e-sidebar[data-side="left"][data-state="open"]) + main {
    transform: translateX(var(--e-sidebar-expanded));
    width: calc(100% - var(--e-sidebar-expanded));
  }
}

/* Link Styling inside Sidebar */
e-sidebar nav {
  display: flex;
  flex-direction: column;
  align-items: center;
  width: 100%;
  gap: var(--e-spacing-md);
  box-sizing: border-box;
  list-style: none;
  padding: 0;
  margin: 0;
  overflow-y: auto;
  scrollbar-width: none;
  padding-bottom: 1px;
}

e-sidebar nav:has(e-tooltip:hover) {
  overflow-y: visible;
}

e-sidebar nav hr[is="e-divider"] {
  width: 90%;
}

e-sidebar nav::-webkit-scrollbar {
  display: none; /* Chrome, Safari and Opera */
}

/* Styled Scrollbar Variant */
e-sidebar[data-show-scrollbar] {
  scrollbar-width: thin;
  scrollbar-color: var(--e-border) transparent;
}

e-sidebar nav a {
  display: flex;
  align-items: center;
  gap: var(--e-spacing-md);
  width: 100%;
  font-size: var(--e-font-size-xs);
  padding: var(--e-spacing-sm);
  border-radius: var(--e-radius-md);
  text-decoration: none;
  color: var(--e-fg);
  white-space: nowrap;
  transition: background-color 0.2s;
  border: 1px solid transparent;
  cursor: pointer;
}

e-sidebar a[data-selected="true"] {
  border: 1px solid var(--e-primary);
  background: var(--e-primary-transparent-accent-bg);
}

e-sidebar a:hover {
  background: var(--e-primary-transparent-accent-bg);
  text-decoration: none;
  border: 1px solid var(--e-primary);
}

/* Icon Handling */
e-sidebar a > img,
e-sidebar a > svg {
  width: var(--e-img-3xs);
  height: var(--e-img-3xs);
  flex-shrink: 0;
}

e-sidebar[data-state="closed"] a {
  justify-content: center;
}

/* Hide text when collapsed on desktop */
e-sidebar[data-state="closed"] a > span {
  display: none;
}

e-sidebar footer {
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: max-content;
  background: var(--e-surface-bg);
  padding: var(--e-spacing-sm);
  box-shadow: 0px -1px 5px 2px rgba(0, 0, 0, 0.1);
}

e-sidebar header {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: max-content;
  background: var(--e-surface-bg);
  padding: var(--e-spacing-sm);
  box-shadow: 0px +1px 5px 2px rgba(0, 0, 0, 0.1);
  display: flex;
  align-items: center;
  justify-content: center;
}

e-sidebar[data-state="closed"] > footer > div[is="e-row"] {
  justify-content: center;
}

e-sidebar[data-state="closed"] [data-hide-on-sidebar-closed] {
  display: none;
}
e-sidebar[data-state="open"] [data-hide-on-sidebar-open] {
  display: none;
}

e-sidebar footer div[is="e-user-avatar"] {
  width: var(--e-img-sm);
  height: var(--e-img-sm);
}

e-sidebar footer div[is="e-row"] {
  justify-content: space-between;
  align-items: center;
}

e-sidebar footer button[is="e-with-icon"] {
  padding: var(--e-spacing-xs);
}

e-sidebar footer button[is="e-with-icon"] img {
  width: var(--e-img-xs);
  height: var(--e-img-xs);
}

/* --- Mobile Logic --- */
@media (max-width: 980px) {
  e-sidebar {
    width: var(--e-sidebar-expanded);
    transform: translateX(-100%);
  }

  e-sidebar[data-state="open"] {
    transform: translateX(0);
  }

  e-sidebar[data-side="right"] { transform: translateX(100%); }

  slot:has(e-sidebar[data-side="left"]) + main {
    transform: translateX(0);
    width: auto;
  }

  e-sidebar footer div[is="e-row"] {
    flex-direction: row;
  }

  body:has(e-sidebar[data-state="close"]) div[is="overlay"] {
    display: none;
  }

  body:has(e-sidebar[data-state="open"]) div[is="overlay"] {
    height: 100%;
    width: 100%;
    position: fixed;
    backdrop-filter: blur(2px);
    z-index: 99;
    inset: 0px;
    background: rgba(10, 14, 22, 0.45);
  }

  button[is="e-sidebar-mobile-toggle"][data-corner="left"] { left: var(--e-spacing-md); }
  button[is="e-sidebar-mobile-toggle"][data-corner="right"] { right: var(--e-spacing-md); }

  button[data-primary] {
    align-self: center;
    width: 100%;
  }
}

/* Hide toggle on desktop */
@media (min-width: 981px) {
  button[is="e-sidebar-mobile-toggle"] { display: none; }
  header[is="e-header"] { display: none; }
}

@media (max-width: 980px) {
  kbd[is="e-kbd"] { display: none }
  [data-hide-in-mobile] { display: none }
}

@media (max-width: 640px) {
  slot:has(header[is="e-header"] + e-sidebar[data-side="left"]) + main {
    transform: translateY(4.5rem);
    width: 100%;
  }
}

@media (min-width: 641px) and (max-width: 980px) {
  slot:has(header[is="e-header"] + e-sidebar[data-side="left"]) + main {
    transform: translateY(5.5rem);
    width: 100%;
  }
}

/* --- Tables --- */

table[is="e-table"] {
  width: 100%;
  border-collapse: collapse;
  border-spacing: 0;
  box-sizing: border-box;
  text-align: left;
  font-family: var(--e-font-interface);
  font-size: var(--e-font-size-sm);
  border-radius: var(--e-radius-md);
  overflow: visible;
}

form e-scrollable:has(table[is="e-table"]) {
  border-radius: var(--e-radius-md);
  border: 1px solid var(--e-border);
}

table[is="e-table"] > thead > tr > th {
  padding: var(--e-spacing-md);
  color: var(--e-muted);
  font-weight: 600;
  font-size: var(--e-font-size-xs);
  background-color: var(--e-muted-bg);
  border-bottom: 1px solid var(--e-divider);
  width: max-content;
}

table[is="e-table"] thead tr th:first-child,
table[is="e-table"] tbody tr td:first-child {
  border-top-left-radius: var(--e-radius-md);
}

table[is="e-table"] thead tr th:last-child,
table[is="e-table"] tbody tr td:last-child {
  border-top-right-radius: var(--e-radius-md);
}

table[is="e-table"] > tbody {
  font-size: var(--e-font-size-sm);
  background-color: var(--e-surface-bg);
  border-radius: var(--e-radius-md);
}

table[is="e-table"] > tbody > tr {
  transition: background-color 0.2s;
  border-bottom: 1pt solid var(--e-divider);
}

table[is="e-table"] tbody tr:last-child > td:first-child {
  border-bottom-left-radius: var(--e-radius-md);
}


table[is="e-table"] tbody tr:last-child > td:last-child {
  border-bottom-right-radius: var(--e-radius-md);
}

table[is="e-table"][data-hover="true"] > tbody > tr:hover {
  background-color: var(--e-muted);
}

table[is="e-table"] > tbody > tr > td {
  padding: var(--e-spacing-md);
  vertical-align: middle;
  color: var(--e-fg);
  white-space: nowrap;
}

/* Allow specific cells to wrap if needed */
table[is="e-table"] > tbody > tr > td[data-flex-wrap="true"] {
  white-space: normal;
  min-width: 200px;
}

/* Zebra Striping Variant */
table[is="e-table"][data-zebra="true"] > tbody > tr:nth-child(even) {
  background-color: rgba(0, 0, 0, 0.02);
}

/* Content Helpers */
table[is="e-table"] td img {
  display: block;
  border-radius: var(--e-radius-full);
  object-fit: cover;
}

/* --- List Container --- */
ul[is="e-list"], 
ol[is="e-list"] {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
}

/* List Types */
ul[is="e-list"][data-type="bullet"] {
  list-style: disc;
  padding-left: var(--e-spacing-lg);
}

ol[is="e-list"][data-type="number"] {
  list-style: decimal;
  padding-left: var(--e-spacing-lg);
}

/* Divided Variant */
ul[is="e-list"][data-divided="true"] li[is="e-list-item"]:not(:last-child),
ol[is="e-list"][data-divided="true"] li[is="e-list-item"]:not(:last-child) {
  border-bottom: 1px solid var(--e-border);
}

/* --- List Item --- */
li[is="e-list-item"] {
  display: flex;
  align-items: center;
  gap: var(--e-spacing-sm);
  padding: var(--e-spacing-xs) 0;
  color: var(--e-fg);
  font-size: var(--e-font-size-sm);
}

/* Interactive Variant */
li[is="e-list-item"][data-interactive="true"] {
  cursor: pointer;
  padding: var(--e-spacing-sm) var(--e-spacing-md);
  border-radius: var(--e-radius-md);
  transition: background-color 0.2s, transform 0.1s;
}

li[is="e-list-item"][data-interactive="true"]:hover {
  background-color: var(--e-muted);
}

li[is="e-list-item"][data-interactive="true"]:active {
  transform: scale(0.99);
}

/* --- Dialog --- */
dialog[is="e-dialog"] {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  margin: 0;
  border: none;
  border-radius: var(--e-radius-lg);
  padding: 0;
  background: var(--e-surface-bg);
  color: var(--e-fg);
  width: 90%;
  max-width: 90%;
  max-height: 90%;
  min-height: 4rem;
  box-shadow: var(--e-shadow-lg);
  z-index: 99999;
  scrollbar-width: none;
  -ms-overflow-style: none;
  overflow: auto;
}

dialog[is="e-dialog"] iframe {
  border: none;
  width: 100%;
  height: 100%;
}

dialog[is="e-dialog"]::-webkit-scrollbar {
  display: none;
}

dialog[is="e-dialog"]::backdrop {
  background: rgba(0, 0, 0, 0.45);
  backdrop-filter: blur(2px);
}

/* Internal Wrapper */
dialog[is="e-dialog"] > div {
  font-size: var(--e-font-size-sm);
  line-height: 1.6;
  position: relative;
  box-sizing: border-box;
  height: max-content;
  max-height: max-content;
}

dialog[is="e-dialog"]:has(iframe) {
  height: 90%;
}

dialog[is="e-dialog"]:has(iframe) > div {
  height: 100%;
}

/* Close Button */
dialog[is="e-dialog"] [is="e-close-icon"] {
  position: absolute;
  top: calc(1 * var(--e-spacing-md));
  right: calc(1 * var(--e-spacing-md));
  width: var(--e-img-xs);
  height: var(--e-img-xs);
  box-sizing: border-box;
  background-color: var(--e-surface-bg);
  border-radius: var(--e-radius-lg);
  border: 1px solid var(--e-border);
  cursor: pointer;
  font-size: 1.5rem;
  color: var(--e-muted);
  line-height: 1;
  user-select: none;
  transition: color 0.2s ease;
  z-index: 10;
  display: flex;
  align-items: center;
  justify-content: center;
}

dialog[is="e-dialog"] [is="e-close-icon"]:hover {
  background-color: var(--e-muted-bg);
}

dialog[is="e-dialog"] [is="e-close-icon"] img {
  /*width: 100%;*/
}

dialog[is="e-dialog"] [data-close]:hover {
  color: var(--e-fg);
}

dialog[is="e-dialog"] h1:first-of-type,
dialog[is="e-dialog"] h2:first-of-type,
dialog[is="e-dialog"] h3:first-of-type {
  margin-top: 0;
}

dialog[is="e-dialog"][data-size="full"] {
  width: 90%;
}
dialog[is="e-dialog"][data-size="small"] {
  width: var(--e-width-sm);
}
dialog[is="e-dialog"][data-size="normal"] {
  width: var(--e-width-xs);
}
dialog[is="e-dialog"][data-size="large"] {
  width: var(--e-width-lg);
}

dialog[is="e-dialog"] e-toast {
  /*position: absolute;*/
}

/* --- Scrollable container ---*/
e-scrollable {
  display: block;
  max-width: 100%;
  overflow: auto;
  box-sizing: border-box;
  /* Hide scrollbars by default */
  -ms-overflow-style: none;  /* IE and Edge */
  scrollbar-width: none;     /* Firefox */
}

e-scrollable::-webkit-scrollbar {
  display: none; /* Chrome, Safari and Opera */
}

/* Styled Scrollbar Variant */
e-scrollable[data-show-scrollbar] {
  scrollbar-width: thin;
  scrollbar-color: var(--e-border) transparent;
}

e-scrollable[data-show-scrollbar]::-webkit-scrollbar {
  display: block;
  width: 6px;
  height: 6px;
}

e-scrollable[data-show-scrollbar]::-webkit-scrollbar-track {
  background: transparent;
}

e-scrollable[data-show-scrollbar]::-webkit-scrollbar-thumb {
  background-color: var(--e-border);
  border-radius: var(--e-radius-full);
}

e-scrollable[data-show-scrollbar]::-webkit-scrollbar-thumb:hover {
  background-color: var(--e-muted);
}

e-json {
  display: none;
}

