@layer tokens, base, objects, components, aliases, pages, utilities;

@layer tokens {
  :root {
    --jb-primary: #ff3b3b;
    --jb-primary-dark: #e92e2e;
    --jb-ink: #121212;
    --jb-surface: #ffffff;
    --jb-surface-alt: #f5f5f5;
    --jb-surface-soft: #fafafa;
    --jb-border: #e7e7ea;
    --jb-text: #121212;
    --jb-reverse-text: #fff;
    --jb-reverse-text-hover: #000000;
    --jb-text-muted: #7b7b87;
    --jb-success: #13b36b;

    --jb-text-rgb: 18, 18, 18;

    --jb-surface-rgb: 255, 255, 255;
    --jb-surface-alt-rgb: 245, 245, 245;
    --jb-surface-soft-rgb: 250, 250, 250;

    --jb-surface-reverse-rgb: 18, 18, 18;
    --jb-surface-reverse-alt-rgb: 30, 30, 30;
    --jb-surface-reverse-soft-rgb: 66, 66, 66;

    --jb-shadow: 0 12px 40px rgba(10, 13, 18, 0.08);
    --jb-shadow-soft: 0 8px 24px rgba(10, 13, 18, 0.06);
    --jb-shadow-hero: 0 28px 70px rgba(14, 17, 22, 0.18);

    --jb-radius-sm: 12px;
    --jb-radius-md: 18px;
    --jb-radius-lg: 28px;
    --jb-radius-xl: 36px;
    --jb-radius-pill: 999px;

    --jb-container: 1360px;

    --jb-space-1: 8px;
    --jb-space-2: 10px;
    --jb-space-3: 12px;
    --jb-space-4: 14px;
    --jb-space-5: 16px;
    --jb-space-6: 18px;
    --jb-space-7: 20px;
    --jb-space-8: 24px;
    --jb-space-9: 28px;
    --jb-space-10: 32px;
    --jb-space-11: 40px;
    --jb-space-12: 48px;
    --jb-space-section: clamp(72px, 8vw, 124px);
    --jb-space-grid: clamp(24px, 2.8vw, 38px);
    --jb-space-card: clamp(24px, 2.3vw, 34px);

    --jb-topbar-height: 92px;
    --jb-button-height: 52px;
    --jb-pill-height: 42px;
    --jb-panel-padding: clamp(30px, 3vw, 42px);

    --jb-gradient-brand: linear-gradient(135deg, var(--jb-primary), var(--jb-primary-dark));
    --jb-gradient-hero:
      radial-gradient(circle at top right, rgba(255, 255, 255, 0.16), transparent 32%),
      linear-gradient(135deg, #15161b 0%, #232631 100%);
  }

  [data-theme='dark'] {
    --jb-ink: #0f1115;
    --jb-surface: #161920;
    --jb-surface-alt: #0f1115;
    --jb-surface-soft: #1d212a;
    --jb-border: #292f3a;
    --jb-text: #f7f7fb;
    --jb-text-muted: #989fb0;
    --jb-shadow: 0 16px 50px rgba(0, 0, 0, 0.28);
    --jb-shadow-soft: 0 10px 28px rgba(0, 0, 0, 0.2);
    --jb-shadow-hero: 0 28px 70px rgba(0, 0, 0, 0.35);

    --jb-surface-rgb: 22, 25, 32;
    --jb-surface-alt-rgb: 15, 17, 21;
    --jb-surface-soft-rgb: 29, 33, 42;

    --jb-surface-reverse-rgb: 255, 255, 255;
    --jb-surface-reverse-alt-rgb: 245, 245, 245;
    --jb-surface-reverse-soft-rgb: 250, 250, 250;

    --jb-text-rgb: 247, 247, 251;
  }
}

@layer base {
  * { box-sizing: border-box; }

  html { scroll-behavior: smooth; }

  body {
    margin: 0;
    font-family: 'Poppins', system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
    background: var(--jb-surface-alt);
    color: var(--jb-text);
    text-rendering: optimizeLegibility;
  }

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

  img {
    display: block;
    max-width: 100%;
  }

  button,
  input,
  select,
  textarea {
    font: inherit;
  }

  [hidden] {
    display: none !important;
  }
}

@layer objects {
  .jb-container {
    width: min(calc(100% - 56px), var(--jb-container));
    margin-inline: auto;
  }

  .jb-stack {
    display: grid;
    gap: var(--jb-stack-gap, var(--jb-space-8));
  }

  .jb-cluster {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: var(--jb-cluster-gap, var(--jb-space-3));
  }

  .jb-row {
  --jb-row-gap: var(--jb-space-6) !important;
  display: flex;
  flex-wrap: wrap;
  gap: var(--jb-row-gap);
  align-items: flex-start;
}

.jb-row > * {
  min-width: 0;
}

.jb-row--nowrap {
  flex-wrap: nowrap;
}

.jb-row--center {
  align-items: center;
}

.jb-row--end {
  align-items: flex-end;
}

.jb-row--between {
  justify-content: space-between;
}

.jb-row--center-x {
  justify-content: center;
}

.jb-row--end-x {
  justify-content: flex-end;
}

.jb-col {
  flex: 1 1 0;
  min-width: 0;
}

.jb-col-auto {
  flex: 0 0 auto;
  width: auto;
  min-width: 0;
}

.jb-col-1  { flex: 0 0 calc((100% - (11 * var(--jb-row-gap))) / 12); max-width: calc((100% - (11 * var(--jb-row-gap))) / 12); }
.jb-col-2  { flex: 0 0 calc((((100% - (11 * var(--jb-row-gap))) / 12) * 2) + (1 * var(--jb-row-gap))); max-width: calc((((100% - (11 * var(--jb-row-gap))) / 12) * 2) + (1 * var(--jb-row-gap))); }
.jb-col-3  { flex: 0 0 calc((((100% - (11 * var(--jb-row-gap))) / 12) * 3) + (2 * var(--jb-row-gap))); max-width: calc((((100% - (11 * var(--jb-row-gap))) / 12) * 3) + (2 * var(--jb-row-gap))); }
.jb-col-4  { flex: 0 0 calc((((100% - (11 * var(--jb-row-gap))) / 12) * 4) + (3 * var(--jb-row-gap))); max-width: calc((((100% - (11 * var(--jb-row-gap))) / 12) * 4) + (3 * var(--jb-row-gap))); }
.jb-col-5  { flex: 0 0 calc((((100% - (11 * var(--jb-row-gap))) / 12) * 5) + (4 * var(--jb-row-gap))); max-width: calc((((100% - (11 * var(--jb-row-gap))) / 12) * 5) + (4 * var(--jb-row-gap))); }
.jb-col-6  { flex: 0 0 calc((((100% - (11 * var(--jb-row-gap))) / 12) * 6) + (5 * var(--jb-row-gap))); max-width: calc((((100% - (11 * var(--jb-row-gap))) / 12) * 6) + (5 * var(--jb-row-gap))); }
.jb-col-7  { flex: 0 0 calc((((100% - (11 * var(--jb-row-gap))) / 12) * 7) + (6 * var(--jb-row-gap))); max-width: calc((((100% - (11 * var(--jb-row-gap))) / 12) * 7) + (6 * var(--jb-row-gap))); }
.jb-col-8  { flex: 0 0 calc((((100% - (11 * var(--jb-row-gap))) / 12) * 8) + (7 * var(--jb-row-gap))); max-width: calc((((100% - (11 * var(--jb-row-gap))) / 12) * 8) + (7 * var(--jb-row-gap))); }
.jb-col-9  { flex: 0 0 calc((((100% - (11 * var(--jb-row-gap))) / 12) * 9) + (8 * var(--jb-row-gap))); max-width: calc((((100% - (11 * var(--jb-row-gap))) / 12) * 9) + (8 * var(--jb-row-gap))); }
.jb-col-10 { flex: 0 0 calc((((100% - (11 * var(--jb-row-gap))) / 12) * 10) + (9 * var(--jb-row-gap))); max-width: calc((((100% - (11 * var(--jb-row-gap))) / 12) * 10) + (9 * var(--jb-row-gap))); }
.jb-col-11 { flex: 0 0 calc((((100% - (11 * var(--jb-row-gap))) / 12) * 11) + (10 * var(--jb-row-gap))); max-width: calc((((100% - (11 * var(--jb-row-gap))) / 12) * 11) + (10 * var(--jb-row-gap))); }
.jb-col-12 { flex: 0 0 100%; max-width: 100%; }

@media (max-width: 768px) {
  .jb-row > [class*="jb-col-"],
  .jb-row > .jb-col,
  .jb-row > .jb-col-auto {
    flex: 0 0 100%;
    max-width: 100%;
    width: 100%;
  }

  .jb-row--nowrap {
    flex-wrap: wrap;
  }
}

  .jb-grid {
    display: grid;
    gap: var(--jb-grid-gap, var(--jb-space-grid));
  }

  .jb-grid--2 {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .jb-grid--3 {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .jb-grid--4 {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }

  .jb-sidebar {
    display: grid;
    grid-template-columns: minmax(0, 1.1fr) minmax(320px, .9fr);
    gap: clamp(24px, 3vw, 40px);
    align-items: start;
  }

  .jb-sidebar--hero {
    grid-template-columns: minmax(0, 1.25fr) minmax(360px, 500px);
    align-items: center;
    gap: clamp(34px, 5vw, 72px);
  }

  .jb-surface-blur {
    backdrop-filter: blur(18px);
  }

  @media (max-width: 1100px) {
    .jb-container {
      width: min(calc(100% - 40px), var(--jb-container));
    }

    .jb-grid--2,
    .jb-grid--3,
    .jb-grid--4,
    .jb-sidebar,
    .jb-sidebar--hero {
      grid-template-columns: 1fr;
    }
  }

  @media (max-width: 768px) {
    .jb-container {
      width: min(calc(100% - 24px), var(--jb-container));
    }
  }
}

@layer components {
  .jb-section {
    padding: var(--jb-space-section) 0;
  }

  .jb-section-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--jb-space-6);
    margin-bottom: var(--jb-space-9);
  }

  .jb-section-title {
    margin: 0;
    font-size: clamp(1.8rem, 3vw, 2.45rem);
    line-height: 1.05;
    letter-spacing: -0.04em;
  }

  .jb-section-link {
    color: var(--jb-primary);
    font-weight: 800;
  }

  .jb-section__link {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    color: var(--jb-primary);
    font-weight: 800;
    transition: gap 0.22s ease, opacity 0.22s ease;
    }

    .jb-section__link::after {
    content: 'chevron_right';
    font-family: 'Material Symbols Rounded';
    font-weight: normal;
    font-style: normal;
    font-size: 20px;
    line-height: 1;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 18px;
    height: 18px;
    transform: translateX(0);
    transition: transform 0.22s ease;
    font-variation-settings:
        'FILL' 0,
        'wght' 400,
        'GRAD' 0,
        'opsz' 24;
    }

    .jb-section__link:hover {
    gap: 10px;
    }

    .jb-section__link:hover::after {
    transform: translateX(2px);
    }

  .jb-card {
    position: relative;
    overflow: hidden;
    padding: var(--jb-card-padding, var(--jb-space-card));
    border-radius: var(--jb-card-radius, 32px);
    background: var(--jb-surface);
    border: 1px solid var(--jb-border);
    box-shadow: var(--jb-shadow-soft);
  }

  .jb-card--hero {
    background: var(--jb-gradient-hero);
    color: #fff;
    box-shadow: var(--jb-shadow-hero);
  }

  .jb-card--hero::before,
  .jb-card--hero::after {
    content: '';
    position: absolute;
    inset: auto;
    border-radius: 999px;
    background: rgba(255, 59, 59, 0.18);
    filter: blur(10px);
  }

  .jb-card--hero::before {
    width: 280px;
    height: 280px;
    right: -40px;
    top: -60px;
  }

  .jb-card--hero::after {
    width: 180px;
    height: 180px;
    left: -40px;
    bottom: -30px;
  }

  .jb-card-header,
  .jb-card-footer {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: var(--jb-space-6);
  }

  .jb-card-title {
    margin: 0;
    font-size: 1.42rem;
    line-height: 1.18;
    letter-spacing: -0.03em;
  }

  .jb-meta {
    color: var(--jb-text-muted);
    line-height: 1.65;
  }

  .jb-pill {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: var(--jb-space-2);
    min-height: var(--jb-pill-height);
    padding: 10px 16px;
    border-radius: var(--jb-radius-pill);
    border: 1px solid var(--jb-border);
    background: var(--jb-surface);
    color: var(--jb-text);
    font-size: 0.92rem;
    font-weight: 700;
    box-shadow: var(--jb-shadow-soft);
  }

  .jb-pill--soft {
    background: var(--jb-surface-soft);
    box-shadow: none;
  }

  .jb-pill--primary {
    color: var(--jb-primary);
    background: color-mix(in srgb, var(--jb-primary) 10%, var(--jb-surface));
    border-color: color-mix(in srgb, var(--jb-primary) 20%, var(--jb-border));
  }

  .jb-pill--on-dark {
    color: #fff;
    background: rgba(255, 255, 255, 0.1);
    border-color: rgba(255, 255, 255, 0.12);
    box-shadow: none;
  }

  .jb-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: var(--jb-space-2);
    min-height: 56px;
    padding: 0 24px;
    border: 0;
    border-radius: 18px;
    background: var(--jb-gradient-brand);
    color: #fff;
    font-weight: 800;
    box-shadow: 0 16px 30px rgba(255, 59, 59, 0.24);
    cursor: pointer;
  }

  .jb-button--ghost {
    background: transparent;
    color: var(--jb-text);
    border: 1px solid var(--jb-border);
    box-shadow: none;
  }

  .jb-button--ghost-on-dark {
    background: transparent;
    color: var(--jb-reverse-text);
    border: 1px solid var(--jb-border);
    box-shadow: none;
  }

  .jb-button--icon {
    width: 46px;
    min-width: 46px;
    min-height: 46px;
    padding: 0;
    border-radius: 999px;
    background: var(--jb-surface);
    color: var(--jb-text);
    border: 1px solid var(--jb-border);
    box-shadow: var(--jb-shadow-soft);
  }

  .jb-brand {
    display: inline-flex;
    align-items: center;
    gap: var(--jb-space-4);
  }

  .jb-brand-logo {
    width: 52px;
    height: 52px;
    border-radius: 18px;
    object-fit: cover;
    box-shadow: var(--jb-shadow-soft);
  }

  .jb-brand-wordmark {
    font-size: 1.9rem;
    font-weight: 800;
    line-height: 1;
    letter-spacing: -0.03em;
  }

  .jb-brand-wordmark .job { color: var(--jb-text); }
  .jb-brand-wordmark .bridge { color: var(--jb-primary); }

  .jb-nav {
    display: flex;
    align-items: center;
    gap: 10px;
  }

    .jb-icon-button {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        width: 46px;
        min-width: 46px;
        height: 46px;
        min-height: 46px;
        padding: 0;
        border-radius: 999px;
        line-height: 1;
    }

    .jb-icon-button .material-symbols-rounded {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        font-size: 22px;
        line-height: 1;
    }

  .jb-search {
    display: flex;
    align-items: center;
    gap: 14px;
    min-height: 70px;
    padding: 12px 12px 12px 20px;
    border-radius: 22px;
    background: rgba(255, 255, 255, 0.98);
    color: var(--jb-text);
  }

  .jb-search-input {
    flex: 1;
    border: 0;
    outline: 0;
    background: transparent;
    color: var(--jb-text);
  }

  .jb-search-input::placeholder {
    color: var(--jb-text-muted);
  }

  .jb-metric {
    padding: 28px;
    border-radius: 30px;
    background: var(--jb-surface);
    border: 1px solid var(--jb-border);
    box-shadow: var(--jb-shadow-soft);
  }

  .jb-metric-label,
  .jb-label {
    display: block;
    margin-bottom: 10px;
    color: var(--jb-text-muted);
  }

  .jb-metric-value,
  .jb-price {
    display: block;
    font-size: clamp(1.6rem, 2vw, 2.2rem);
    font-weight: 800;
    color: var(--jb-primary);
    line-height: 1;
  }

  .jb-metric-sub {
    display: block;
    margin-top: 10px;
    color: var(--jb-text-muted);
  }

  .jb-list,
  .jb-facts {
    display: grid;
    gap: 18px;
  }

  .jb-list-item,
  .jb-fact-item {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    padding: 18px 0;
    border-bottom: 1px solid color-mix(in srgb, var(--jb-border) 90%, transparent);
  }

  .jb-list-item:last-child,
  .jb-fact-item:last-child {
    padding-bottom: 0;
    border-bottom: 0;
  }

  .jb-value {
    font-weight: 700;
  }

  .jb-benefits {
    display: flex;
    flex-wrap: wrap;
    gap: 16px 22px;
  }

  .jb-benefit {
    display: inline-flex;
    align-items: center;
    gap: 8px;
  }

  .jb-benefit-dot {
    width: 10px;
    height: 10px;
    border-radius: 999px;
    background: var(--jb-success);
    box-shadow: 0 0 0 6px color-mix(in srgb, var(--jb-success) 14%, transparent);
  }

  .jb-floating-apply {
    position: sticky;
    bottom: 24px;
    z-index: 35;
    margin-top: 30px;
  }

  .jb-floating-apply-inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 18px;
    padding: 18px 20px;
    border-radius: 26px;
    background: color-mix(in srgb, var(--jb-surface) 92%, transparent);
    border: 1px solid var(--jb-border);
    box-shadow: var(--jb-shadow);
    backdrop-filter: blur(18px);
  }

  .jb-locale-switcher {
    position: relative;
    display: inline-flex;
    align-items: center;
  }

  .jb-locale-trigger {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    min-height: 46px;
    padding: 0 16px;
    cursor: pointer;
    user-select: none;
  }

  .jb-locale-panel {
    position: absolute;
    top: calc(100% + 10px);
    right: 0;
    z-index: 60;
    min-width: 170px;
    padding: 10px;
    display: grid;
    gap: 8px;
    border-radius: 20px;
    background: var(--jb-surface);
    border: 1px solid var(--jb-border);
    box-shadow: var(--jb-shadow-soft);
  }

  .jb-locale-panel[hidden] { display: none !important; }

  .jb-locale-option {
    display: flex;
    align-items: center;
    justify-content: space-between;
    min-height: 46px;
    padding: 0 14px;
    border-radius: 14px;
    color: var(--jb-text);
    transition: background .18s ease, color .18s ease, transform .18s ease;
  }

  .jb-locale-option:hover {
    background: var(--jb-surface-soft);
    transform: translateY(-1px);
  }

  .jb-locale-option.is-active {
    background: color-mix(in srgb, var(--jb-primary) 10%, var(--jb-surface));
    color: var(--jb-primary);
    font-weight: 800;
  }

  @media (max-width: 768px) {
    .jb-nav { display: none; }
    .jb-button,
    .jb-search button { width: 100%; }
    .jb-search { flex-wrap: wrap; padding: 14px; }
    .jb-floating-apply-inner { flex-direction: column; align-items: stretch; }
    .jb-locale-panel { right: auto; left: 0; }
  }
}

@layer aliases {
  :where(.jb-container, .container) {
    width: min(calc(100% - 56px), var(--jb-container));
    margin-inline: auto;
  }

  :where(.jb-section, .jb-section) {
    padding: var(--jb-space-section) 0;
  }

  :where(.jb-section-header, .jb-section__header) {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--jb-space-6);
    margin-bottom: 28px;
  }

  :where(.jb-section-title, .jb-section__title) {
    margin: 0;
    font-size: clamp(1.8rem, 3vw, 2.45rem);
    line-height: 1.05;
    letter-spacing: -0.04em;
  }

  :where(.jb-section-link, .jb-section__link) {
    color: var(--jb-primary);
    font-weight: 800;
  }

  :where(.jb-card, .jb-card, .jb-panel, .jb-metric, .jb-stat-card) {
    position: relative;
    overflow: hidden;
    padding: var(--jb-card-padding, var(--jb-space-card));
    border-radius: var(--jb-card-radius, 32px);
    background: var(--jb-surface);
    border: 1px solid var(--jb-border);
    box-shadow: var(--jb-shadow-soft);
  }

  :where(.jb-card-header, .jb-card__header, .jb-card__footer) {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: var(--jb-space-6);
  }

  :where(.jb-card-title, .jb-card__title) {
    margin: 0;
    font-size: 1.42rem;
    line-height: 1.18;
    letter-spacing: -0.03em;
  }

  :where(.jb-meta, .jb-card__meta, .jb-job-copy) {
    color: var(--jb-text-muted);
    line-height: 1.75;
  }

  :where(.jb-pill, .jb-chip, .jb-tag, .jb-score) {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    min-height: 40px;
    padding: 8px 14px;
    border-radius: var(--jb-radius-pill);
    font-weight: 700;
  }

  :where(.jb-badge) {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    min-height: 46px;
    padding: 12px 18px;
    border-radius: var(--jb-radius-pill);
    font-weight: 700;
    color: #fff;
    background: rgba(255, 255, 255, 0.1);
    border: 1px solid rgba(255, 255, 255, 0.12);
  }

  :where(.jb-chip, .jb-tag, .jb-icon-button, .jb-nav__link, .jb-locale-switcher__trigger) {
    background: var(--jb-surface);
    color: var(--jb-text);
    border: 1px solid var(--jb-border);
    box-shadow: var(--jb-shadow-soft);
  }

  :where(.jb-chip.is-active, .jb-tag--primary, .jb-locale-switcher__option.is-active, .jb-score) {
    color: var(--jb-primary);
    background: color-mix(in srgb, var(--jb-primary) 10%, var(--jb-surface));
    border-color: color-mix(in srgb, var(--jb-primary) 20%, var(--jb-border));
  }

  :where(.jb-button, .jb-button, .jb-search__button) {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    min-height: 56px;
    padding: 0 24px;
    border: 0;
    border-radius: 18px;
    background: var(--jb-gradient-brand);
    color: #fff;
    font-weight: 800;
    box-shadow: 0 16px 30px rgba(255, 59, 59, 0.24);
    cursor: pointer;
  }

  :where(.jb-button--ghost, .jb-button--ghost) {
    background: transparent;
    color: var(--jb-text);
    border: 1px solid var(--jb-border);
    box-shadow: none;
  }

  :where(.jb-button--ghost-on-dark, .jb-button--ghost-on-dark) {
    background: transparent;
    color: var(--jb-reverse-text);
    border: 1px solid var(--jb-border);
    box-shadow: none;
  }

  :where(.jb-brand, .jb-brand) {
    display: inline-flex;
    align-items: center;
    gap: 14px;
  }

  :where(.jb-brand-logo, .jb-brand__logo) {
    width: 52px;
    height: 52px;
    border-radius: 18px;
    object-fit: cover;
    box-shadow: var(--jb-shadow-soft);
  }

  :where(.jb-brand-wordmark, .jb-brand__wordmark) {
    font-size: 1.9rem;
    font-weight: 800;
    line-height: 1;
    letter-spacing: -0.03em;
  }

  :where(.jb-brand__wordmark .job, .jb-brand-wordmark .job) { color: var(--jb-text); }
  :where(.jb-brand__wordmark .bridge, .jb-brand-wordmark .bridge) { color: var(--jb-primary); }

  :where(.jb-nav, .jb-nav) {
    display: flex;
    align-items: center;
    gap: 10px;
  }

    :where(.jb-icon-button) {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        width: 46px;
        min-width: 46px;
        height: 46px;
        min-height: 46px;
        padding: 0;
        border-radius: 999px;
        line-height: 1;
    }

    :where(.jb-icon-button .material-symbols-rounded) {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        font-size: 22px;
        line-height: 1;
    }

  :where(.jb-search, .jb-search) {
    display: flex;
    align-items: center;
    gap: 14px;
    min-height: 70px;
    padding: 12px 12px 12px 20px;
    border-radius: 22px;
    background: rgba(255, 255, 255, 0.98);
    color: var(--jb-text);
  }

  :where(.jb-search-input, .jb-search__input) {
    flex: 1;
    border: 0;
    outline: 0;
    background: transparent;
    color: var(--jb-text);
  }

  :where(.jb-search-input, .jb-search__input)::placeholder {
    color: var(--jb-text-muted);
  }

  :where(.jb-grid, .jb-grid, .jb-metrics, .jb-statsgrid) {
    display: grid;
    gap: var(--jb-space-grid);
  }

  :where(.jb-grid--jobs) {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  :where(.jb-metrics) {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }

  :where(.jb-statsgrid--single) {
    grid-template-columns: 1fr;
  }

  :where(.jb-metric, .jb-metric) {
    padding: 28px;
    border-radius: 30px;
    background: var(--jb-surface);
    border: 1px solid var(--jb-border);
    box-shadow: var(--jb-shadow-soft);
  }

  :where(.jb-metric__label, .jb-list__label, .jb-keyfacts__label, .jb-stat-card__label) {
    color: var(--jb-text-muted);
  }

  :where(.jb-metric__value, .jb-floating-apply__price, .jb-stat-card__value) {
    color: var(--jb-primary);
    font-weight: 800;
  }

  :where(.jb-list, .jb-keyfacts) {
    display: grid;
    gap: 18px;
  }

  :where(.jb-list__item, .jb-keyfacts__item) {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    padding: 18px 0;
    border-bottom: 1px solid color-mix(in srgb, var(--jb-border) 90%, transparent);
  }

  :where(.jb-list__item:last-child, .jb-keyfacts__item:last-child) {
    padding-bottom: 0;
    border-bottom: 0;
  }

  :where(.jb-list__value, .jb-keyfacts__value) {
    font-weight: 700;
  }

  :where(.jb-benefits, .jb-job-hero__actions, .jb-badges, .jb-filters, .jb-tags) {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
  }

  :where(.jb-benefit) {
    display: inline-flex;
    align-items: center;
    gap: 8px;
  }

  :where(.jb-benefit__dot) {
    width: 10px;
    height: 10px;
    border-radius: 999px;
    background: var(--jb-success);
    box-shadow: 0 0 0 6px color-mix(in srgb, var(--jb-success) 14%, transparent);
  }

  :where(.jb-floating-apply) {
    position: sticky;
    bottom: 24px;
    z-index: 35;
    margin-top: 30px;
  }

  :where(.jb-floating-apply__inner) {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 18px;
    padding: 18px 20px;
    border-radius: 26px;
    background: color-mix(in srgb, var(--jb-surface) 92%, transparent);
    border: 1px solid var(--jb-border);
    box-shadow: var(--jb-shadow);
    backdrop-filter: blur(18px);
  }

  :where(.jb-locale-switcher) {
    position: relative;
    display: inline-flex;
    align-items: center;
  }

  :where(.jb-locale-switcher__trigger) {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    min-height: 46px;
    padding: 0 16px;
    cursor: pointer;
    user-select: none;
  }

  :where(.jb-locale-switcher__panel) {
    position: absolute;
    top: calc(100% + 10px);
    right: 0;
    z-index: 60;
    min-width: 170px;
    padding: 10px;
    display: grid;
    gap: 8px;
    border-radius: 20px;
    background: var(--jb-surface);
    border: 1px solid var(--jb-border);
    box-shadow: var(--jb-shadow-soft);
  }

  :where(.jb-locale-switcher__option) {
    display: flex;
    align-items: center;
    justify-content: space-between;
    min-height: 46px;
    padding: 0 14px;
    border-radius: 14px;
    color: var(--jb-text);
    transition: background .18s ease, color .18s ease, transform .18s ease;
  }

  :where(.jb-locale-switcher__option:hover) {
    background: var(--jb-surface-soft);
    transform: translateY(-1px);
  }

  :where(.jb-locale-switcher__panel[hidden]) {
    display: none !important;
  }

  @media (max-width: 1100px) {
    :where(.container, .jb-container) {
      width: min(calc(100% - 40px), var(--jb-container));
    }

    :where(.jb-grid--jobs, .jb-metrics) {
      grid-template-columns: 1fr;
    }
  }

  @media (max-width: 768px) {
    :where(.container, .jb-container) {
      width: min(calc(100% - 24px), var(--jb-container));
    }

    :where(.jb-nav, .jb-nav) {
      display: none;
    }

    :where(.jb-search, .jb-search) {
      flex-wrap: wrap;
      padding: 14px;
    }

    :where(.jb-button, .jb-button, .jb-search__button) {
      width: 100%;
    }

    :where(.jb-floating-apply__inner) {
      flex-direction: column;
      align-items: stretch;
    }

    :where(.jb-locale-switcher__panel) {
      right: auto;
      left: 0;
    }
  }
}

@layer pages {
  .jb-site {
    min-height: 100vh;
    overflow-x: clip;
  }

  html:not([data-theme='dark']) .jb-card--hero {
    color: var(--jb-text);
  }

  html:not([data-theme='dark']) .jb-card--hero p {
    color: var(--jb-text-muted);
  }

  html:not([data-theme='dark']) .jb-card--hero span:not(.material-symbols-rounded):not(.jb-chip):not(.jb-tag):not(.jb-pill):not(.jb-badge):not(.jb-score):not(.jb-brand__wordmark):not(.job):not(.bridge) {
    color: inherit;
  }

  html:not([data-theme='dark']) .jb-card--hero .jb-kicker,
  html:not([data-theme='dark']) .jb-card--hero .jb-hero__title,
  html:not([data-theme='dark']) .jb-card--hero .jb-auth-title,
  html:not([data-theme='dark']) .jb-card--hero .jb-job-hero__title,
  html:not([data-theme='dark']) .jb-card--hero .jb-company-hero__title,
  html:not([data-theme='dark']) .jb-card--hero .jb-location-page__hero-title,
  html:not([data-theme='dark']) .jb-card--hero .jb-auth-stat strong,
  html:not([data-theme='dark']) .jb-card--hero .jb-location-page__hero-stat strong,
  html:not([data-theme='dark']) .jb-card--hero .jb-company-hero__stat strong,
  html:not([data-theme='dark']) .jb-card--hero .jb-job-breadcrumbs strong,
  html:not([data-theme='dark']) .jb-card--hero .jb-company-breadcrumbs strong {
    color: var(--jb-text);
  }

  html:not([data-theme='dark']) .jb-card--hero .jb-hero__lead,
  html:not([data-theme='dark']) .jb-card--hero .jb-auth-lead,
  html:not([data-theme='dark']) .jb-card--hero .jb-auth-benefit p,
  html:not([data-theme='dark']) .jb-card--hero .jb-job-hero__lead,
  html:not([data-theme='dark']) .jb-card--hero .jb-job-hero__meta,
  html:not([data-theme='dark']) .jb-card--hero .jb-job-hero__text,
  html:not([data-theme='dark']) .jb-card--hero .jb-company-hero__lead,
  html:not([data-theme='dark']) .jb-card--hero .jb-location-page__hero-lead,
  html:not([data-theme='dark']) .jb-card--hero .jb-auth-stat span,
  html:not([data-theme='dark']) .jb-card--hero .jb-location-page__hero-stat span,
  html:not([data-theme='dark']) .jb-card--hero .jb-job-breadcrumbs,
  html:not([data-theme='dark']) .jb-card--hero .jb-company-breadcrumbs,
  html:not([data-theme='dark']) .jb-card--hero .jb-company-hero__stat span {
    color: var(--jb-text-muted);
  }

  .jb-topbar {
    position: sticky;
    top: 0;
    z-index: 50;
    backdrop-filter: blur(18px);
    background: color-mix(in srgb, var(--jb-surface-alt) 82%, transparent);
    border-bottom: 1px solid color-mix(in srgb, var(--jb-border) 72%, transparent);
  }

  .jb-topbar__inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 24px;
    min-height: var(--jb-topbar-height);
  }

  .jb-hero {
    padding: 42px 0 var(--jb-space-section);
  }

  .jb-hero__panel {
    position: relative;
    overflow: hidden;
    min-height: 760px;
    padding: clamp(34px, 4.5vw, 64px);
    border-radius: 40px;
    background: var(--jb-gradient-hero);
    color: #fff;
    box-shadow: var(--jb-shadow-hero);
  }

  .jb-hero__content {
    position: relative;
    z-index: 1;
    display: grid;
    grid-template-columns: minmax(0, 1.25fr) minmax(360px, 500px);
    gap: clamp(34px, 5vw, 72px);
    align-items: center;
  }

  .jb-filters {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    padding: 20px 0;
  }

  .jb-kicker {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    min-height: 46px;
    padding: 12px 18px;
    border-radius: 999px;
    color: #fff;
    background: rgba(var(--jb-surface-reverse-rgb), 0.1);
    border: 1px solid rgba(var(--jb-surface-reverse-rgb), 0.12);
    font-weight: 700;
  }

  .jb-hero__title {
    margin: 22px 0 18px;
    max-width: 12ch;
    font-size: clamp(3rem, 6vw, 5.2rem);
    line-height: .95;
    letter-spacing: -.05em;
  }

  .jb-hero__lead {
    max-width: 62ch;
    margin: 0 0 32px;
    color: rgba(255, 255, 255, 0.78);
    font-size: clamp(1rem, 1.4vw, 1.15rem);
    line-height: 1.82;
  }

  .jb-search-card {
    padding: 30px;
    border-radius: 34px;
    background: rgba(255, 255, 255, 0.08);
    border: 1px solid rgba(255, 255, 255, 0.08);
  }

  .jb-search-meta {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 16px;
  }

  .jb-stat {
    padding: 20px;
    border-radius: 24px;
    background: rgba(255, 255, 255, 0.08);
    border: 1px solid rgba(255, 255, 255, 0.1);
  }

  .jb-stat__label {
    display: block;
    margin-bottom: 10px;
    color: rgba(255, 255, 255, 0.7);
    font-size: 0.86rem;
  }

  .jb-stat__value {
    font-size: 1.5rem;
    font-weight: 800;
  }

  .jb-card--job::before {
    content: '';
    position: absolute;
    inset: auto auto 0 0;
    width: 100%;
    height: 4px;
    background: linear-gradient(90deg, var(--jb-primary), rgba(255, 59, 59, 0.12));
    transform-origin: left center;
    transform: scaleX(.45);
  }

  .jb-card__meta {
    margin-top: 8px;
  }

  .jb-tags {
    margin: 22px 0 20px;
  }

  .jb-card__text {
    margin: 0;
    line-height: 1.85;
  }

  .jb-card__footer {
    margin-top: 28px;
  }

  .jb-detail {
    display: grid;
    grid-template-columns: minmax(0, 1.1fr) minmax(360px, .9fr);
    gap: clamp(26px, 3vw, 40px);
  }

  .jb-panel--hero {
    background: var(--jb-gradient-brand);
    color: #fff;
    box-shadow: 0 18px 36px rgba(255, 59, 59, 0.18);
  }

  .jb-panel__eyebrow {
    display: inline-flex;
    align-items: center;
    min-height: 40px;
    padding: 0 14px;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.14);
    border: 1px solid rgba(255, 255, 255, 0.12);
    font-weight: 700;
  }

  .jb-panel__title {
    margin: 18px 0 14px;
    font-size: clamp(2rem, 3vw, 3rem);
    line-height: .98;
    letter-spacing: -.05em;
  }

  .jb-panel__sub {
    margin: 0;
    color: rgba(255, 255, 255, 0.84);
    line-height: 1.82;
  }

  .jb-job-page {
    padding-bottom: 90px;
  }

  .jb-job-hero {
    padding-top: 34px;
    padding-bottom: 34px;
  }

  .jb-job-hero__grid,
  .jb-job-layout {
    display: grid;
    grid-template-columns: minmax(0, 1.1fr) minmax(320px, .9fr);
    gap: clamp(24px, 3vw, 40px);
    align-items: start;
  }

  .jb-job-hero__main {
    background: var(--jb-gradient-hero);
    color: #fff;
    box-shadow: var(--jb-shadow-hero);
  }

  .jb-job-hero__aside {
    position: sticky;
    top: 118px;
    align-self: start;
  }

  .jb-job-breadcrumbs {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    align-items: center;
    margin-bottom: 20px;
    color: var(--jb-text-rgb);
    font-size: .95rem;
  }

  .jb-job-breadcrumbs strong { color: var(--jb-text); }

  .jb-job-hero__meta {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
  }

  .jb-job-hero__title {
    margin: 20px 0 12px;
    font-size: clamp(2.4rem, 4vw, 4.2rem);
    line-height: .96;
    letter-spacing: -.05em;
  }

  .jb-job-hero__lead {
    margin: 0 0 16px;
    color: rgba(255,255,255,.86);
    font-size: 1.08rem;
    font-weight: 700;
  }

  .jb-job-hero__text {
    margin: 0;
    color: rgba(255,255,255,.78);
    line-height: 1.82;
    max-width: 64ch;
  }

  .jb-job-hero__tags { margin-top: 24px; }
  .jb-job-hero__actions { margin-top: 28px; }

  .jb-job-anchorbar {
    position: sticky;
    top: 92px;
    z-index: 30;
    padding-bottom: 12px;
  }

  .jb-job-anchorbar__inner {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    padding: 14px;
    border-radius: 24px;
    background: color-mix(in srgb, var(--jb-surface) 92%, transparent);
    border: 1px solid var(--jb-border);
    box-shadow: var(--jb-shadow-soft);
    backdrop-filter: blur(18px);
  }

  .jb-job-anchorbar__inner a {
    display: inline-flex;
    align-items: center;
    min-height: 42px;
    padding: 0 16px;
    border-radius: 999px;
    background: var(--jb-surface-soft);
    color: var(--jb-text);
    border: 1px solid color-mix(in srgb, var(--jb-border) 88%, transparent);
    font-weight: 700;
  }

  .jb-job-layout__main,
  .jb-job-layout__side {
    display: grid;
    gap: 24px;
  }

  .jb-section__header--compact { margin-bottom: 20px; }

  .jb-job-copy {
    margin: 0;
    line-height: 1.84;
    color: var(--jb-text-muted);
  }

  .jb-job-highlightgrid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 16px;
    margin-top: 24px;
  }

  .jb-job-highlight {
    padding: 20px;
    border-radius: 24px;
    background: var(--jb-surface-soft);
    border: 1px solid color-mix(in srgb, var(--jb-border) 88%, transparent);
  }

  .jb-job-highlight strong {
    display: block;
    margin-top: 10px;
    font-size: 1.02rem;
  }

  .jb-job-bullets {
    display: grid;
    gap: 14px;
    margin: 0;
    padding-left: 22px;
    color: var(--jb-text);
  }

  .jb-benefits--detail { gap: 16px 22px; margin-top: 0; }
  .jb-job-sidecard { position: relative; }

  .jb-job-page [data-copy-link].is-copied {
    border-color: color-mix(in srgb, var(--jb-success) 30%, var(--jb-border));
    color: var(--jb-success);
  }

  .jb-statsgrid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .jb-stat-card::before {
    content: '';
    position: absolute;
    inset: 0 auto 0 0;
    width: 4px;
    background: linear-gradient(180deg, var(--jb-primary), var(--jb-primary-dark));
  }

  .jb-stat-card__top {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 16px;
    margin-bottom: 18px;
  }

  .jb-stat-card__label {
    display: block;
    margin-bottom: 8px;
    font-size: 0.88rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.04em;
  }

  .jb-stat-card__value {
    display: block;
    font-size: clamp(2rem, 3vw, 2.8rem);
    line-height: 1;
    font-weight: 900;
    letter-spacing: -0.04em;
  }

  .jb-stat-card__badge,
  .jb-stat-card__pill {
    display: inline-flex;
    align-items: center;
    min-height: 36px;
    padding: 0 12px;
    border-radius: 999px;
    background: var(--jb-surface-soft);
    border: 1px solid color-mix(in srgb, var(--jb-border) 86%, transparent);
    font-size: 0.84rem;
    font-weight: 700;
  }

  .jb-stat-card__badge {
    min-height: 38px;
    color: var(--jb-primary);
    background: color-mix(in srgb, var(--jb-primary) 10%, var(--jb-surface));
    border-color: color-mix(in srgb, var(--jb-primary) 18%, var(--jb-border));
    font-size: 0.82rem;
    font-weight: 800;
    white-space: nowrap;
  }

  .jb-stat-card__meter {
    position: relative;
    height: 12px;
    margin: 0 0 18px;
    border-radius: 999px;
    background: color-mix(in srgb, var(--jb-border) 72%, transparent);
    overflow: hidden;
  }

  .jb-stat-card__meter > span {
    display: block;
    width: var(--value, 0%);
    height: 100%;
    border-radius: inherit;
    background: linear-gradient(90deg, var(--jb-primary), var(--jb-primary-dark));
    box-shadow: 0 8px 18px rgba(255, 59, 59, 0.24);
  }

  .jb-stat-card__helper {
    margin: 0 0 14px;
    color: var(--jb-text-muted);
    line-height: 1.78;
  }

  .jb-stat-card__footer {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
  }

  .jb-locale-switcher__current {
    font-weight: 800;
    letter-spacing: 0.04em;
  }

  .jb-locale-switcher__chevron {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 20px;
    height: 20px;
    font-size: 20px;
    line-height: 1;
    transition: transform 0.22s ease;
    flex-shrink: 0;
  }

  .jb-locale-switcher.is-open .jb-locale-switcher__chevron {
    transform: rotate(180deg);
  }

  .jb-reveal,
  .jb-reveal-stagger > * {
    opacity: 0;
    transform: translateY(24px);
  }

  .jb-parallax { will-change: transform; }

  @media (min-width: 1500px) {
    .jb-hero__panel { min-height: 820px; }
  }

  @media (max-width: 1100px) {
    .jb-hero__content,
    .jb-detail,
    .jb-job-hero__grid,
    .jb-job-layout {
      grid-template-columns: 1fr;
    }

    .jb-job-hero__aside,
    .jb-job-anchorbar {
      position: static;
    }

    .jb-hero__panel { min-height: auto; }
  }

  @media (max-width: 768px) {
    .jb-topbar__inner { min-height: 76px; }
    .jb-brand__wordmark { font-size: 1.55rem; }
    .jb-hero { padding-top: 20px; }

    .jb-hero__panel,
    .jb-card,
    .jb-panel {
      border-radius: 26px;
    }

    .jb-hero__panel { padding: 24px; }
    .jb-hero__title { max-width: none; }

    .jb-search-meta,
    .jb-keyfacts,
    .jb-metrics,
    .jb-grid--jobs,
    .jb-statsgrid,
    .jb-job-highlightgrid {
      grid-template-columns: 1fr;
    }

    .jb-job-page { padding-bottom: 54px; }
    .jb-job-hero__meta { flex-direction: column; align-items: flex-start; }
    .jb-job-anchorbar__inner { padding: 10px; }
    .jb-job-anchorbar__inner a { width: 100%; justify-content: center; }
    .jb-stat-card { padding: 20px; border-radius: 22px; }
    .jb-stat-card__top { flex-direction: column; align-items: flex-start; }
  }
}

@layer utilities {
  .jb-d-block { display: block !important; }
  .jb-d-inline-flex { display: inline-flex !important; }
  .jb-d-flex { display: flex !important; }
  .jb-d-grid { display: grid !important; }
  .jb-hidden { display: none !important; }

  .jb-w-full { width: 100% !important; }
  .jb-h-full { height: 100% !important; }

  .jb-text-left { text-align: left !important; }
  .jb-text-center { text-align: center !important; }
  .jb-text-right { text-align: right !important; }

  .jb-text-capitalize { text-transform: capitalize !important; }
  .jb-text-uppercase { text-transform: uppercase !important; }
  .jb-text-lowercase { text-transform: lowercase !important; }

  .jb-text-bold { font-weight: var(--jb-fw) !important; }
  .jb-text-fw { font-weight: var(--jb-fw) !important; }
  .jb-text-fw-100 { font-weight: 100 !important; }
  .jb-text-fw-200 { font-weight: 200 !important; }
  .jb-text-fw-300 { font-weight: 300 !important; }
  .jb-text-fw-400 { font-weight: 400 !important; }
  .jb-text-fw-500 { font-weight: 500 !important; }
  .jb-text-fw-600 { font-weight: 600 !important; }
  .jb-text-fw-700 { font-weight: 700 !important; }
  .jb-text-fw-800 { font-weight: 800 !important; }
  .jb-text-fw-900 { font-weight: 900 !important; }


  .jb-items-start { align-items: flex-start !important; }
  .jb-items-center { align-items: center !important; }
  .jb-items-end { align-items: flex-end !important; }

  .jb-justify-start { justify-content: flex-start !important; }
  .jb-justify-center { justify-content: center !important; }
  .jb-justify-between { justify-content: space-between !important; }
  .jb-justify-end { justify-content: flex-end !important; }

  .jb-rounded-sm { border-radius: var(--jb-radius-sm) !important; }
  .jb-rounded-md { border-radius: var(--jb-radius-md) !important; }
  .jb-rounded-lg { border-radius: var(--jb-radius-lg) !important; }
  .jb-rounded-xl { border-radius: var(--jb-radius-xl) !important; }
  .jb-rounded-pill { border-radius: var(--jb-radius-pill) !important; }

  .jb-shadow-soft { box-shadow: var(--jb-shadow-soft) !important; }
  .jb-shadow { box-shadow: var(--jb-shadow) !important; }

  .jb-bg-surface { background: var(--jb-surface) !important; }
  .jb-bg-surface-soft { background: var(--jb-surface-soft) !important; }
  .jb-bg-surface-alt { background: var(--jb-surface-alt) !important; }
  .jb-bg-brand { background: var(--jb-gradient-brand) !important; color: #fff !important; }

  .jb-text-primary { color: var(--jb-primary) !important; }
  .jb-text-muted { color: var(--jb-text-muted) !important; }
  .jb-text-default { color: var(--jb-text) !important; }
  .jb-text-white { color: #fff !important; }

  .jb-border { border: 1px solid var(--jb-border) !important; }
  .jb-border-0 { border: 0 !important; }

  .jb-gap-1 { gap: var(--jb-space-1) !important; }
  .jb-gap-2 { gap: var(--jb-space-2) !important; }
  .jb-gap-3 { gap: var(--jb-space-3) !important; }
  .jb-gap-4 { gap: var(--jb-space-4) !important; }
  .jb-gap-5 { gap: var(--jb-space-5) !important; }
  .jb-gap-6 { gap: var(--jb-space-6) !important; }
  .jb-gap-7 { gap: var(--jb-space-7) !important; }
  .jb-gap-8 { gap: var(--jb-space-8) !important; }
  .jb-gap-9 { gap: var(--jb-space-9) !important; }
  .jb-gap-10 { gap: var(--jb-space-10) !important; }
  .jb-gap-11 { gap: var(--jb-space-11) !important; }
  .jb-gap-12 { gap: var(--jb-space-12) !important; }

  .jb-p-0 { padding: 0 !important; }
  .jb-p-1 { padding: var(--jb-space-1) !important; }
  .jb-p-2 { padding: var(--jb-space-2) !important; }
  .jb-p-3 { padding: var(--jb-space-3) !important; }
  .jb-p-4 { padding: var(--jb-space-4) !important; }
  .jb-p-5 { padding: var(--jb-space-5) !important; }
  .jb-p-6 { padding: var(--jb-space-6) !important; }
  .jb-p-7 { padding: var(--jb-space-7) !important; }
  .jb-p-8 { padding: var(--jb-space-8) !important; }
  .jb-p-9 { padding: var(--jb-space-9) !important; }
  .jb-p-10 { padding: var(--jb-space-10) !important; }
  .jb-p-11 { padding: var(--jb-space-11) !important; }
  .jb-p-12 { padding: var(--jb-space-12) !important; }
  .jb-pt-0 { padding-top: 0 !important; }
  .jb-pt-1 { padding-top: var(--jb-space-1) !important; }
  .jb-pt-2 { padding-top: var(--jb-space-2) !important; }
  .jb-pt-3 { padding-top: var(--jb-space-3) !important; }
  .jb-pt-4 { padding-top: var(--jb-space-4) !important; }
  .jb-pt-5 { padding-top: var(--jb-space-5) !important; }
  .jb-pt-6 { padding-top: var(--jb-space-6) !important; }
  .jb-pt-7 { padding-top: var(--jb-space-7) !important; }
  .jb-pt-8 { padding-top: var(--jb-space-8) !important; }
  .jb-pt-9 { padding-top: var(--jb-space-9) !important; }
  .jb-pt-10 { padding-top: var(--jb-space-10) !important; }
  .jb-pt-11 { padding-top: var(--jb-space-11) !important; }
  .jb-pt-12 { padding-top: var(--jb-space-12) !important; }
  .jb-pr-0 { padding-right: 0 !important; }
  .jb-pr-1 { padding-right: var(--jb-space-1) !important; }
  .jb-pr-2 { padding-right: var(--jb-space-2) !important; }
  .jb-pr-3 { padding-right: var(--jb-space-3) !important; }
  .jb-pr-4 { padding-right: var(--jb-space-4) !important; }
  .jb-pr-5 { padding-right: var(--jb-space-5) !important; }
  .jb-pr-6 { padding-right: var(--jb-space-6) !important; }
  .jb-pr-7 { padding-right: var(--jb-space-7) !important; }
  .jb-pr-8 { padding-right: var(--jb-space-8) !important; }
  .jb-pr-9 { padding-right: var(--jb-space-9) !important; }
  .jb-pr-10 { padding-right: var(--jb-space-10) !important; }
  .jb-pr-11 { padding-right: var(--jb-space-11) !important; }
  .jb-pr-12 { padding-right: var(--jb-space-12) !important; }
  .jb-pb-0 { padding-bottom: 0 !important; }
  .jb-pb-1 { padding-bottom: var(--jb-space-1) !important; }
  .jb-pb-2 { padding-bottom: var(--jb-space-2) !important; }
  .jb-pb-3 { padding-bottom: var(--jb-space-3) !important; }
  .jb-pb-4 { padding-bottom: var(--jb-space-4) !important; }
  .jb-pb-5 { padding-bottom: var(--jb-space-5) !important; }
  .jb-pb-6 { padding-bottom: var(--jb-space-6) !important; }
  .jb-pb-7 { padding-bottom: var(--jb-space-7) !important; }
  .jb-pb-8 { padding-bottom: var(--jb-space-8) !important; }
  .jb-pb-9 { padding-bottom: var(--jb-space-9) !important; }
  .jb-pb-10 { padding-bottom: var(--jb-space-10) !important; }
  .jb-pb-11 { padding-bottom: var(--jb-space-11) !important; }
  .jb-pb-12 { padding-bottom: var(--jb-space-12) !important; }
  .jb-pl-0 { padding-left: 0 !important; }
  .jb-pl-1 { padding-left: var(--jb-space-1) !important; }
  .jb-pl-2 { padding-left: var(--jb-space-2) !important; }
  .jb-pl-3 { padding-left: var(--jb-space-3) !important; }
  .jb-pl-4 { padding-left: var(--jb-space-4) !important; }
  .jb-pl-5 { padding-left: var(--jb-space-5) !important; }
  .jb-pl-6 { padding-left: var(--jb-space-6) !important; }
  .jb-pl-7 { padding-left: var(--jb-space-7) !important; }
  .jb-pl-8 { padding-left: var(--jb-space-8) !important; }
  .jb-pl-9 { padding-left: var(--jb-space-9) !important; }
  .jb-pl-10 { padding-left: var(--jb-space-10) !important; }
  .jb-pl-11 { padding-left: var(--jb-space-11) !important; }
  .jb-pl-12 { padding-left: var(--jb-space-12) !important; }
  .jb-px-0 { padding-left: 0 !important; padding-right: 0 !important; }
  .jb-px-1 { padding-left: var(--jb-space-1) !important; padding-right: var(--jb-space-1) !important; }
  .jb-px-2 { padding-left: var(--jb-space-2) !important; padding-right: var(--jb-space-2) !important; }
  .jb-px-3 { padding-left: var(--jb-space-3) !important; padding-right: var(--jb-space-3) !important; }
  .jb-px-4 { padding-left: var(--jb-space-4) !important; padding-right: var(--jb-space-4) !important; }
  .jb-px-5 { padding-left: var(--jb-space-5) !important; padding-right: var(--jb-space-5) !important; }
  .jb-px-6 { padding-left: var(--jb-space-6) !important; padding-right: var(--jb-space-6) !important; }
  .jb-px-7 { padding-left: var(--jb-space-7) !important; padding-right: var(--jb-space-7) !important; }
  .jb-px-8 { padding-left: var(--jb-space-8) !important; padding-right: var(--jb-space-8) !important; }
  .jb-px-9 { padding-left: var(--jb-space-9) !important; padding-right: var(--jb-space-9) !important; }
  .jb-px-10 { padding-left: var(--jb-space-10) !important; padding-right: var(--jb-space-10) !important; }
  .jb-px-11 { padding-left: var(--jb-space-11) !important; padding-right: var(--jb-space-11) !important; }
  .jb-px-12 { padding-left: var(--jb-space-12) !important; padding-right: var(--jb-space-12) !important; }
  .jb-py-0 { padding-top: 0 !important; padding-bottom: 0 !important; }
  .jb-py-1 { padding-top: var(--jb-space-1) !important; padding-bottom: var(--jb-space-1) !important; }
  .jb-py-2 { padding-top: var(--jb-space-2) !important; padding-bottom: var(--jb-space-2) !important; }
  .jb-py-3 { padding-top: var(--jb-space-3) !important; padding-bottom: var(--jb-space-3) !important; }
  .jb-py-4 { padding-top: var(--jb-space-4) !important; padding-bottom: var(--jb-space-4) !important; }
  .jb-py-5 { padding-top: var(--jb-space-5) !important; padding-bottom: var(--jb-space-5) !important; }
  .jb-py-6 { padding-top: var(--jb-space-6) !important; padding-bottom: var(--jb-space-6) !important; }
  .jb-py-7 { padding-top: var(--jb-space-7) !important; padding-bottom: var(--jb-space-7) !important; }
  .jb-py-8 { padding-top: var(--jb-space-8) !important; padding-bottom: var(--jb-space-8) !important; }
  .jb-py-9 { padding-top: var(--jb-space-9) !important; padding-bottom: var(--jb-space-9) !important; }
  .jb-py-10 { padding-top: var(--jb-space-10) !important; padding-bottom: var(--jb-space-10) !important; }
  .jb-py-11 { padding-top: var(--jb-space-11) !important; padding-bottom: var(--jb-space-11) !important; }
  .jb-py-12 { padding-top: var(--jb-space-12) !important; padding-bottom: var(--jb-space-12) !important; }
  .jb-m-0 { margin: 0 !important; }
  .jb-m-1 { margin: var(--jb-space-1) !important; }
  .jb-m-2 { margin: var(--jb-space-2) !important; }
  .jb-m-3 { margin: var(--jb-space-3) !important; }
  .jb-m-4 { margin: var(--jb-space-4) !important; }
  .jb-m-5 { margin: var(--jb-space-5) !important; }
  .jb-m-6 { margin: var(--jb-space-6) !important; }
  .jb-m-7 { margin: var(--jb-space-7) !important; }
  .jb-m-8 { margin: var(--jb-space-8) !important; }
  .jb-m-9 { margin: var(--jb-space-9) !important; }
  .jb-m-10 { margin: var(--jb-space-10) !important; }
  .jb-m-11 { margin: var(--jb-space-11) !important; }
  .jb-m-12 { margin: var(--jb-space-12) !important; }
  .jb-mt-0 { margin-top: 0 !important; }
  .jb-mt-1 { margin-top: var(--jb-space-1) !important; }
  .jb-mt-2 { margin-top: var(--jb-space-2) !important; }
  .jb-mt-3 { margin-top: var(--jb-space-3) !important; }
  .jb-mt-4 { margin-top: var(--jb-space-4) !important; }
  .jb-mt-5 { margin-top: var(--jb-space-5) !important; }
  .jb-mt-6 { margin-top: var(--jb-space-6) !important; }
  .jb-mt-7 { margin-top: var(--jb-space-7) !important; }
  .jb-mt-8 { margin-top: var(--jb-space-8) !important; }
  .jb-mt-9 { margin-top: var(--jb-space-9) !important; }
  .jb-mt-10 { margin-top: var(--jb-space-10) !important; }
  .jb-mt-11 { margin-top: var(--jb-space-11) !important; }
  .jb-mt-12 { margin-top: var(--jb-space-12) !important; }
  .jb-mr-0 { margin-right: 0 !important; }
  .jb-mr-1 { margin-right: var(--jb-space-1) !important; }
  .jb-mr-2 { margin-right: var(--jb-space-2) !important; }
  .jb-mr-3 { margin-right: var(--jb-space-3) !important; }
  .jb-mr-4 { margin-right: var(--jb-space-4) !important; }
  .jb-mr-5 { margin-right: var(--jb-space-5) !important; }
  .jb-mr-6 { margin-right: var(--jb-space-6) !important; }
  .jb-mr-7 { margin-right: var(--jb-space-7) !important; }
  .jb-mr-8 { margin-right: var(--jb-space-8) !important; }
  .jb-mr-9 { margin-right: var(--jb-space-9) !important; }
  .jb-mr-10 { margin-right: var(--jb-space-10) !important; }
  .jb-mr-11 { margin-right: var(--jb-space-11) !important; }
  .jb-mr-12 { margin-right: var(--jb-space-12) !important; }
  .jb-mb-0 { margin-bottom: 0 !important; }
  .jb-mb-1 { margin-bottom: var(--jb-space-1) !important; }
  .jb-mb-2 { margin-bottom: var(--jb-space-2) !important; }
  .jb-mb-3 { margin-bottom: var(--jb-space-3) !important; }
  .jb-mb-4 { margin-bottom: var(--jb-space-4) !important; }
  .jb-mb-5 { margin-bottom: var(--jb-space-5) !important; }
  .jb-mb-6 { margin-bottom: var(--jb-space-6) !important; }
  .jb-mb-7 { margin-bottom: var(--jb-space-7) !important; }
  .jb-mb-8 { margin-bottom: var(--jb-space-8) !important; }
  .jb-mb-9 { margin-bottom: var(--jb-space-9) !important; }
  .jb-mb-10 { margin-bottom: var(--jb-space-10) !important; }
  .jb-mb-11 { margin-bottom: var(--jb-space-11) !important; }
  .jb-mb-12 { margin-bottom: var(--jb-space-12) !important; }
  .jb-ml-0 { margin-left: 0 !important; }
  .jb-ml-1 { margin-left: var(--jb-space-1) !important; }
  .jb-ml-2 { margin-left: var(--jb-space-2) !important; }
  .jb-ml-3 { margin-left: var(--jb-space-3) !important; }
  .jb-ml-4 { margin-left: var(--jb-space-4) !important; }
  .jb-ml-5 { margin-left: var(--jb-space-5) !important; }
  .jb-ml-6 { margin-left: var(--jb-space-6) !important; }
  .jb-ml-7 { margin-left: var(--jb-space-7) !important; }
  .jb-ml-8 { margin-left: var(--jb-space-8) !important; }
  .jb-ml-9 { margin-left: var(--jb-space-9) !important; }
  .jb-ml-10 { margin-left: var(--jb-space-10) !important; }
  .jb-ml-11 { margin-left: var(--jb-space-11) !important; }
  .jb-ml-12 { margin-left: var(--jb-space-12) !important; }
  .jb-mx-0 { margin-left: 0 !important; margin-right: 0 !important; }
  .jb-mx-1 { margin-left: var(--jb-space-1) !important; margin-right: var(--jb-space-1) !important; }
  .jb-mx-2 { margin-left: var(--jb-space-2) !important; margin-right: var(--jb-space-2) !important; }
  .jb-mx-3 { margin-left: var(--jb-space-3) !important; margin-right: var(--jb-space-3) !important; }
  .jb-mx-4 { margin-left: var(--jb-space-4) !important; margin-right: var(--jb-space-4) !important; }
  .jb-mx-5 { margin-left: var(--jb-space-5) !important; margin-right: var(--jb-space-5) !important; }
  .jb-mx-6 { margin-left: var(--jb-space-6) !important; margin-right: var(--jb-space-6) !important; }
  .jb-mx-7 { margin-left: var(--jb-space-7) !important; margin-right: var(--jb-space-7) !important; }
  .jb-mx-8 { margin-left: var(--jb-space-8) !important; margin-right: var(--jb-space-8) !important; }
  .jb-mx-9 { margin-left: var(--jb-space-9) !important; margin-right: var(--jb-space-9) !important; }
  .jb-mx-10 { margin-left: var(--jb-space-10) !important; margin-right: var(--jb-space-10) !important; }
  .jb-mx-11 { margin-left: var(--jb-space-11) !important; margin-right: var(--jb-space-11) !important; }
  .jb-mx-12 { margin-left: var(--jb-space-12) !important; margin-right: var(--jb-space-12) !important; }
  .jb-my-0 { margin-top: 0 !important; margin-bottom: 0 !important; }
  .jb-my-1 { margin-top: var(--jb-space-1) !important; margin-bottom: var(--jb-space-1) !important; }
  .jb-my-2 { margin-top: var(--jb-space-2) !important; margin-bottom: var(--jb-space-2) !important; }
  .jb-my-3 { margin-top: var(--jb-space-3) !important; margin-bottom: var(--jb-space-3) !important; }
  .jb-my-4 { margin-top: var(--jb-space-4) !important; margin-bottom: var(--jb-space-4) !important; }
  .jb-my-5 { margin-top: var(--jb-space-5) !important; margin-bottom: var(--jb-space-5) !important; }
  .jb-my-6 { margin-top: var(--jb-space-6) !important; margin-bottom: var(--jb-space-6) !important; }
  .jb-my-7 { margin-top: var(--jb-space-7) !important; margin-bottom: var(--jb-space-7) !important; }
  .jb-my-8 { margin-top: var(--jb-space-8) !important; margin-bottom: var(--jb-space-8) !important; }
  .jb-my-9 { margin-top: var(--jb-space-9) !important; margin-bottom: var(--jb-space-9) !important; }
  .jb-my-10 { margin-top: var(--jb-space-10) !important; margin-bottom: var(--jb-space-10) !important; }
  .jb-my-11 { margin-top: var(--jb-space-11) !important; margin-bottom: var(--jb-space-11) !important; }
  .jb-my-12 { margin-top: var(--jb-space-12) !important; margin-bottom: var(--jb-space-12) !important; }

  /* =========================
   HOVER SYSTEM
   ========================= */

.jb-hover {
  --jb-hover-y: -2px;
  --jb-hover-scale: 1;
  --jb-hover-shadow: var(--jb-shadow);
  --jb-hover-border: color-mix(in srgb, var(--jb-primary) 14%, var(--jb-border));
  --jb-hover-bg: initial;
  --jb-hover-color: inherit;
  --jb-hover-ring: 0 0 0 4px color-mix(in srgb, var(--jb-primary) 14%, transparent);

  transition:
    transform 0.22s ease,
    box-shadow 0.28s ease,
    border-color 0.28s ease,
    background-color 0.28s ease,
    color 0.22s ease,
    opacity 0.22s ease,
    filter 0.22s ease;
  will-change: transform;
}

.jb-hover[href],
button.jb-hover,
a.jb-hover,
[role='button'].jb-hover,
[data-clickable].jb-hover {
  cursor: pointer;
}

@media (hover: hover) and (pointer: fine) {
  .jb-hover:hover {
    transform: translateY(var(--jb-hover-y)) scale(var(--jb-hover-scale));
    box-shadow: var(--jb-hover-shadow);
    border-color: var(--jb-hover-border);
    background: var(--jb-hover-bg);
    color: var(--jb-hover-color);
  }

  .jb-hover:active {
    transform: translateY(calc(var(--jb-hover-y) / 2)) scale(0.985);
  }
}

.jb-hover:focus-visible {
  outline: none;
  box-shadow: var(--jb-hover-ring), var(--jb-hover-shadow);
  border-color: var(--jb-hover-border);
}

.jb-hover[aria-disabled='true'],
.jb-hover.is-disabled,
.jb-hover:disabled {
  opacity: 0.55;
  pointer-events: none;
  transform: none !important;
  box-shadow: none !important;
}

/* ----- Variants ----- */

.jb-hover--soft {
  --jb-hover-y: -1px;
  --jb-hover-scale: 1;
  --jb-hover-shadow: var(--jb-shadow-soft);
  /* --jb-hover-border: color-mix(in srgb, var(--jb-primary) 10%, var(--jb-border)); */
}

.jb-hover--lift {
  --jb-hover-y: -4px;
  --jb-hover-scale: 1;
  --jb-hover-shadow: 0 18px 42px rgba(10, 13, 18, 0.12);
  /* --jb-hover-border: color-mix(in srgb, var(--jb-primary) 16%, var(--jb-border)); */
}

.jb-hover--glow {
  --jb-hover-y: -2px;
  --jb-hover-scale: 1;
  --jb-hover-shadow:
    0 16px 34px rgba(255, 59, 59, 0.22),
    0 0 0 1px color-mix(in srgb, var(--jb-primary) 18%, transparent);
  --jb-hover-border: color-mix(in srgb, var(--jb-primary) 24%, var(--jb-border));
  --jb-hover-ring:
    0 0 0 4px color-mix(in srgb, var(--jb-primary) 18%, transparent);
}

/* ----- Good defaults on common interactive UI ----- */

.jb-card.jb-hover,
.jb-panel.jb-hover,
.jb-metric.jb-hover,
.jb-stat-card.jb-hover {
  transform-origin: center;
}

.jb-button.jb-hover,
.jb-icon-button.jb-hover,
.jb-chip.jb-hover,
.jb-tag.jb-hover {
  transform-origin: center;
}

.jb-button.jb-hover--glow {
  --jb-hover-bg: #c02c2c;
  --jb-hover-color: #fff;
}

.jb-button--ghost.jb-hover {
  --jb-hover-bg: color-mix(in srgb, var(--jb-primary) 6%, var(--jb-surface));
}

.jb-button--ghost-on-dark.jb-hover {
  --jb-hover-bg: #fff;
  --jb-hover-color: var(--jb-reverse-text-hover);
}

.jb-chip.jb-hover,
.jb-tag.jb-hover,
.jb-icon-button.jb-hover {
  --jb-hover-shadow: var(--jb-shadow-soft);
  --jb-hover-y: -2px;
}

/* ----- Reduced motion ----- */

@media (prefers-reduced-motion: reduce) {
  .jb-hover {
    transition:
      box-shadow 0.2s ease,
      border-color 0.2s ease,
      background-color 0.2s ease,
      color 0.2s ease,
      opacity 0.2s ease;
  }

  .jb-hover:hover,
  .jb-hover:active {
    transform: none;
  }
}

.jb-hover.is-pressed {
  transform: translateY(-1px) scale(0.985);
}

.jb-hover.is-touching {
  filter: brightness(0.985);
}

.jb-icon-button.jb-hover {
  --jb-hover-bg: var(--jb-surface-soft);
  --jb-hover-shadow: 0 12px 28px rgba(10, 13, 18, 0.1);
}

.jb-icon-button.jb-hover .material-symbols-rounded {
  transition: transform 0.22s ease, color 0.22s ease;
}

@media (hover: hover) and (pointer: fine) {
  .jb-icon-button.jb-hover:hover .material-symbols-rounded {
    transform: scale(1.08);
  }
}

}


@layer utilities {
  /* ===== Size utilities added for integral utility support ===== */
  .jb-w-auto { width: auto !important; }
  .jb-w-fit { width: fit-content !important; }
  .jb-w-screen { width: 100vw !important; }
  .jb-min-w-0 { min-width: 0 !important; }
  .jb-min-w-full { min-width: 100% !important; }
  .jb-max-w-none { max-width: none !important; }
  .jb-max-w-full { max-width: 100% !important; }
  .jb-max-w-screen { max-width: 100vw !important; }
  .jb-h-auto { height: auto !important; }
  .jb-h-screen { height: 100vh !important; }
  .jb-min-h-0 { min-height: 0 !important; }
  .jb-min-h-full { min-height: 100% !important; }
  .jb-min-h-screen { min-height: 100vh !important; }
  .jb-max-h-none { max-height: none !important; }
  .jb-max-h-full { max-height: 100% !important; }
  .jb-max-h-screen { max-height: 100vh !important; }
  .jb-w-0 { width: 0 !important; }
  .jb-w-1 { width: var(--jb-space-1) !important; }
  .jb-w-2 { width: var(--jb-space-2) !important; }
  .jb-w-3 { width: var(--jb-space-3) !important; }
  .jb-w-4 { width: var(--jb-space-4) !important; }
  .jb-w-5 { width: var(--jb-space-5) !important; }
  .jb-w-6 { width: var(--jb-space-6) !important; }
  .jb-w-7 { width: var(--jb-space-7) !important; }
  .jb-w-8 { width: var(--jb-space-8) !important; }
  .jb-w-9 { width: var(--jb-space-9) !important; }
  .jb-w-10 { width: var(--jb-space-10) !important; }
  .jb-w-11 { width: var(--jb-space-11) !important; }
  .jb-w-12 { width: var(--jb-space-12) !important; }
  .jb-h-0 { height: 0 !important; }
  .jb-h-1 { height: var(--jb-space-1) !important; }
  .jb-h-2 { height: var(--jb-space-2) !important; }
  .jb-h-3 { height: var(--jb-space-3) !important; }
  .jb-h-4 { height: var(--jb-space-4) !important; }
  .jb-h-5 { height: var(--jb-space-5) !important; }
  .jb-h-6 { height: var(--jb-space-6) !important; }
  .jb-h-7 { height: var(--jb-space-7) !important; }
  .jb-h-8 { height: var(--jb-space-8) !important; }
  .jb-h-9 { height: var(--jb-space-9) !important; }
  .jb-h-10 { height: var(--jb-space-10) !important; }
  .jb-h-11 { height: var(--jb-space-11) !important; }
  .jb-h-12 { height: var(--jb-space-12) !important; }
  .jb-min-h-0 { min-height: 0 !important; }
  .jb-min-h-1 { min-height: var(--jb-space-1) !important; }
  .jb-min-h-2 { min-height: var(--jb-space-2) !important; }
  .jb-min-h-3 { min-height: var(--jb-space-3) !important; }
  .jb-min-h-4 { min-height: var(--jb-space-4) !important; }
  .jb-min-h-5 { min-height: var(--jb-space-5) !important; }
  .jb-min-h-6 { min-height: var(--jb-space-6) !important; }
  .jb-min-h-7 { min-height: var(--jb-space-7) !important; }
  .jb-min-h-8 { min-height: var(--jb-space-8) !important; }
  .jb-min-h-9 { min-height: var(--jb-space-9) !important; }
  .jb-min-h-10 { min-height: var(--jb-space-10) !important; }
  .jb-min-h-11 { min-height: var(--jb-space-11) !important; }
  .jb-min-h-12 { min-height: var(--jb-space-12) !important; }
  .jb-max-w-0 { max-width: 0 !important; }
  .jb-max-w-1 { max-width: var(--jb-space-1) !important; }
  .jb-max-w-2 { max-width: var(--jb-space-2) !important; }
  .jb-max-w-3 { max-width: var(--jb-space-3) !important; }
  .jb-max-w-4 { max-width: var(--jb-space-4) !important; }
  .jb-max-w-5 { max-width: var(--jb-space-5) !important; }
  .jb-max-w-6 { max-width: var(--jb-space-6) !important; }
  .jb-max-w-7 { max-width: var(--jb-space-7) !important; }
  .jb-max-w-8 { max-width: var(--jb-space-8) !important; }
  .jb-max-w-9 { max-width: var(--jb-space-9) !important; }
  .jb-max-w-10 { max-width: var(--jb-space-10) !important; }
  .jb-max-w-11 { max-width: var(--jb-space-11) !important; }
  .jb-max-w-12 { max-width: var(--jb-space-12) !important; }
  .jb-max-w-xs { max-width: 20rem !important; }
  .jb-max-w-sm { max-width: 24rem !important; }
  .jb-max-w-md { max-width: 28rem !important; }
  .jb-max-w-lg { max-width: 32rem !important; }
  .jb-max-w-xl { max-width: 36rem !important; }
  .jb-max-w-2xl { max-width: 42rem !important; }
  .jb-max-w-3xl { max-width: 48rem !important; }
  .jb-max-w-4xl { max-width: 56rem !important; }
  .jb-max-w-5xl { max-width: 64rem !important; }
  .jb-max-w-6xl { max-width: 72rem !important; }
  .jb-max-w-7xl { max-width: 80rem !important; }
  .jb-max-w-full { max-width: 100% !important; }
  .jb-max-w-screen { max-width: 100vw !important; }
  .jb-max-w-none { max-width: none !important; }
}

/* =========================
   THEME TOGGLE ANIMATION
   ========================= */

.jb-theme-toggle {
  position: relative;
  overflow: hidden;
  isolation: isolate;
  transition:
    transform 0.22s ease,
    border-color 0.28s ease,
    background 0.28s ease,
    box-shadow 0.28s ease;
}

.jb-theme-toggle:hover {
  transform: translateY(-2px);
}

.jb-theme-toggle:active {
  transform: translateY(0) scale(0.96);
}

.jb-theme-toggle::before {
  content: '';
  position: absolute;
  inset: 7px;
  border-radius: 999px;
  background: color-mix(in srgb, var(--jb-primary) 12%, transparent);
  opacity: 0;
  transform: scale(0.6);
  transition:
    opacity 0.35s ease,
    transform 0.45s cubic-bezier(.22, 1, .36, 1);
  z-index: 0;
}

.jb-theme-toggle {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.jb-theme-toggle__icon {
  position: absolute;
  inset: 0;
  margin: auto;
  width: 22px;
  height: 22px;
  display: grid;
  place-items: center;
  padding: 0;
  font-size: 22px;
  line-height: 1;
  pointer-events: none;
  transition:
    opacity 0.35s ease,
    transform 0.5s cubic-bezier(.22, 1, .36, 1),
    color 0.28s ease;
  z-index: 1;
  transform-origin: center;
}

.jb-theme-toggle__icon.material-symbols-rounded {
  font-size: 22px;
  line-height: 1;
}

/* état par défaut = thème clair -> lune visible */
.jb-theme-toggle__icon--moon {
  opacity: 1;
  transform: rotate(0deg) scale(1);
}

.jb-theme-toggle__icon--sun {
  opacity: 0;
  transform: rotate(-90deg) scale(0.45);
  color: #f5a623;
}

/* thème sombre -> soleil visible */
[data-theme='dark'] .jb-theme-toggle::before {
  opacity: 1;
  transform: scale(1);
}

[data-theme='dark'] .jb-theme-toggle__icon--moon {
  opacity: 0;
  transform: rotate(90deg) scale(0.45);
}

[data-theme='dark'] .jb-theme-toggle__icon--sun {
  opacity: 1;
  transform: rotate(0deg) scale(1);
}

/* petit boost pendant le switch */
.jb-theme-toggle.is-switching {
  animation: jb-theme-toggle-bounce 0.42s cubic-bezier(.22, 1, .36, 1);
}

.jb-theme-toggle.is-switching .jb-theme-toggle__icon--moon,
.jb-theme-toggle.is-switching .jb-theme-toggle__icon--sun {
  transition-duration: 0.42s;
}

@keyframes jb-theme-toggle-bounce {
  0%   { transform: scale(1); }
  35%  { transform: scale(0.88); }
  70%  { transform: scale(1.08); }
  100% { transform: scale(1); }
}

/* =========================
   MOBILE NAVBAR
   ========================= */

.jb-topbar {
  overflow: visible;
}

.jb-topbar__actions {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-left: auto;
}

.jb-notification-center {
  position: relative;
  display: inline-flex;
  align-items: center;
}

.jb-notification-center__trigger {
  position: relative;
  overflow: visible;
}

.jb-notification-center__badge {
  position: absolute;
  top: -5px;
  right: -4px;
  min-width: 20px;
  height: 20px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0 5px;
  border-radius: 999px;
  background: var(--jb-primary);
  color: #fff;
  font-size: 0.72rem;
  font-weight: 800;
  line-height: 1;
  box-shadow: 0 8px 18px rgba(255, 59, 59, 0.24);
}

.jb-notification-center__panel {
  position: absolute;
  top: calc(100% + 12px);
  right: 0;
  z-index: 80;
  width: min(360px, calc(100vw - 24px));
  display: grid;
  gap: 12px;
  padding: 14px;
  border-radius: 24px;
  background: color-mix(in srgb, var(--jb-surface) 96%, transparent);
  border: 1px solid color-mix(in srgb, var(--jb-border) 84%, transparent);
  box-shadow: var(--jb-shadow);
  backdrop-filter: blur(18px);
}

.jb-notification-center__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.jb-notification-center__copy {
  display: grid;
  gap: 4px;
}

.jb-notification-center__copy strong {
  font-size: 0.98rem;
  line-height: 1.2;
}

.jb-notification-center__copy span,
.jb-notification-center__time,
.jb-notification-center__excerpt {
  color: var(--jb-text-muted);
}

.jb-notification-center__count,
.jb-notification-center__pill {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 28px;
  padding: 0 10px;
  border-radius: 999px;
  border: 1px solid color-mix(in srgb, var(--jb-primary) 20%, var(--jb-border));
  background: color-mix(in srgb, var(--jb-primary) 10%, var(--jb-surface));
  color: var(--jb-primary);
  font-size: 0.78rem;
  font-weight: 800;
}

.jb-notification-center__list {
  display: grid;
  gap: 10px;
}

.jb-notification-center__item,
.jb-notification-center__empty {
  display: grid;
  gap: 12px;
  border-radius: 18px;
  background: var(--jb-surface);
  border: 1px solid color-mix(in srgb, var(--jb-border) 84%, transparent);
}

.jb-notification-center__item {
  grid-template-columns: 40px minmax(0, 1fr);
  align-items: start;
  padding: 12px;
  transition: transform 0.2s ease, border-color 0.2s ease, box-shadow 0.2s ease;
}

.jb-notification-center__item:hover {
  transform: translateY(-1px);
  border-color: color-mix(in srgb, var(--jb-primary) 18%, var(--jb-border));
  box-shadow: var(--jb-shadow-soft);
}

.jb-notification-center__item.is-unread {
  border-color: color-mix(in srgb, var(--jb-primary) 20%, var(--jb-border));
  background: color-mix(in srgb, var(--jb-primary) 6%, var(--jb-surface));
}

.jb-notification-center__icon {
  width: 40px;
  height: 40px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 14px;
  background: color-mix(in srgb, var(--jb-primary) 12%, var(--jb-surface));
  color: var(--jb-primary);
}

.jb-notification-center__content,
.jb-notification-center__meta {
  display: grid;
  gap: 6px;
  min-width: 0;
}

.jb-notification-center__meta {
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
}

.jb-notification-center__meta strong,
.jb-notification-center__excerpt {
  overflow-wrap: anywhere;
}

.jb-notification-center__excerpt {
  font-size: 0.9rem;
  line-height: 1.5;
}

.jb-notification-center__time {
  font-size: 0.78rem;
  line-height: 1.3;
}

.jb-notification-center__empty {
  place-items: center;
  padding: 18px 16px;
  text-align: center;
  color: var(--jb-text-muted);
}

.jb-notification-center__empty .material-symbols-rounded {
  color: var(--jb-primary);
}

.jb-nav--desktop {
  display: flex;
  align-items: center;
  gap: 10px;
}

.jb-topbar__mobile-actions {
  display: none;
  align-items: center;
  gap: 10px;
}

.jb-topbar__burger {
  position: relative;
  overflow: hidden;
}

.jb-topbar__burger-open,
.jb-topbar__burger-close {
  position: absolute;
  inset: 0;
  margin: auto;
  width: 22px;
  height: 22px;
  display: grid;
  place-items: center;
  transition: opacity 0.22s ease, transform 0.28s ease;
}

.jb-topbar__burger-open {
  opacity: 1;
  transform: rotate(0deg) scale(1);
}

.jb-topbar__burger-close {
  opacity: 0;
  transform: rotate(-90deg) scale(0.6);
}

.jb-topbar__burger[aria-expanded='true'] .jb-topbar__burger-open {
  opacity: 0;
  transform: rotate(90deg) scale(0.6);
}

.jb-topbar__burger[aria-expanded='true'] .jb-topbar__burger-close {
  opacity: 1;
  transform: rotate(0deg) scale(1);
}

.jb-mobile-nav {
  display: none;
  padding: 0 0 14px;
}

.jb-mobile-nav.is-open {
  display: block;
}

.jb-mobile-nav__panel {
  display: grid;
  gap: 14px;
  padding: 14px;
  border-radius: 24px;
  background: color-mix(in srgb, var(--jb-surface) 94%, transparent);
  border: 1px solid var(--jb-border);
  box-shadow: var(--jb-shadow);
  backdrop-filter: blur(18px);
}

.jb-mobile-nav__links {
  display: grid;
  gap: 10px;
}

.jb-mobile-nav__section {
  display: grid;
  gap: 10px;
  width: 100%;
}

.jb-mobile-nav__link {
  display: flex;
  align-items: center;
  justify-content: space-between;
  min-height: 52px;
  padding: 0 16px;
  border-radius: 18px;
  background: var(--jb-surface);
  border: 1px solid var(--jb-border);
  box-shadow: var(--jb-shadow-soft);
  color: var(--jb-text);
  font-weight: 700;
}

.jb-mobile-nav__link--toggle {
  width: 100%;
  text-align: left;
  cursor: pointer;
}

.jb-mobile-nav__section-panel {
  display: grid;
  gap: 8px;
  padding-left: 14px;
}

.jb-mobile-nav__sublink {
  display: flex;
  align-items: center;
  min-height: 46px;
  padding: 0 16px;
  border-radius: 16px;
  background: color-mix(in srgb, var(--jb-surface-soft) 92%, transparent);
  border: 1px solid color-mix(in srgb, var(--jb-border) 84%, transparent);
  color: var(--jb-text);
  font-weight: 600;
}

.jb-mobile-nav__sublink:hover {
  border-color: color-mix(in srgb, var(--jb-primary) 16%, var(--jb-border));
}

.jb-mobile-nav__link::after {
  content: 'chevron_right';
  font-family: 'Material Symbols Rounded';
  font-size: 20px;
  line-height: 1;
  font-variation-settings:
    'FILL' 0,
    'wght' 400,
    'GRAD' 0,
    'opsz' 24;
}

.jb-mobile-nav__link.jb-mobile-nav__link--toggle::after {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transform: rotate(0deg);
  transition: transform 0.22s ease;
}

.jb-mobile-nav__section.is-open .jb-mobile-nav__link.jb-mobile-nav__link--toggle::after {
  transform: rotate(90deg);
}

.jb-mobile-nav__locales {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
}

.jb-mobile-nav__locales .jb-chip {
  justify-content: center;
}

@media (max-width: 768px) {
  .jb-topbar__inner {
    min-height: 76px;
    gap: 14px;
  }

  .jb-nav--desktop,
  .jb-locale-switcher--desktop {
    display: none;
  }

  .jb-topbar__mobile-actions {
    display: flex;
  }

  .jb-notification-center__panel {
    width: min(360px, calc(100vw - 24px));
  }

  .jb-brand__wordmark {
    font-size: 1.55rem;
  }
}

@media (min-width: 769px) {
  .jb-mobile-nav {
    display: none !important;
  }

  .jb-topbar__mobile-actions {
    display: none !important;
  }
}


.jb-auth {
  min-height: calc(100vh - var(--jb-topbar-height));
}

.jb-input {
  width: 100%;
  min-height: 52px;
  padding: 0 16px;
  border-radius: 16px;
  border: 1px solid var(--jb-border);
  background: var(--jb-surface);
  color: var(--jb-text);
  outline: none;
  transition: border-color .2s ease, box-shadow .2s ease, background-color .2s ease;
}

.jb-input:focus {
  border-color: color-mix(in srgb, var(--jb-primary) 35%, var(--jb-border));
  box-shadow: 0 0 0 4px color-mix(in srgb, var(--jb-primary) 12%, transparent);
}

.jb-auth__error {
  color: var(--jb-primary);
  font-size: .9rem;
}

@media (max-width: 768px) {
  .jb-auth .jb-card {
    padding: 24px !important;
  }
}


/* =========================
   AUTH REDESIGN
   ========================= */

.jb-main {
  min-height: 0;
  flex: 1 0 auto;
}

.jb-site {
  display: flex;
  flex-direction: column;
}

.jb-footer {
  padding: 0 0 clamp(22px, 3vw, 36px);
}

.jb-footer__panel {
  position: relative;
  overflow: hidden;
  padding: clamp(28px, 4vw, 46px);
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 40px;
  background:
    radial-gradient(circle at top left, rgba(255, 59, 59, 0.18), transparent 24%),
    radial-gradient(circle at bottom right, rgba(255, 255, 255, 0.08), transparent 26%),
    linear-gradient(180deg, #22254d 0%, #1f2245 52%, #1b1e3a 100%);
  color: #fff;
  box-shadow: var(--jb-shadow-hero);
}

.jb-footer__panel::before,
.jb-footer__panel::after {
  content: '';
  position: absolute;
  border-radius: 999px;
  pointer-events: none;
}

.jb-footer__panel::before {
  width: 240px;
  height: 240px;
  top: -100px;
  right: -80px;
  background: rgba(255, 255, 255, 0.06);
  filter: blur(18px);
}

.jb-footer__panel::after {
  width: 260px;
  height: 260px;
  left: -110px;
  bottom: -150px;
  background: rgba(255, 59, 59, 0.12);
  filter: blur(28px);
}

.jb-footer__top,
.jb-footer__body,
.jb-footer__bottom {
  position: relative;
  z-index: 1;
}

.jb-footer__top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  margin-bottom: clamp(32px, 5vw, 58px);
}

.jb-footer__brand-pill {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  min-height: 52px;
  padding: 8px 18px 8px 10px;
  border-radius: 999px;
  background: #fff;
  color: #121212;
  font-weight: 800;
  box-shadow: 0 18px 32px rgba(9, 11, 19, 0.16);
}

.jb-footer__brand-pill .job {
  color: #121212;
}

.jb-footer__brand-pill .bridge {
  color: var(--jb-primary);
}

.jb-footer__brand-mark {
  width: 34px;
  height: 34px;
  display: grid;
  place-items: center;
  border-radius: 12px;
  background: var(--jb-gradient-brand);
  color: #fff;
  font-size: 0.8rem;
  font-weight: 900;
  letter-spacing: 0.06em;
}

.jb-footer__cta {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 48px;
  padding: 0 20px;
  border-radius: 999px;
  background: #fff;
  color: #121212;
  font-weight: 800;
  box-shadow: 0 18px 32px rgba(9, 11, 19, 0.16);
}

.jb-footer__body {
  display: grid;
  grid-template-columns: minmax(300px, 380px) minmax(0, 1fr);
  gap: clamp(34px, 5vw, 88px);
}

.jb-footer__showcase {
  display: grid;
  gap: 26px;
  align-content: start;
}

.jb-footer__glyph {
  width: 68px;
  height: 68px;
  display: grid;
  place-items: center;
  border-radius: 24px;
  background: rgba(255, 255, 255, 0.08);
  border: 1px solid rgba(255, 255, 255, 0.1);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.06);
}

.jb-footer__glyph .material-symbols-rounded {
  font-size: 34px;
  color: #fff;
}

.jb-footer__copyblock,
.jb-footer__meta,
.jb-footer__locale-card,
.jb-footer__shortcut-block,
.jb-footer__column {
  display: grid;
  gap: 14px;
  align-content: start;
}

.jb-footer__title {
  margin: 0;
  max-width: 9ch;
  font-size: clamp(2.4rem, 4.2vw, 4rem);
  line-height: 0.92;
  letter-spacing: -0.055em;
}

.jb-footer__lead,
.jb-footer__copyright {
  margin: 0;
  color: rgba(255, 255, 255, 0.72);
  line-height: 1.8;
}

.jb-footer__label {
  color: rgba(255, 255, 255, 0.74);
  font-size: 0.92rem;
  font-weight: 700;
}

.jb-footer__locale-current {
  width: 100%;
  min-height: 52px;
  padding: 0 18px;
  border-radius: 18px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  background: rgba(255, 255, 255, 0.09);
  border: 1px solid rgba(255, 255, 255, 0.1);
  color: #fff;
  font-weight: 700;
  text-align: left;
  cursor: pointer;
  transition: background 0.22s ease, border-color 0.22s ease, transform 0.22s ease, box-shadow 0.22s ease;
}

.jb-footer__locale-current:hover,
.jb-footer__locale-card.is-open .jb-footer__locale-current {
  background: rgba(255, 255, 255, 0.12);
  border-color: rgba(255, 59, 59, 0.42);
  box-shadow: 0 12px 24px rgba(9, 11, 19, 0.18);
}

.jb-footer__locale-current:focus-visible {
  outline: none;
  border-color: rgba(255, 59, 59, 0.52);
  box-shadow: 0 0 0 4px rgba(255, 59, 59, 0.18);
}

.jb-footer__locale-value {
  flex: 1 1 auto;
  min-width: 0;
}

.jb-footer__locale-chevron,
.jb-footer__locale-current .material-symbols-rounded {
  flex: 0 0 auto;
  pointer-events: none;
  transition: transform 0.22s ease;
}

.jb-footer__locale-card {
  position: relative;
}

.jb-footer__locale-card.is-open .jb-footer__locale-chevron {
  transform: rotate(180deg);
}

.jb-footer__locale-panel {
  position: absolute;
  top: calc(100% + 10px);
  left: 0;
  right: 0;
  z-index: 20;
  display: grid;
  gap: 8px;
  padding: 10px;
  border-radius: 22px;
  background: rgba(26, 29, 58, 0.98);
  border: 1px solid rgba(255, 255, 255, 0.12);
  box-shadow: 0 22px 50px rgba(6, 8, 18, 0.34);
  backdrop-filter: blur(16px);
}

.jb-footer__locale-panel[hidden] {
  display: none !important;
}

.jb-footer__locale-option {
  display: flex;
  align-items: center;
  justify-content: space-between;
  min-height: 46px;
  padding: 0 14px;
  border-radius: 14px;
  color: rgba(255, 255, 255, 0.94);
  font-weight: 700;
  transition: background 0.18s ease, color 0.18s ease, transform 0.18s ease;
}

.jb-footer__locale-option:hover {
  background: rgba(255, 255, 255, 0.08);
  color: #fff;
  transform: translateY(-1px);
}

.jb-footer__locale-option.is-active {
  background: rgba(255, 59, 59, 0.16);
  color: #fff;
}

.jb-footer__locale-option .material-symbols-rounded {
  font-size: 18px;
}

.jb-footer__shortcut-list {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
}

.jb-footer__shortcut {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 44px;
  width: 44px;
  padding: 0;
  border-radius: 999px;
  border: 1px solid rgba(255, 255, 255, 0.12);
  background: rgba(255, 255, 255, 0.05);
  color: #fff;
  font-weight: 700;
  transition: transform 0.22s ease, border-color 0.22s ease, background 0.22s ease;
}

.jb-footer__shortcut:hover {
  transform: translateY(-2px);
  background: rgba(255, 59, 59, 0.18);
  border-color: rgba(255, 59, 59, 0.42);
}

.jb-footer__nav {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, .9fr)) minmax(220px, 1.35fr);
  gap: clamp(22px, 3vw, 34px);
  align-content: start;
  align-items: start;
}

.jb-footer__column-title {
  margin: 0;
  color: rgba(255, 255, 255, 0.62);
  font-size: 0.92rem;
  font-weight: 700;
}

.jb-footer__column-copy {
  margin: 0;
  color: rgba(255, 255, 255, 0.72);
  line-height: 1.72;
}

.jb-footer__brand-highlights {
  display: grid;
  gap: 10px;
}

.jb-footer__brand-highlight {
  display: flex;
  align-items: center;
  gap: 10px;
  min-height: 44px;
  padding: 0 14px;
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.06);
  border: 1px solid rgba(255, 255, 255, 0.08);
  color: rgba(255, 255, 255, 0.92);
  font-weight: 700;
}

.jb-footer__brand-highlight .material-symbols-rounded {
  font-size: 18px;
  color: var(--jb-primary);
}

.jb-footer__links,
.jb-footer__locale-list {
  display: grid;
  gap: 14px;
}

.jb-footer__links a,
.jb-footer__bottom-links a,
.jb-footer__privacy-link,
.jb-footer__locale {
  width: fit-content;
  color: rgba(255, 255, 255, 0.94);
  font-weight: 700;
  line-height: 1.35;
  transition: color 0.22s ease, transform 0.22s ease;
}

.jb-footer__links a:hover,
.jb-footer__bottom-links a:hover,
.jb-footer__privacy-link:hover,
.jb-footer__locale:hover,
.jb-footer__locale.is-active {
  color: var(--jb-primary);
  transform: translateX(2px);
}

.jb-footer__privacy-link {
  padding: 0;
  border: 0;
  background: transparent;
  cursor: pointer;
  text-align: left;
}

.jb-footer__link-with-badge {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}

.jb-footer__live-badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 3px 10px;
  border-radius: 999px;
  background: var(--jb-primary);
  color: #fff;
  font-size: 10px;
  font-weight: 800;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  line-height: 1;
  box-shadow: 0 0 0 0 rgba(255, 59, 59, 0.55);
  animation: jb-footer-live-pulse 1.8s ease-out infinite;
}

.jb-footer__live-dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: #fff;
  box-shadow: 0 0 0 0 rgba(255, 255, 255, 0.8);
  animation: jb-footer-live-dot 1.4s ease-out infinite;
}

@keyframes jb-footer-live-pulse {
  0% {
    box-shadow: 0 0 0 0 rgba(255, 59, 59, 0.55);
  }
  70% {
    box-shadow: 0 0 0 10px rgba(255, 59, 59, 0);
  }
  100% {
    box-shadow: 0 0 0 0 rgba(255, 59, 59, 0);
  }
}

@keyframes jb-footer-live-dot {
  0%, 100% {
    opacity: 1;
  }
  50% {
    opacity: 0.45;
  }
}

.jb-footer__links a:hover .jb-footer__live-badge {
  transform: translateX(-2px);
}

.jb-footer__bottom {
  margin-top: clamp(32px, 5vw, 56px);
  padding-top: 20px;
  border-top: 1px solid rgba(255, 255, 255, 0.12);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
}

.jb-footer__bottom-links {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: flex-end;
  gap: 18px;
}

@media (max-width: 1100px) {
  .jb-footer__body {
    grid-template-columns: 1fr;
  }

  .jb-footer__nav {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .jb-footer__column--brand {
    grid-column: 1 / -1;
  }
}

@media (max-width: 768px) {
  .jb-footer {
    padding-bottom: 16px;
  }

  .jb-footer__panel {
    padding: 22px 18px;
    border-radius: 28px;
  }

  .jb-footer__top,
  .jb-footer__bottom {
    flex-direction: column;
    align-items: flex-start;
  }

  .jb-footer__cta {
    width: 100%;
  }

  .jb-footer__title {
    max-width: none;
    font-size: clamp(2rem, 9vw, 2.9rem);
  }

  .jb-footer__nav {
    grid-template-columns: 1fr;
  }

  .jb-footer__bottom-links {
    justify-content: flex-start;
  }
}

.jb-team-page {
  background:
    radial-gradient(circle at top left, color-mix(in srgb, var(--jb-primary) 8%, transparent), transparent 30%),
    radial-gradient(circle at bottom right, rgba(34, 37, 77, 0.3), transparent 28%),
    var(--jb-surface-alt);
}

.jb-team-hero {
  padding: clamp(18px, 3vw, 28px) 0 0;
}

.jb-team-hero__panel {
  position: relative;
  overflow: hidden;
  min-height: min(760px, calc(100vh - var(--jb-topbar-height) - 40px));
  padding: clamp(28px, 4vw, 48px);
  border-radius: 40px;
}

.jb-team-hero__panel::before,
.jb-team-hero__panel::after {
  content: '';
  position: absolute;
  border-radius: 999px;
  pointer-events: none;
  filter: blur(18px);
}

.jb-team-hero__panel::before {
  width: 260px;
  height: 260px;
  top: -80px;
  left: -60px;
  background: rgba(255, 59, 59, 0.14);
}

.jb-team-hero__panel::after {
  width: 220px;
  height: 220px;
  right: -60px;
  bottom: -60px;
  background: rgba(255, 255, 255, 0.08);
}

.jb-team-hero__grid {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: minmax(0, 1.15fr) minmax(320px, 420px);
  gap: clamp(28px, 4vw, 56px);
  align-items: center;
}

.jb-team-hero__copy,
.jb-team-showcase,
.jb-team-showcase__members,
.jb-team-showcase__header,
.jb-team-showcase__pillars,
.jb-team-role,
.jb-team-role__header,
.jb-team-card {
  display: grid;
  gap: 18px;
}

.jb-team-breadcrumbs {
  display: inline-flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 8px;
  color: rgba(255, 255, 255, 0.72);
  font-weight: 700;
}

.jb-team-breadcrumbs strong {
  color: #fff;
}

.jb-team-hero__title {
  margin: 0;
  max-width: 10ch;
  font-size: clamp(3rem, 6vw, 5.2rem);
  line-height: 0.92;
  letter-spacing: -0.06em;
}

.jb-team-hero__lead {
  margin: 0;
  max-width: 58ch;
  color: rgba(255, 255, 255, 0.78);
  font-size: clamp(1rem, 1.6vw, 1.1rem);
  line-height: 1.85;
}

.jb-team-stats {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 16px;
}

.jb-team-stat {
  padding: 18px 18px 20px;
  border-radius: 24px;
  background: rgba(255, 255, 255, 0.08);
  border: 1px solid rgba(255, 255, 255, 0.1);
  backdrop-filter: blur(14px);
}

.jb-team-stat span {
  display: block;
  margin-bottom: 10px;
  color: rgba(255, 255, 255, 0.68);
  font-size: 0.84rem;
  text-transform: uppercase;
  letter-spacing: 0.06em;
}

.jb-team-stat strong {
  display: block;
  font-size: clamp(1.5rem, 2vw, 2.2rem);
  line-height: 1;
}

.jb-team-showcase {
  align-content: start;
  padding: clamp(22px, 3vw, 30px);
  border-radius: 32px;
  background: rgba(255, 255, 255, 0.08);
  border: 1px solid rgba(255, 255, 255, 0.12);
  backdrop-filter: blur(18px);
}

.jb-team-showcase__eyebrow {
  display: inline-flex;
  width: fit-content;
  min-height: 36px;
  padding: 0 12px;
  align-items: center;
  border-radius: 999px;
  background: rgba(255, 59, 59, 0.18);
  color: #fff;
  font-size: 0.78rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.jb-team-showcase__header h2 {
  margin: 0;
  font-size: clamp(1.6rem, 2.4vw, 2.1rem);
  line-height: 1.05;
  letter-spacing: -0.04em;
}

.jb-team-showcase__member {
  display: grid;
  grid-template-columns: 56px minmax(0, 1fr);
  gap: 14px;
  align-items: center;
  padding: 14px 16px;
  border-radius: 22px;
  background: rgba(12, 14, 24, 0.18);
  border: 1px solid rgba(255, 255, 255, 0.08);
}

.jb-team-showcase__member strong,
.jb-team-showcase__member span,
.jb-team-showcase__empty {
  color: #fff;
}

.jb-team-showcase__member span,
.jb-team-showcase__empty {
  color: rgba(255, 255, 255, 0.7);
}

.jb-team-showcase__empty {
  padding: 18px;
  border-radius: 22px;
  background: rgba(12, 14, 24, 0.18);
  border: 1px solid rgba(255, 255, 255, 0.08);
}

.jb-team-avatar {
  width: 56px;
  height: 56px;
  display: grid;
  place-items: center;
  border-radius: 18px;
  background: linear-gradient(135deg, var(--team-accent, var(--team-role-color, var(--jb-primary))), color-mix(in srgb, var(--team-accent, var(--team-role-color, var(--jb-primary))) 46%, #ffffff));
  color: #fff;
  font-weight: 900;
  letter-spacing: 0.04em;
  box-shadow: 0 14px 24px rgba(10, 13, 18, 0.16);
}

.jb-team-pillar {
  display: flex;
  align-items: center;
  gap: 10px;
  min-height: 46px;
  padding: 0 14px;
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.06);
  border: 1px solid rgba(255, 255, 255, 0.08);
  color: rgba(255, 255, 255, 0.92);
  font-weight: 700;
}

.jb-team-pillar .material-symbols-rounded {
  font-size: 18px;
  color: var(--jb-primary);
}

.jb-team-directory__lead {
  margin: 0;
  max-width: 52ch;
  color: var(--jb-text-muted);
  line-height: 1.78;
}

.jb-team-role {
  margin-top: clamp(26px, 4vw, 40px);
}

.jb-team-role__header {
  grid-template-columns: minmax(0, 280px) minmax(0, 1fr);
  align-items: end;
  gap: 20px;
  margin-bottom: 22px;
}

.jb-team-role__eyebrow {
  display: inline-flex;
  align-items: center;
  width: fit-content;
  min-height: 38px;
  padding: 0 14px;
  border-radius: 999px;
  background: color-mix(in srgb, var(--team-role-color, var(--jb-primary)) 12%, var(--jb-surface));
  border: 1px solid color-mix(in srgb, var(--team-role-color, var(--jb-primary)) 24%, var(--jb-border));
  color: var(--team-role-color, var(--jb-primary));
  font-size: 0.82rem;
  font-weight: 800;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.jb-team-role__title {
  margin: 0;
  font-size: clamp(1.7rem, 2.6vw, 2.4rem);
  letter-spacing: -0.04em;
}

.jb-team-role__copy {
  margin: 0;
  color: var(--jb-text-muted);
  line-height: 1.78;
}

.jb-team-role__count {
  display: inline-flex;
  width: fit-content;
  min-height: 38px;
  padding: 0 12px;
  align-items: center;
  border-radius: 999px;
  background: color-mix(in srgb, var(--jb-surface-soft) 92%, transparent);
  border: 1px solid color-mix(in srgb, var(--jb-border) 84%, transparent);
  color: var(--jb-text);
  font-weight: 700;
}

.jb-team-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: clamp(18px, 2.5vw, 24px);
}

.jb-team-card {
  min-height: 100%;
  align-content: start;
}

.jb-team-card__head {
  display: grid;
  grid-template-columns: 56px minmax(0, 1fr);
  gap: 14px;
  align-items: center;
}

.jb-team-card__name {
  margin: 0;
  font-size: 1.18rem;
  letter-spacing: -0.03em;
}

.jb-team-card__handle,
.jb-team-card__copy {
  color: var(--jb-text-muted);
}

.jb-team-card__copy {
  margin: 0;
  line-height: 1.74;
}

.jb-team-card__role {
  display: inline-flex;
  align-items: center;
  width: fit-content;
  gap: 10px;
  min-height: 40px;
  padding: 0 14px;
  border-radius: 999px;
  background: color-mix(in srgb, var(--team-role-color, var(--jb-primary)) 10%, var(--jb-surface));
  border: 1px solid color-mix(in srgb, var(--team-role-color, var(--jb-primary)) 20%, var(--jb-border));
  color: var(--team-role-color, var(--jb-primary));
}

.jb-team-card__role-dot {
  width: 10px;
  height: 10px;
  border-radius: 999px;
  background: var(--team-role-color, var(--jb-primary));
  box-shadow: 0 0 0 6px color-mix(in srgb, var(--team-role-color, var(--jb-primary)) 14%, transparent);
}

.jb-team-card__tags {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.jb-team-card__tag {
  display: inline-flex;
  align-items: center;
  min-height: 34px;
  padding: 0 12px;
  border-radius: 999px;
  background: var(--jb-surface-soft);
  border: 1px solid color-mix(in srgb, var(--jb-border) 84%, transparent);
  color: var(--jb-text);
  font-size: 0.84rem;
  font-weight: 700;
}

.jb-team-empty {
  display: grid;
  gap: 10px;
  text-align: center;
}

@media (max-width: 1100px) {
  .jb-team-hero__grid,
  .jb-team-role__header,
  .jb-team-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 768px) {
  .jb-team-hero__panel {
    min-height: auto;
    padding: 22px 18px;
    border-radius: 28px;
  }

  .jb-team-hero__title {
    max-width: none;
    font-size: clamp(2.2rem, 12vw, 3.6rem);
  }

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

.jb-auth-page {
  background:
    radial-gradient(circle at top left, color-mix(in srgb, var(--jb-primary) 8%, transparent), transparent 34%),
    radial-gradient(circle at bottom right, color-mix(in srgb, var(--jb-primary) 7%, transparent), transparent 32%),
    var(--jb-surface-alt);
}

.jb-auth-main {
  position: relative;
}

.jb-auth-screen {
  position: relative;
  padding: clamp(28px, 4vw, 42px) 0 clamp(48px, 8vw, 96px);
}

.jb-auth-screen::before,
.jb-auth-screen::after {
  content: '';
  position: absolute;
  inset: auto;
  border-radius: 999px;
  filter: blur(48px);
  pointer-events: none;
  opacity: .9;
}

.jb-auth-screen::before {
  width: 240px;
  height: 240px;
  top: 48px;
  left: max(24px, calc(50% - 760px));
  background: color-mix(in srgb, var(--jb-primary) 14%, transparent);
}

.jb-auth-screen::after {
  width: 180px;
  height: 180px;
  right: max(24px, calc(50% - 720px));
  bottom: 48px;
  background: color-mix(in srgb, var(--jb-primary) 10%, transparent);
}

.jb-auth-shell {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: minmax(320px, 1fr) minmax(420px, 540px);
  gap: clamp(24px, 3.5vw, 44px);
  align-items: stretch;
}

.jb-auth-shell--register {
  grid-template-columns: minmax(320px, .95fr) minmax(480px, 640px);
}

.jb-auth-showcase,
.jb-auth-card,
.jb-dashboard-hero,
.jb-dashboard-card {
  border-color: color-mix(in srgb, var(--jb-border) 88%, transparent);
}

.jb-auth-showcase {
  min-height: 100%;
}

.jb-auth-showcase__inner {
  position: relative;
  z-index: 1;
  display: grid;
  align-content: space-between;
  min-height: 100%;
  gap: clamp(28px, 4vw, 40px);
}

.jb-auth-kicker {
  width: fit-content;
}

.jb-auth-title {
  margin: 0;
  max-width: 11ch;
  font-size: clamp(2.6rem, 5vw, 4.4rem);
  line-height: .94;
  letter-spacing: -.05em;
}

.jb-auth-lead {
  margin: 0;
  max-width: 56ch;
  color: rgba(var(--jb-text-rgb), .78);
  font-size: clamp(1rem, 1.4vw, 1.08rem);
  line-height: 1.82;
}

.jb-auth-statgrid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 16px;
}

.jb-auth-stat {
  padding: 18px 18px 20px;
  border-radius: 24px;
  background: rgba(var(--jb-surface-reverse-rgb),.08);
  border: 1px solid rgba(var(--jb-surface-reverse-rgb),.1);
  backdrop-filter: blur(14px);
}

.jb-auth-stat span {
  display: block;
  color: rgba(var(--jb-text-rgb), .66);
  font-size: .82rem;
  margin-bottom: 8px;
}

.jb-auth-stat strong {
  display: block;
  font-size: 1.05rem;
  line-height: 1.15;
}

.jb-auth-benefits {
  display: grid;
  gap: 14px;
}

.jb-auth-benefit {
  display: flex;
  align-items: flex-start;
  gap: 12px;
}

.jb-auth-benefit span {
  width: 10px;
  height: 10px;
  margin-top: 8px;
  border-radius: 999px;
  background: var(--jb-primary);
  box-shadow: 0 0 0 8px rgba(255,255,255,.08);
}

.jb-auth-benefit p {
  margin: 0;
  color: rgba(255,255,255,.78);
  line-height: 1.7;
}

.jb-auth-card {
  position: relative;
  z-index: 1;
  padding: clamp(24px, 3vw, 38px);
  display: grid;
  align-content: start;
  gap: 26px;
  overflow: visible;
}

.jb-auth-card::before {
  content: '';
  position: absolute;
  inset: -1px;
  border-radius: inherit;
  padding: 1px;
  background: linear-gradient(145deg, color-mix(in srgb, var(--jb-primary) 24%, transparent), transparent 36%);
  -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  -webkit-mask-composite: xor;
          mask-composite: exclude;
  pointer-events: none;
}

.jb-auth-card__header {
  display: grid;
  gap: 20px;
}

.jb-auth-card__title {
  margin: 0;
  font-size: clamp(1.8rem, 3vw, 2.4rem);
  line-height: 1;
  letter-spacing: -.04em;
}

.jb-auth-form {
  display: grid;
  gap: 18px;
}

.jb-auth-socials {
  display: grid;
  gap: 12px;
}

.jb-auth-social {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  width: 100%;
  min-height: 54px;
  padding: 0 16px;
  border-radius: 18px;
  border: 1px solid color-mix(in srgb, var(--jb-border) 88%, transparent);
  background: color-mix(in srgb, var(--jb-surface) 96%, transparent);
  color: var(--jb-text);
  font-weight: 700;
  text-decoration: none;
  box-shadow: var(--jb-shadow-soft);
}

.jb-auth-social__icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 34px;
  height: 34px;
  margin-right: 12px;
  border-radius: 999px;
  background: color-mix(in srgb, var(--jb-primary) 10%, var(--jb-surface));
  color: var(--jb-primary);
  font-size: .8rem;
  font-weight: 900;
  letter-spacing: .04em;
  flex: 0 0 auto;
}

.jb-auth-divider {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--jb-text-muted);
  font-size: .82rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .08em;
}

.jb-auth-divider::before,
.jb-auth-divider::after {
  content: '';
  flex: 1;
  border-top: 1px solid color-mix(in srgb, var(--jb-border) 84%, transparent);
}

.jb-auth-divider::before {
  margin-right: 14px;
}

.jb-auth-divider::after {
  margin-left: 14px;
}

.jb-auth-alert {
  padding: 14px 16px;
  border-radius: 16px;
  border: 1px solid color-mix(in srgb, var(--jb-primary) 18%, var(--jb-border));
  background: color-mix(in srgb, var(--jb-primary) 10%, var(--jb-surface));
  color: var(--jb-primary-dark);
  font-size: .94rem;
  font-weight: 700;
  line-height: 1.55;
}

.jb-auth-alert--success {
  border-color: color-mix(in srgb, var(--jb-success) 26%, var(--jb-border));
  background: color-mix(in srgb, var(--jb-success) 12%, var(--jb-surface));
  color: color-mix(in srgb, var(--jb-success) 74%, var(--jb-text));
}

.jb-auth-field {
  display: grid;
  gap: 10px;
}

.jb-auth-field label {
  font-weight: 700;
  letter-spacing: -.01em;
}

.jb-input {
  width: 100%;
  min-height: 58px;
  padding: 0 18px;
  border-radius: 18px;
  border: 1px solid color-mix(in srgb, var(--jb-border) 92%, transparent);
  background: color-mix(in srgb, var(--jb-surface) 88%, transparent);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.65);
  color: var(--jb-text);
  outline: none;
  transition: border-color .2s ease, box-shadow .25s ease, transform .2s ease, background-color .2s ease;
}

.jb-input::placeholder {
  color: color-mix(in srgb, var(--jb-text-muted) 76%, transparent);
}

.jb-input:focus {
  border-color: color-mix(in srgb, var(--jb-primary) 30%, var(--jb-border));
  box-shadow:
    0 0 0 4px color-mix(in srgb, var(--jb-primary) 10%, transparent),
    0 16px 36px rgba(10, 13, 18, 0.08);
  transform: translateY(-1px);
}

.flatpickr-calendar {
  border: 1px solid color-mix(in srgb, var(--jb-border) 84%, transparent);
  border-radius: 20px;
  background: var(--jb-surface);
  box-shadow: 0 24px 70px rgba(10, 13, 18, .18);
  color: var(--jb-text);
  font-family: inherit;
}

.flatpickr-calendar.arrowTop::before,
.flatpickr-calendar.arrowTop::after,
.flatpickr-calendar.arrowBottom::before,
.flatpickr-calendar.arrowBottom::after {
  display: none;
}

.flatpickr-months,
.flatpickr-weekdays {
  background: color-mix(in srgb, var(--jb-surface-soft) 86%, transparent);
}

.flatpickr-months .flatpickr-month,
.flatpickr-current-month,
.flatpickr-weekday,
.flatpickr-day {
  color: var(--jb-text);
}

.flatpickr-current-month .flatpickr-monthDropdown-months,
.flatpickr-current-month input.cur-year,
.flatpickr-time input,
.flatpickr-time .flatpickr-am-pm {
  color: var(--jb-text);
  font-family: inherit;
  font-weight: 750;
}

.flatpickr-day {
  border-radius: 12px;
}

.flatpickr-day:hover,
.flatpickr-day:focus {
  border-color: color-mix(in srgb, var(--jb-primary) 18%, var(--jb-border));
  background: color-mix(in srgb, var(--jb-primary) 9%, var(--jb-surface));
}

.flatpickr-day.selected,
.flatpickr-day.startRange,
.flatpickr-day.endRange,
.flatpickr-day.selected:hover {
  border-color: var(--jb-primary);
  background: var(--jb-primary);
  color: #fff;
}

.flatpickr-day.today {
  border-color: color-mix(in srgb, var(--jb-primary) 46%, var(--jb-border));
}

.flatpickr-day.flatpickr-disabled,
.flatpickr-day.prevMonthDay,
.flatpickr-day.nextMonthDay {
  color: var(--jb-text-muted);
}

.flatpickr-time {
  border-top-color: color-mix(in srgb, var(--jb-border) 84%, transparent);
}

.jb-auth-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
}

.jb-auth-check {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  color: var(--jb-text-muted);
}

.jb-auth-check input {
  accent-color: var(--jb-primary);
}

.jb-auth-check--full {
  align-items: flex-start;
  line-height: 1.7;
}

.jb-auth-helper {
  color: var(--jb-text-muted);
  font-size: .92rem;
}

.jb-auth-footer {
  margin: 2px 0 0;
  color: var(--jb-text-muted);
  line-height: 1.75;
}

.jb-auth__error {
  color: var(--jb-primary);
  font-size: .9rem;
  font-weight: 600;
}

.jb-dashboard-shell {
  display: grid;
  gap: 26px;
}

.jb-dashboard-hero {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 220px;
  gap: 24px;
  align-items: end;
}

.jb-dashboard-hero__main,
.jb-dashboard-hero__aside {
  position: relative;
  z-index: 1;
}

.jb-dashboard-hero__aside {
  display: grid;
  align-items: end;
}

.jb-dashboard-grid {
  display: grid;
  grid-template-columns: repeat(12, minmax(0, 1fr));
  gap: 24px;
}

.jb-dashboard-card {
  min-height: 100%;
  padding: clamp(22px, 2.8vw, 32px);
}

.jb-dashboard-card:nth-child(1) { grid-column: span 5; }
.jb-dashboard-card:nth-child(2) { grid-column: span 7; }
.jb-dashboard-card--wide { grid-column: 1 / -1; }

.jb-dashboard-card__head {
  display: flex;
  justify-content: space-between;
  gap: 18px;
  align-items: flex-start;
}

.jb-dashboard-card__eyebrow {
  display: inline-block;
  color: var(--jb-text-muted);
  font-size: .82rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .06em;
}

.jb-dashboard-card__title {
  margin: 0;
  font-size: 1.35rem;
  letter-spacing: -.03em;
}

.jb-dashboard-profile {
  display: flex;
  align-items: center;
  gap: 18px;
}

.jb-dashboard-avatar {
  display: grid;
  place-items: center;
  width: 74px;
  height: 74px;
  border-radius: 24px;
  background: var(--jb-gradient-brand);
  color: #fff;
  font-size: 1.15rem;
  font-weight: 900;
  box-shadow: 0 18px 36px rgba(255, 59, 59, .18);
}

.jb-dashboard-avatar--image {
  object-fit: cover;
  background: var(--jb-surface-soft);
  color: transparent;
}

.jb-dashboard-avatar-form {
  display: grid;
  gap: 16px;
}

.jb-dashboard-avatar-form__footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  flex-wrap: wrap;
}

.jb-dashboard-avatar-form__footer .jb-job-copy {
  margin: 0;
}

.jb-dashboard-abilities {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
}

.jb-dashboard-abilities .jb-tag {
  min-height: 40px;
  padding: 8px 14px;
  border-radius: 999px;
  background: var(--jb-surface-soft);
  border: 1px solid color-mix(in srgb, var(--jb-border) 88%, transparent);
  box-shadow: none;
  font-size: .92rem;
}

[data-theme='dark'] .jb-auth-card,
[data-theme='dark'] .jb-dashboard-card {
  background: color-mix(in srgb, var(--jb-surface) 94%, transparent);
}

[data-theme='dark'] .jb-auth-social {
  background: color-mix(in srgb, var(--jb-surface-soft) 84%, transparent);
  border-color: color-mix(in srgb, var(--jb-border) 84%, transparent);
}

[data-theme='dark'] .jb-auth-social__icon {
  background: color-mix(in srgb, var(--jb-primary) 14%, var(--jb-surface-soft));
}

[data-theme='dark'] .jb-input {
  background: color-mix(in srgb, var(--jb-surface-soft) 84%, transparent);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.02);
}

@media (max-width: 1200px) {
  .jb-auth-shell,
  .jb-auth-shell--register,
  .jb-dashboard-hero {
    grid-template-columns: 1fr;
  }

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

  .jb-dashboard-card,
  .jb-dashboard-card--wide {
    grid-column: auto;
  }
}

@media (max-width: 768px) {
  .jb-auth-screen {
    padding-top: 24px;
  }

  .jb-auth-shell {
    gap: 18px;
  }

  .jb-auth-title {
    max-width: none;
    font-size: clamp(2.1rem, 10vw, 3rem);
  }

  .jb-auth-card,
  .jb-auth-showcase,
  .jb-dashboard-card,
  .jb-dashboard-hero {
    border-radius: 26px;
  }

  .jb-auth-card {
    padding: 22px;
  }

  .jb-auth-statgrid {
    grid-template-columns: 1fr;
  }

  .jb-auth-row,
  .jb-dashboard-card__head,
  .jb-dashboard-profile {
    flex-direction: column;
    align-items: flex-start;
  }

  .jb-dashboard-avatar-form__footer {
    align-items: stretch;
  }

  .jb-dashboard-avatar-form__footer .jb-button {
    width: 100%;
  }
}


/* =========================
   MOBILE RESOLUTION HOTFIX
   ========================= */

:root {
  --jb-safe-top: env(safe-area-inset-top, 0px);
  --jb-safe-right: env(safe-area-inset-right, 0px);
  --jb-safe-bottom: env(safe-area-inset-bottom, 0px);
  --jb-safe-left: env(safe-area-inset-left, 0px);
  --jb-mobile-gutter: 12px;
}

html,
body,
.jb-site {
  max-width: 100%;
  overflow-x: clip;
}

.jb-container,
.container {
  width: min(100%, var(--jb-container));
  padding-left: max(12px, var(--jb-safe-left));
  padding-right: max(12px, var(--jb-safe-right));
}

.jb-hero,
.jb-hero__panel,
.jb-hero__content,
.jb-search-card,
.jb-search-meta,
.jb-stat {
  min-width: 0;
}

.jb-hero__title,
.jb-panel__title,
.jb-job-hero__title {
  overflow-wrap: anywhere;
  word-break: break-word;
  text-wrap: balance;
}

.jb-badges,
.jb-filters,
.jb-auth-statgrid,
.jb-dashboard-abilities {
  min-width: 0;
}

.jb-badge,
.jb-chip,
.jb-tag {
  max-width: 100%;
}

@media (max-width: 900px) {
  .jb-hero__content,
  .jb-detail,
  .jb-job-hero__grid,
  .jb-job-layout {
    grid-template-columns: 1fr;
    gap: 22px;
    align-items: start;
  }

  .jb-hero__panel {
    min-height: auto;
  }
}

@media (max-width: 768px) {
  :root {
    --jb-mobile-gutter: 12px;
  }

  .jb-topbar {
    padding-top: var(--jb-safe-top);
  }

  .jb-topbar__inner {
    gap: 12px;
    min-height: 72px;
  }

  .jb-topbar__actions,
  .jb-topbar__mobile-actions,
  .jb-brand {
    min-width: 0;
  }

  .jb-topbar__mobile-actions {
    flex: 0 0 auto;
  }

  .jb-topbar__mobile-actions .jb-icon-button {
    flex: 0 0 46px;
  }

  .jb-brand__wordmark {
    font-size: clamp(1.35rem, 7vw, 1.8rem);
  }

  .jb-hero {
    padding-top: 16px;
    padding-bottom: 28px;
  }

  .jb-hero__panel {
    padding: 20px;
    border-radius: 24px;
  }

  .jb-hero__panel::before {
    width: 180px;
    height: 180px;
    right: -70px;
    top: -70px;
  }

  .jb-hero__panel::after {
    width: 120px;
    height: 120px;
    left: -50px;
    bottom: -50px;
  }

  .jb-hero__content {
    gap: 20px;
    align-items: start;
  }

  .jb-kicker {
    width: fit-content;
    max-width: 100%;
    min-height: 40px;
    padding: 10px 14px;
  }

  .jb-hero__title {
    margin: 16px 0 14px;
    font-size: clamp(2.25rem, 13vw, 3.6rem);
    line-height: .98;
    max-width: none;
    text-wrap: pretty;
  }

  .jb-hero__lead {
    margin-bottom: 24px;
    max-width: none;
    font-size: 1rem;
    line-height: 1.72;
  }

  .jb-badges,
  .jb-filters {
    gap: 8px;
  }

  .jb-badge,
  .jb-chip {
    min-height: 38px;
    padding: 8px 12px;
    font-size: 0.88rem;
  }

  .jb-search-card {
    width: 100%;
    padding: 18px;
    border-radius: 22px;
  }

  .jb-search-meta {
    gap: 12px;
    margin-top: 16px;
  }

  .jb-stat {
    padding: 16px;
    border-radius: 18px;
  }

  .jb-stat__value {
    font-size: 1.3rem;
  }
}

@media (max-width: 430px) {
  :root {
    --jb-mobile-gutter: 14px;
  }

  .jb-container,
  .container {
    padding-left: max(14px, var(--jb-safe-left));
    padding-right: max(14px, var(--jb-safe-right));
  }

  .jb-brand__wordmark {
    font-size: clamp(1.2rem, 8vw, 1.55rem);
  }

  .jb-hero__panel {
    padding: 18px;
    border-radius: 22px;
  }

  .jb-hero__title {
    font-size: clamp(2rem, 12vw, 3rem);
  }

  .jb-hero__lead {
    font-size: 0.96rem;
  }
}

@supports not (overflow: clip) {
  html,
  body,
  .jb-site {
    overflow-x: hidden;
  }
}

/* =========================
   LEGAL PAGES
   ========================= */

.jb-legal-page {
  background:
    radial-gradient(circle at top left, color-mix(in srgb, var(--jb-primary) 8%, transparent), transparent 30%),
    var(--jb-surface-alt);
}

.jb-legal-hero {
  padding: clamp(34px, 5vw, 68px) 0 clamp(22px, 4vw, 42px);
}

.jb-legal-hero__inner {
  display: grid;
  gap: 16px;
  max-width: 900px;
}

.jb-legal-hero__eyebrow {
  width: fit-content;
  display: inline-flex;
  align-items: center;
  min-height: 38px;
  padding: 0 14px;
  border-radius: 999px;
  color: var(--jb-primary);
  background: color-mix(in srgb, var(--jb-primary) 10%, var(--jb-surface));
  border: 1px solid color-mix(in srgb, var(--jb-primary) 16%, var(--jb-border));
  font-size: 0.82rem;
  font-weight: 800;
  text-transform: uppercase;
}

.jb-legal-hero__title {
  margin: 0;
  max-width: 12ch;
  color: var(--jb-text);
  font-size: clamp(2.55rem, 6vw, 5.5rem);
  line-height: 0.94;
  letter-spacing: 0;
  text-wrap: balance;
}

.jb-legal-hero__lead {
  margin: 0;
  max-width: 74ch;
  color: var(--jb-text-muted);
  font-size: clamp(1rem, 1.35vw, 1.15rem);
  line-height: 1.85;
}

.jb-legal-hero__meta {
  margin: 0;
  width: fit-content;
  min-height: 38px;
  display: inline-flex;
  align-items: center;
  padding: 0 14px;
  border-radius: 999px;
  background: var(--jb-surface);
  border: 1px solid var(--jb-border);
  color: var(--jb-text-muted);
  font-size: 0.88rem;
  font-weight: 700;
}

.jb-legal-section {
  padding: 0 0 clamp(64px, 8vw, 118px);
}

.jb-legal-layout {
  display: grid;
  grid-template-columns: minmax(220px, 280px) minmax(0, 1fr);
  gap: clamp(20px, 4vw, 42px);
  align-items: start;
}

.jb-legal-sidebar {
  position: sticky;
  top: calc(var(--jb-topbar-height) + 22px);
}

.jb-legal-sidebar nav {
  display: grid;
  gap: 8px;
  padding: 12px;
  border: 1px solid var(--jb-border);
  border-radius: 22px;
  background: color-mix(in srgb, var(--jb-surface) 92%, transparent);
  box-shadow: var(--jb-shadow-soft);
  backdrop-filter: blur(18px);
}

.jb-legal-sidebar a {
  display: flex;
  align-items: center;
  min-height: 42px;
  padding: 0 12px;
  border-radius: 14px;
  color: var(--jb-text-muted);
  font-size: 0.9rem;
  font-weight: 800;
  transition: background 0.2s ease, color 0.2s ease, transform 0.2s ease;
}

.jb-legal-sidebar a:hover,
.jb-legal-sidebar a:focus-visible {
  background: color-mix(in srgb, var(--jb-primary) 9%, var(--jb-surface));
  color: var(--jb-primary);
  transform: translateX(2px);
}

.jb-legal-card {
  display: grid;
  gap: clamp(26px, 4vw, 42px);
  padding: clamp(22px, 4vw, 48px);
  border: 1px solid var(--jb-border);
  border-radius: 30px;
  background: var(--jb-surface);
  box-shadow: var(--jb-shadow-soft);
}

.jb-legal-block {
  display: grid;
  gap: 14px;
  scroll-margin-top: calc(var(--jb-topbar-height) + 22px);
}

.jb-legal-block + .jb-legal-block {
  padding-top: clamp(22px, 3vw, 34px);
  border-top: 1px solid color-mix(in srgb, var(--jb-border) 88%, transparent);
}

.jb-legal-block h2 {
  margin: 0;
  color: var(--jb-text);
  font-size: clamp(1.35rem, 2vw, 1.9rem);
  line-height: 1.15;
  letter-spacing: 0;
}

.jb-legal-block p,
.jb-legal-block li,
.jb-legal-definitions dd,
.jb-legal-table {
  color: var(--jb-text-muted);
  line-height: 1.82;
}

.jb-legal-block p,
.jb-legal-block ul {
  margin: 0;
}

.jb-legal-block ul {
  padding-left: 1.25rem;
}

.jb-legal-block li + li {
  margin-top: 8px;
}

.jb-legal-block a {
  color: var(--jb-primary);
  font-weight: 800;
}

.jb-legal-definitions {
  display: grid;
  gap: 10px;
  margin: 0;
}

.jb-legal-definitions div {
  display: grid;
  grid-template-columns: minmax(150px, 220px) minmax(0, 1fr);
  gap: 12px;
  padding: 12px 0;
  border-bottom: 1px solid color-mix(in srgb, var(--jb-border) 84%, transparent);
}

.jb-legal-definitions dt {
  color: var(--jb-text);
  font-weight: 800;
}

.jb-legal-definitions dd {
  margin: 0;
  min-width: 0;
  overflow-wrap: anywhere;
}

.jb-legal-table-wrap {
  overflow-x: auto;
  border: 1px solid var(--jb-border);
  border-radius: 18px;
}

.jb-legal-table {
  width: 100%;
  min-width: 640px;
  border-collapse: collapse;
  background: var(--jb-surface);
}

.jb-legal-table th,
.jb-legal-table td {
  padding: 16px;
  text-align: left;
  vertical-align: top;
  border-bottom: 1px solid color-mix(in srgb, var(--jb-border) 88%, transparent);
}

.jb-legal-table tr:last-child td {
  border-bottom: 0;
}

.jb-legal-table th {
  color: var(--jb-text);
  font-weight: 900;
  background: color-mix(in srgb, var(--jb-surface-soft) 72%, var(--jb-surface));
}

@media (max-width: 980px) {
  .jb-legal-layout {
    grid-template-columns: 1fr;
  }

  .jb-legal-sidebar {
    position: static;
  }

  .jb-legal-sidebar nav {
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  }
}

@media (max-width: 620px) {
  .jb-legal-hero {
    padding-top: 26px;
  }

  .jb-legal-hero__title {
    font-size: clamp(2.2rem, 13vw, 3.4rem);
  }

  .jb-legal-card {
    border-radius: 24px;
    padding: 20px;
  }

  .jb-legal-definitions div {
    grid-template-columns: 1fr;
    gap: 4px;
  }
}

/* =========================
   COOKIE CONSENT
   ========================= */

.jb-cookie-consent[hidden],
.jb-cookie-consent__banner[hidden],
.jb-cookie-consent__backdrop[hidden],
.jb-cookie-consent__modal[hidden] {
  display: none !important;
}

.jb-cookie-consent {
  position: fixed;
  inset: 0;
  z-index: 1200;
  pointer-events: none;
}

.jb-cookie-consent__banner,
.jb-cookie-consent__modal,
.jb-cookie-consent__backdrop {
  pointer-events: auto;
}

.jb-cookie-consent__banner {
  position: fixed;
  left: 50%;
  bottom: max(18px, env(safe-area-inset-bottom));
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  gap: 20px;
  width: min(calc(100% - 32px), 1120px);
  padding: clamp(18px, 2vw, 24px);
  border: 1px solid color-mix(in srgb, var(--jb-border) 84%, transparent);
  border-radius: 26px;
  background: color-mix(in srgb, var(--jb-surface) 94%, transparent);
  box-shadow: 0 24px 70px rgba(10, 13, 18, 0.2);
  backdrop-filter: blur(20px);
  transform: translateX(-50%);
}

.jb-cookie-consent__copy,
.jb-cookie-consent__form,
.jb-cookie-consent__categories,
.jb-cookie-consent__category-copy {
  display: grid;
  gap: 12px;
}

.jb-cookie-consent__eyebrow {
  width: fit-content;
  display: inline-flex;
  align-items: center;
  min-height: 30px;
  padding: 0 10px;
  border-radius: 999px;
  color: var(--jb-primary);
  background: color-mix(in srgb, var(--jb-primary) 10%, var(--jb-surface));
  border: 1px solid color-mix(in srgb, var(--jb-primary) 18%, var(--jb-border));
  font-size: 0.76rem;
  font-weight: 800;
  text-transform: uppercase;
}

.jb-cookie-consent__title,
.jb-cookie-consent__modal-title,
.jb-cookie-consent__category-title {
  margin: 0;
  color: var(--jb-text);
  line-height: 1.1;
  letter-spacing: 0;
}

.jb-cookie-consent__title,
.jb-cookie-consent__modal-title {
  font-size: clamp(1.35rem, 2vw, 1.85rem);
}

.jb-cookie-consent__category-title {
  font-size: 1rem;
}

.jb-cookie-consent__text,
.jb-cookie-consent__category-copy p,
.jb-cookie-consent__fineprint {
  margin: 0;
  color: var(--jb-text-muted);
  line-height: 1.65;
}

.jb-cookie-consent__text {
  max-width: 72ch;
}

.jb-cookie-consent__fineprint {
  font-size: 0.86rem;
}

.jb-cookie-consent__actions,
.jb-cookie-consent__modal-actions {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: flex-end;
  gap: 10px;
}

.jb-cookie-consent__button {
  min-height: 48px;
  padding-inline: 18px;
  white-space: nowrap;
}

.jb-cookie-consent__button .material-symbols-rounded {
  font-size: 20px;
}

.jb-cookie-consent__backdrop {
  position: fixed;
  inset: 0;
  background: rgba(9, 11, 16, 0.54);
  backdrop-filter: blur(10px);
}

.jb-cookie-consent__modal {
  position: fixed;
  left: 50%;
  top: 50%;
  display: grid;
  gap: 18px;
  width: min(calc(100% - 32px), 760px);
  max-height: min(760px, calc(100vh - 40px));
  padding: clamp(20px, 3vw, 30px);
  overflow: auto;
  border: 1px solid color-mix(in srgb, var(--jb-border) 86%, transparent);
  border-radius: 28px;
  background: var(--jb-surface);
  box-shadow: 0 30px 90px rgba(0, 0, 0, 0.28);
  transform: translate(-50%, -50%);
}

.jb-cookie-consent__modal-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
}

.jb-cookie-consent__close {
  flex: 0 0 46px;
}

.jb-cookie-consent__categories {
  gap: 10px;
}

.jb-cookie-consent__category {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  padding: 16px;
  border: 1px solid color-mix(in srgb, var(--jb-border) 88%, transparent);
  border-radius: 18px;
  background: color-mix(in srgb, var(--jb-surface-soft) 72%, var(--jb-surface));
}

.jb-cookie-switch {
  position: relative;
  flex: 0 0 auto;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  cursor: pointer;
}

.jb-cookie-switch input {
  position: absolute;
  width: 1px;
  height: 1px;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
}

.jb-cookie-switch__track {
  position: relative;
  display: inline-flex;
  align-items: center;
  width: 54px;
  height: 30px;
  padding: 3px;
  border-radius: 999px;
  background: color-mix(in srgb, var(--jb-text-muted) 22%, var(--jb-surface));
  border: 1px solid color-mix(in srgb, var(--jb-border) 92%, transparent);
  transition: background 0.22s ease, border-color 0.22s ease, box-shadow 0.22s ease;
}

.jb-cookie-switch__thumb {
  width: 22px;
  height: 22px;
  border-radius: 50%;
  background: #fff;
  box-shadow: 0 3px 10px rgba(10, 13, 18, 0.18);
  transition: transform 0.22s ease;
}

.jb-cookie-switch input:checked + .jb-cookie-switch__track {
  background: var(--jb-gradient-brand);
  border-color: color-mix(in srgb, var(--jb-primary) 34%, transparent);
  box-shadow: 0 10px 24px rgba(255, 59, 59, 0.2);
}

.jb-cookie-switch input:checked + .jb-cookie-switch__track .jb-cookie-switch__thumb {
  transform: translateX(24px);
}

.jb-cookie-switch input:focus-visible + .jb-cookie-switch__track {
  outline: 0;
  box-shadow:
    0 0 0 3px color-mix(in srgb, var(--jb-primary) 18%, transparent),
    0 0 0 6px color-mix(in srgb, var(--jb-primary) 8%, transparent);
}

.jb-cookie-switch input:disabled + .jb-cookie-switch__track {
  opacity: 0.78;
  cursor: not-allowed;
}

.jb-cookie-switch__label {
  max-width: 14ch;
  color: var(--jb-text-muted);
  font-size: 0.78rem;
  font-weight: 800;
  line-height: 1.25;
  text-align: right;
}

html.jb-cookie-consent-modal-open {
  overflow: hidden;
}

[data-theme='dark'] .jb-cookie-consent__banner {
  background: color-mix(in srgb, var(--jb-surface) 92%, transparent);
  box-shadow: 0 24px 70px rgba(0, 0, 0, 0.42);
}

@media (max-width: 900px) {
  .jb-cookie-consent__banner {
    grid-template-columns: 1fr;
    align-items: stretch;
  }

  .jb-cookie-consent__actions,
  .jb-cookie-consent__modal-actions {
    display: grid;
    grid-template-columns: 1fr;
  }

  .jb-cookie-consent__button {
    width: 100%;
    white-space: normal;
  }
}

@media (max-width: 620px) {
  .jb-cookie-consent__banner {
    bottom: max(10px, env(safe-area-inset-bottom));
    width: min(calc(100% - 20px), 1120px);
    border-radius: 20px;
  }

  .jb-cookie-consent__modal {
    width: min(calc(100% - 20px), 760px);
    max-height: calc(100vh - 20px);
    border-radius: 22px;
  }

  .jb-cookie-consent__category {
    align-items: flex-start;
    flex-direction: column;
  }

  .jb-cookie-switch {
    width: 100%;
    justify-content: space-between;
  }

  .jb-cookie-switch__label {
    max-width: none;
  }
}

/* =========================
   ERROR PAGES
   ========================= */

.jb-button.jb-primary,
:where(.jb-button.jb-primary) {
  --jb-button-bg: var(--jb-gradient-brand);
  --jb-button-color: #fff;
  --jb-button-border: transparent;
  --jb-button-shadow: 0 16px 30px rgba(255, 59, 59, 0.24);
  background: var(--jb-button-bg);
  color: var(--jb-button-color);
  border-color: var(--jb-button-border);
  box-shadow: var(--jb-button-shadow);
}

.jb-button.jb-primary.jb-hover,
:where(.jb-button.jb-primary.jb-hover) {
  --jb-hover-bg: linear-gradient(135deg, #ff4d4d, #d72d2d);
  --jb-hover-color: #fff;
  --jb-hover-border: color-mix(in srgb, var(--jb-primary) 24%, transparent);
  --jb-hover-shadow: 0 18px 36px rgba(255, 59, 59, 0.28);
  --jb-hover-ring: 0 0 0 4px color-mix(in srgb, var(--jb-primary) 18%, transparent);
}

.jb-button.jb-primary.jb-hover--glow,
:where(.jb-button.jb-primary.jb-hover--glow) {
  --jb-hover-bg: linear-gradient(135deg, #ff5252, #cf2a2a);
  --jb-hover-color: #fff;
  --jb-hover-border: color-mix(in srgb, var(--jb-primary) 28%, transparent);
  --jb-hover-shadow:
    0 18px 38px rgba(255, 59, 59, 0.3),
    0 0 0 1px color-mix(in srgb, var(--jb-primary) 16%, transparent);
}

.jb-error-page {
  background:
    radial-gradient(circle at top left, color-mix(in srgb, var(--jb-primary) 10%, transparent), transparent 34%),
    radial-gradient(circle at bottom right, color-mix(in srgb, var(--jb-primary) 8%, transparent), transparent 32%),
    var(--jb-surface-alt);
}

.jb-error-site { min-height: 100vh; display: grid; grid-template-rows: auto 1fr; }
.jb-error-topbar { position: sticky; top: 0; z-index: 40; backdrop-filter: blur(18px); background: color-mix(in srgb, var(--jb-surface-alt) 82%, transparent); border-bottom: 1px solid color-mix(in srgb, var(--jb-border) 72%, transparent); }
.jb-error-topbar__inner { display: flex; align-items: center; justify-content: space-between; gap: 18px; min-height: var(--jb-topbar-height); }
.jb-error-topbar__actions { display: flex; align-items: center; gap: 12px; }
.jb-error-main { display: grid; align-items: center; min-height: calc(100vh - var(--jb-topbar-height)); padding: clamp(24px, 4vw, 40px) 0 clamp(40px, 7vw, 80px); }
.jb-error-wrap { position: relative; display: grid; gap: 24px; }
.jb-error-shell { position: relative; display: grid; grid-template-columns: minmax(0, 1.05fr) minmax(320px, 460px); gap: clamp(22px, 4vw, 42px); align-items: stretch; }
.jb-error-panel { position: relative; overflow: hidden; padding: clamp(24px, 3vw, 40px); border-radius: 32px; background: color-mix(in srgb, var(--jb-surface) 92%, transparent); border: 1px solid color-mix(in srgb, var(--jb-border) 82%, transparent); box-shadow: var(--jb-shadow-soft); backdrop-filter: blur(18px); }
.jb-error-panel::before { content: ''; position: absolute; inset: -1px; border-radius: inherit; padding: 1px; background: linear-gradient(145deg, color-mix(in srgb, var(--jb-primary) 22%, transparent), transparent 38%); -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0); -webkit-mask-composite: xor; mask-composite: exclude; pointer-events: none; }
.jb-error-kicker { width: fit-content; display: inline-flex; align-items: center; min-height: 42px; padding: 0 14px; border-radius: 999px; color: var(--jb-primary); background: color-mix(in srgb, var(--jb-primary) 10%, var(--jb-surface)); border: 1px solid color-mix(in srgb, var(--jb-primary) 16%, var(--jb-border)); font-weight: 800; letter-spacing: .02em; }
.jb-error-code { margin: 0; font-size: clamp(4.8rem, 15vw, 10rem); line-height: .86; letter-spacing: -.08em; }
.jb-error-title { margin: 0; font-size: clamp(2rem, 4vw, 3.25rem); line-height: .95; letter-spacing: -.05em; max-width: 12ch; }
.jb-error-lead { margin: 0; max-width: 64ch; color: var(--jb-text-muted); line-height: 1.84; font-size: clamp(1rem, 1.4vw, 1.08rem); }
.jb-error-actions, .jb-error-meta { display: flex; flex-wrap: wrap; gap: 12px; }
.jb-error-chip { display: inline-flex; align-items: center; min-height: 42px; padding: 0 14px; border-radius: 999px; background: var(--jb-surface-soft); border: 1px solid color-mix(in srgb, var(--jb-border) 86%, transparent); color: var(--jb-text); font-weight: 700; }
.jb-error-visual { position: relative; display: grid; align-items: center; justify-items: center; min-height: 100%; padding: clamp(24px, 3vw, 36px); border-radius: 32px; background: var(--jb-gradient-hero); color: #fff; box-shadow: var(--jb-shadow-hero); overflow: hidden; }
.jb-error-visual::before, .jb-error-visual::after { content: ''; position: absolute; border-radius: 999px; filter: blur(16px); background: rgba(255, 59, 59, 0.18); }
.jb-error-visual::before { width: 240px; height: 240px; right: -60px; top: -70px; }
.jb-error-visual::after { width: 160px; height: 160px; left: -40px; bottom: -50px; }
.jb-error-orbits { position: absolute; inset: 0; pointer-events: none; }
.jb-error-orbit { position: absolute; display: inline-flex; align-items: center; min-height: 36px; padding: 0 12px; border-radius: 999px; background: rgba(255,255,255,.08); border: 1px solid rgba(255,255,255,.12); color: rgba(255,255,255,.88); font-size: .82rem; font-weight: 700; backdrop-filter: blur(10px); }
.jb-error-orbit--a { top: 22px; left: 22px; }
.jb-error-orbit--b { top: 30px; right: 24px; }
.jb-error-orbit--c { bottom: 26px; left: 26px; }
.jb-error-orbit--d { bottom: 22px; right: 22px; }
.jb-error-face { position: relative; z-index: 1; width: min(100%, 320px); aspect-ratio: 1; display: grid; place-items: center; }
.jb-error-face__halo { position: absolute; inset: 12%; border-radius: 999px; background: radial-gradient(circle, rgba(255,255,255,.16), transparent 70%); filter: blur(8px); }
.jb-error-face__core { position: relative; width: 100%; height: 100%; border-radius: 34%; background: linear-gradient(180deg, rgba(255,255,255,.12), rgba(255,255,255,.04)), linear-gradient(135deg, rgba(255,255,255,.08), rgba(255,255,255,.02)); border: 1px solid rgba(255,255,255,.12); box-shadow: inset 0 1px 0 rgba(255,255,255,.12), 0 28px 50px rgba(0,0,0,.2); backdrop-filter: blur(14px); }
.jb-error-face__brow { position: absolute; top: 28%; width: 28%; height: 8px; border-radius: 999px; background: rgba(255,255,255,.8); opacity: .78; }
.jb-error-face__brow--left { left: 16%; transform: rotate(-8deg); }
.jb-error-face__brow--right { right: 16%; transform: rotate(8deg); }
.jb-error-face__eyes { position: absolute; inset: 36% 14% auto; display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 18px; }
.jb-error-eye { position: relative; height: 82px; border-radius: 999px; background: rgba(255,255,255,.94); overflow: hidden; box-shadow: inset 0 3px 12px rgba(16, 18, 24, .1), 0 10px 20px rgba(0,0,0,.08); }
.jb-error-eye__shine { position: absolute; inset: 8px auto auto 18px; width: 24px; height: 14px; border-radius: 999px; background: rgba(255,255,255,.8); filter: blur(2px); z-index: 2; }
.jb-error-eye__pupil-wrap { position: absolute; inset: 0; display: grid; place-items: center; z-index: 2; }
.jb-error-eye__pupil { position: relative; width: 34px; height: 34px; border-radius: 999px; background: #16181d; box-shadow: inset 0 0 0 10px #0f1115; transform: translate3d(0,0,0); }
.jb-error-eye__pupil::after { content: ''; position: absolute; inset: 7px auto auto 8px; width: 9px; height: 9px; border-radius: 999px; background: rgba(255,255,255,.86); }
.jb-error-eye__lid { position: absolute; left: -2%; width: 104%; height: 54%; background: linear-gradient(180deg, rgba(29,32,40,.98), rgba(23,25,31,.95)); z-index: 3; pointer-events: none; }
.jb-error-eye__lid--top { top: 0; border-bottom-left-radius: 999px; border-bottom-right-radius: 999px; transform: translateY(-110%); }
.jb-error-eye__lid--bottom { bottom: 0; border-top-left-radius: 999px; border-top-right-radius: 999px; transform: translateY(110%); }
.jb-error-face__nose { position: absolute; top: 63%; left: 50%; width: 14px; height: 14px; border-radius: 999px; background: rgba(255,255,255,.78); transform: translateX(-50%); }
.jb-error-face__mouth { position: absolute; left: 50%; bottom: 19%; width: 88px; height: 16px; border-radius: 999px; border: 4px solid rgba(255,255,255,.72); border-top: 0; transform: translateX(-50%); opacity: .78; }
.jb-error-hint { position: relative; z-index: 1; margin: 18px 0 0; color: rgba(255,255,255,.74); text-align: center; line-height: 1.7; max-width: 26ch; }
.jb-error-stagger > * { opacity: 0; transform: translateY(18px); }
[data-theme='dark'] .jb-error-panel { background: color-mix(in srgb, var(--jb-surface) 92%, transparent); }
[data-theme='dark'] .jb-error-chip { background: color-mix(in srgb, var(--jb-surface-soft) 84%, transparent); }

@media (max-width: 1100px) { .jb-error-shell { grid-template-columns: 1fr; } .jb-error-visual { min-height: 460px; } }
@media (max-width: 768px) {
  .jb-error-topbar__inner { min-height: 76px; }
  .jb-error-main { padding-top: 22px; }
  .jb-error-panel, .jb-error-visual { border-radius: 26px; padding: 22px; }
  .jb-error-actions { display: grid; grid-template-columns: 1fr; }
  .jb-error-face { width: min(100%, 260px); }
  .jb-error-eye { height: 68px; }
  .jb-error-eye__pupil { width: 28px; height: 28px; }
}

/* =========================
   JOBBRIDGE MERGED MODULE CSS: LOCATION PICKER
   ========================= */

/* =========================
   JOB LOCATION PICKER · JOBBRIDGE UPGRADE
   ========================= */

:root {
  --jb-location-water: color-mix(in srgb, var(--jb-surface-soft) 94%, #fff2f2);
  --jb-location-surface: color-mix(in srgb, var(--jb-surface) 96%, transparent);
  --jb-location-surface-strong: color-mix(in srgb, var(--jb-surface-soft) 92%, transparent);
  --jb-location-stroke: color-mix(in srgb, var(--jb-primary-dark) 72%, transparent);
  --jb-location-fill: color-mix(in srgb, var(--jb-primary) 10%, #ffdede);
  --jb-location-fill-hover: color-mix(in srgb, var(--jb-primary) 18%, #ffd3d3);
  --jb-location-fill-active: color-mix(in srgb, var(--jb-primary) 26%, #ffc1c1);
  --jb-location-fill-selected: color-mix(in srgb, var(--jb-primary) 40%, #ffb3b3);
}

[data-theme='dark'] {
  --jb-location-water: color-mix(in srgb, var(--jb-surface-soft) 92%, #1d1416);
  --jb-location-surface: color-mix(in srgb, var(--jb-surface) 94%, transparent);
  --jb-location-surface-strong: color-mix(in srgb, var(--jb-surface-soft) 86%, transparent);
  --jb-location-stroke: color-mix(in srgb, var(--jb-primary) 68%, #ffffff);
  --jb-location-fill: color-mix(in srgb, var(--jb-primary) 12%, #25191b);
  --jb-location-fill-hover: color-mix(in srgb, var(--jb-primary) 18%, #311e21);
  --jb-location-fill-active: color-mix(in srgb, var(--jb-primary) 24%, #3a2024);
  --jb-location-fill-selected: color-mix(in srgb, var(--jb-primary) 34%, #52282d);
}

.jb-location-picker {
  display: grid;
  gap: 14px;
}

.jb-location-picker--page {
  gap: 0;
}

.jb-location-picker__trigger {
  width: 100%;
  justify-content: space-between;
}

.jb-location-picker__summary {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.jb-location-picker__summary:empty {
  display: none;
}

.jb-location-picker__summary .jb-chip {
  box-shadow: none;
}

.jb-location-modal[hidden] {
  display: none !important;
}

.jb-location-modal {
  position: fixed;
  inset: 0;
  z-index: 120;
  display: grid;
  place-items: center;
  padding: 24px;
  background:
    radial-gradient(circle at top left, color-mix(in srgb, var(--jb-primary) 10%, transparent), transparent 28%),
    rgba(12, 14, 18, 0.6);
  backdrop-filter: blur(14px);
}

.jb-location-modal__dialog,
.jb-location-shell {
  /* width: min(1160px, 100%); */
  overflow: hidden;
  border-radius: 34px;
  background: var(--jb-location-surface);
  border: 1px solid color-mix(in srgb, var(--jb-border) 84%, transparent);
  box-shadow: var(--jb-shadow);
  display: grid;
  grid-template-rows: auto 1fr auto;
  position: relative;
}

.jb-location-shell::before,
.jb-location-modal__dialog::before {
  content: '';
  position: absolute;
  inset: -1px;
  border-radius: inherit;
  padding: 1px;
  background: linear-gradient(145deg, color-mix(in srgb, var(--jb-primary) 22%, transparent), transparent 34%);
  -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  -webkit-mask-composite: xor;
          mask-composite: exclude;
  pointer-events: none;
}

.jb-location-modal__dialog {
  max-height: min(94vh, 980px);
}

.jb-location-shell {
  max-width: none;
}

.jb-location-modal__header,
.jb-location-shell__header {
  position: relative;
  display: grid;
  gap: 14px;
  padding: 28px 30px 22px;
  border-bottom: 1px solid color-mix(in srgb, var(--jb-border) 78%, transparent);
  background:
    radial-gradient(circle at top right, color-mix(in srgb, var(--jb-primary) 10%, transparent), transparent 32%),
    linear-gradient(180deg, color-mix(in srgb, var(--jb-surface) 98%, transparent), color-mix(in srgb, var(--jb-surface-soft) 92%, transparent));
}

.jb-location-shell__header {
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: end;
}

.jb-location-shell__eyebrow {
  display: inline-flex;
  align-items: center;
  width: fit-content;
  min-height: 40px;
  padding: 0 14px;
  border-radius: 999px;
  background: color-mix(in srgb, var(--jb-primary) 10%, var(--jb-surface));
  border: 1px solid color-mix(in srgb, var(--jb-primary) 18%, var(--jb-border));
  color: var(--jb-primary);
  font-size: .84rem;
  font-weight: 800;
  letter-spacing: .04em;
  text-transform: uppercase;
}

.jb-location-modal__title,
.jb-location-shell__title {
  margin: 0;
  font-size: clamp(1.95rem, 3vw, 2.7rem);
  letter-spacing: -.05em;
  line-height: .98;
}

.jb-location-modal__close {
  position: absolute;
  top: 18px;
  right: 18px;
}

.jb-location-shell__meta {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  justify-content: flex-end;
}

.jb-location-modal__body {
  display: grid;
  gap: 18px;
  padding: 22px 24px 12px;
  overflow: auto;
}

.jb-location-breadcrumbs {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 10px;
  min-height: 46px;
}

.jb-location-breadcrumbs__button {
  display: inline-flex;
  align-items: center;
  min-height: 42px;
  padding: 0 14px;
  border-radius: 999px;
  border: 1px solid transparent;
  background: transparent;
  color: var(--jb-text);
  font-weight: 800;
  cursor: pointer;
  transition: background .22s ease, border-color .22s ease, color .22s ease, transform .22s ease;
}

.jb-location-breadcrumbs__button:hover {
  background: color-mix(in srgb, var(--jb-primary) 6%, var(--jb-surface));
  border-color: color-mix(in srgb, var(--jb-primary) 14%, var(--jb-border));
  transform: translateY(-1px);
}

.jb-location-breadcrumbs__button.is-active {
  color: var(--jb-primary);
  background: color-mix(in srgb, var(--jb-primary) 10%, var(--jb-surface));
  border-color: color-mix(in srgb, var(--jb-primary) 18%, var(--jb-border));
}

.jb-location-breadcrumbs__separator {
  color: var(--jb-text-muted);
  font-weight: 800;
}

.jb-location-stage {
  display: grid;
  gap: 18px;
}

.jb-location-stage__topbar {
  display: flex;
  align-items: stretch;
  justify-content: space-between;
  gap: 14px;
  flex-wrap: wrap;
}

.jb-location-count,
.jb-location-offers {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  min-height: 40px;
  padding: 0 14px;
  border-radius: 999px;
  background: var(--jb-surface);
  border: 1px solid var(--jb-border);
  color: var(--jb-text);
  font-weight: 800;
  box-shadow: var(--jb-shadow-soft);
}

.jb-location-offers {
  background: color-mix(in srgb, var(--jb-primary) 8%, var(--jb-surface));
  border-color: color-mix(in srgb, var(--jb-primary) 18%, var(--jb-border));
  color: var(--jb-primary);
}

.jb-location-stage__insight {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 16px;
  align-items: center;
  padding: 18px 20px;
  border-radius: 26px;
  background:
    radial-gradient(circle at top right, color-mix(in srgb, var(--jb-primary) 10%, transparent), transparent 34%),
    var(--jb-location-surface-strong);
  border: 1px solid color-mix(in srgb, var(--jb-border) 84%, transparent);
  box-shadow: var(--jb-shadow-soft);
}

.jb-location-stage__eyebrow {
  display: block;
  color: var(--jb-text-muted);
  font-size: .82rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .06em;
}

.jb-location-stage__title {
  display: block;
  font-size: clamp(1.35rem, 2vw, 1.8rem);
  line-height: 1;
  letter-spacing: -.04em;
}

.jb-location-stage__meta {
  margin: 0;
  color: var(--jb-text-muted);
  line-height: 1.75;
}

.jb-location-stage__canvas {
  position: relative;
  min-height: 460px;
  padding: 18px;
  border-radius: 30px;
  background:
    radial-gradient(circle at top left, color-mix(in srgb, var(--jb-primary) 7%, transparent), transparent 28%),
    linear-gradient(180deg, var(--jb-location-water), color-mix(in srgb, var(--jb-location-water) 86%, var(--jb-surface-soft)));
  border: 1px solid color-mix(in srgb, var(--jb-border) 84%, transparent);
  overflow: hidden;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.7);
}

[data-theme='dark'] .jb-location-stage__canvas {
  box-shadow: inset 0 1px 0 rgba(255,255,255,.04);
}

.jb-location-stage__canvas::after {
  content: '';
  position: absolute;
  inset: 14px;
  border-radius: 24px;
  border: 1px dashed color-mix(in srgb, var(--jb-primary) 12%, var(--jb-border));
  pointer-events: none;
  opacity: .55;
}

.jb-location-stage__canvas > svg,
.jb-location-stage__canvas > .jb-location-stage__empty {
  width: 100%;
  height: 100%;
  min-height: 400px;
}

.jb-location-stage__canvas svg {
  display: block;
}

.jb-location-stage__empty {
  display: grid;
  place-items: center;
  color: var(--jb-text-muted);
  text-align: center;
  line-height: 1.7;
}

.jb-location-map__feature {
  isolation: isolate;
}

.jb-location-map__shape {
  fill: var(--jb-location-fill);
  stroke: var(--jb-location-stroke);
  stroke-width: 1.65;
  vector-effect: non-scaling-stroke;
  transition: fill .22s ease, opacity .22s ease, transform .22s ease, stroke .22s ease, filter .22s ease;
  cursor: pointer;
  transform-origin: center;
}

.jb-location-map__shape:hover,
.jb-location-map__shape.is-hovered {
  fill: var(--jb-location-fill-hover);
  filter: saturate(1.03);
}

.jb-location-map__shape.is-active {
  fill: var(--jb-location-fill-active);
}

.jb-location-map__shape.is-selected {
  fill: var(--jb-location-fill-selected);
  stroke: color-mix(in srgb, var(--jb-primary-dark) 88%, transparent);
}

.jb-location-map__label {
  font: 700 14px/1.2 'Poppins', sans-serif;
  fill: rgba(0, 0, 0, 0.82);
  text-anchor: middle;
  pointer-events: none;
  user-select: none;
  paint-order: stroke;
  stroke: rgba(255,255,255,.82);
  stroke-width: 4px;
  stroke-linecap: round;
  stroke-linejoin: round;
}

[data-theme='dark'] .jb-location-map__label {
  fill: rgba(255, 255, 255, 0.92);
  stroke: rgba(16, 18, 24, .72);
}

.jb-location-selection {
  display: grid;
  gap: 14px;
  justify-items: center;
  padding: 6px 0 10px;
}

.jb-location-selection__title {
  margin: 0;
  font-size: 1.35rem;
  letter-spacing: -.03em;
  text-align: center;
}

.jb-location-selection__tags {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 10px;
}

.jb-location-tag {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  min-height: 40px;
  padding: 0 12px;
  border-radius: 999px;
  border: 1px solid color-mix(in srgb, var(--jb-primary) 16%, var(--jb-border));
  background: color-mix(in srgb, var(--jb-primary) 10%, var(--jb-surface));
  color: var(--jb-primary);
  font-weight: 800;
  box-shadow: none;
}

.jb-location-tag__remove {
  width: 22px;
  height: 22px;
  border: 0;
  border-radius: 999px;
  background: transparent;
  color: inherit;
  cursor: pointer;
  display: inline-grid;
  place-items: center;
  padding: 0;
  transition: transform .18s ease, background .18s ease;
}

.jb-location-tag__remove:hover {
  transform: scale(1.06);
  background: color-mix(in srgb, var(--jb-primary) 12%, transparent);
}

.jb-location-modal__footer {
  display: flex;
  justify-content: center;
  gap: 12px;
  padding: 18px 24px 26px;
  border-top: 1px solid color-mix(in srgb, var(--jb-border) 76%, transparent);
  background: color-mix(in srgb, var(--jb-surface) 98%, transparent);
}

.jb-location-hint {
  margin: 0;
  color: var(--jb-text-muted);
  line-height: 1.75;
}

.jb-location-hint--center {
  text-align: center;
}

.jb-location-page {
  background:
    radial-gradient(circle at top left, color-mix(in srgb, var(--jb-primary) 8%, transparent), transparent 34%),
    radial-gradient(circle at bottom right, color-mix(in srgb, var(--jb-primary) 7%, transparent), transparent 32%),
    var(--jb-surface-alt);
}

.jb-location-page__hero {
  padding-top: 30px;
  padding-bottom: 18px;
}

.jb-location-page__hero-card {
  position: relative;
  overflow: hidden;
}

.jb-location-page__hero-grid {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: minmax(0, 1.15fr) minmax(280px, .85fr);
  gap: clamp(22px, 4vw, 34px);
  align-items: end;
}

.jb-location-page__hero-title {
  margin: 18px 0 14px;
  max-width: 12ch;
  font-size: clamp(2.8rem, 5vw, 4.6rem);
  line-height: .93;
  letter-spacing: -.05em;
}

.jb-location-page__hero-lead {
  margin: 0;
  max-width: 62ch;
  color: var(--jb-text);
  line-height: 1.82;
}

.jb-location-page__hero-stats {
  display: grid;
  gap: 14px;
}

.jb-location-page__hero-stat {
  padding: 18px 20px;
  border-radius: 24px;
  background: rgba(var(--jb-surface-reverse-rgb), .08);
  border: 1px solid rgba(var(--jb-surface-reverse-rgb), .1);
  backdrop-filter: blur(14px);
}

.jb-location-page__hero-stat span {
  display: block;
  color: var(--jb-text-muted);
  font-size: .82rem;
  margin-bottom: 8px;
}

.jb-location-page__hero-stat strong {
  display: block;
  font-size: 1.08rem;
  line-height: 1.15;
}

.jb-location-page__body {
  padding-top: 6px;
  padding-bottom: var(--jb-space-section);
}

.jb-location-page__back {
  margin-bottom: 18px;
}

@media (max-width: 1100px) {
  .jb-location-page__hero-grid,
  .jb-location-shell__header,
  .jb-location-stage__insight {
    grid-template-columns: 1fr;
  }

  .jb-location-shell__meta {
    justify-content: flex-start;
  }
}

@media (max-width: 768px) {
  .jb-location-modal {
    padding: 12px;
  }

  .jb-location-modal__dialog,
  .jb-location-shell {
    border-radius: 26px;
  }

  .jb-location-modal__header,
  .jb-location-shell__header {
    padding: 22px 20px 18px;
  }

  .jb-location-modal__body {
    padding: 16px 16px 10px;
  }

  .jb-location-stage__canvas {
    padding: 10px;
    min-height: 320px;
    border-radius: 22px;
  }

  .jb-location-stage__canvas > svg,
  .jb-location-stage__canvas > .jb-location-stage__empty {
    min-height: 280px;
  }

  .jb-location-modal__footer {
    flex-direction: column;
    padding: 18px 16px 20px;
  }

  .jb-location-modal__footer .jb-button {
    width: 100%;
  }

  .jb-location-selection__title {
    font-size: 1.15rem;
  }

  .jb-location-page__hero-title {
    max-width: none;
    font-size: clamp(2.2rem, 10vw, 3.2rem);
  }
}

/* =========================
   JOBBRIDGE MERGED MODULE CSS: COMPANIES
   ========================= */

/* =========================
   COMPANIES PAGES
   ========================= */

.jb-company-page {
  background:
    radial-gradient(circle at top left, color-mix(in srgb, var(--jb-primary) 8%, transparent), transparent 34%),
    radial-gradient(circle at bottom right, color-mix(in srgb, var(--jb-primary) 7%, transparent), transparent 32%),
    var(--jb-surface-alt);
}

.jb-company-hero {
  padding-top: 28px;
  padding-bottom: 24px;
}

.jb-company-hero__panel {
  position: relative;
  min-height: 520px;
  overflow: hidden;
}

.jb-company-hero__grid {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: minmax(0, 1.12fr) minmax(320px, .88fr);
  gap: clamp(24px, 4vw, 40px);
  align-items: stretch;
}

.jb-company-hero__main,
.jb-company-hero__aside {
  position: relative;
  z-index: 1;
}

.jb-company-hero__aside {
  display: grid;
  align-content: end;
}

.jb-company-hero__title {
  margin: 18px 0 14px;
  max-width: 11ch;
  font-size: clamp(3rem, 5vw, 4.9rem);
  line-height: .93;
  letter-spacing: -.06em;
  text-wrap: balance;
}

.jb-company-hero__lead {
  margin: 0;
  max-width: 62ch;
  color: rgba(var(--jb-text), .88);
  line-height: 1.82;
  font-size: clamp(1rem, 1.4vw, 1.08rem);
}

.jb-company-hero__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 28px;
}

.jb-company-hero__halo,
.jb-company-hero__halo--two {
  position: absolute;
  border-radius: 999px;
  filter: blur(10px);
  pointer-events: none;
}

.jb-company-hero__halo {
  width: 240px;
  height: 240px;
  right: -40px;
  top: -40px;
  background: rgba(255,255,255,.08);
}

.jb-company-hero__halo--two {
  width: 160px;
  height: 160px;
  left: -20px;
  bottom: -24px;
  background: rgba(255, 59, 59, .20);
}

.jb-company-hero__stats {
  display: grid;
  gap: 14px;
}

.jb-company-hero__stat {
  padding: 18px 20px;
  border-radius: 24px;
  background: rgba(var(--jb-surface-reverse-rgb), .08);
  border: 1px solid rgba(var(--jb-surface-reverse-rgb), .12);
  backdrop-filter: blur(14px);
}

.jb-company-hero__stat span {
  display: block;
  color: rgba(var(--jb-text), .66);
  font-size: .82rem;
  margin-bottom: 8px;
}

.jb-company-hero__stat strong {
  display: block;
  font-size: 1.06rem;
  line-height: 1.15;
}

.jb-company-toolbar {
  display: grid;
  gap: 28px;
  margin-top: 8px;
}

.jb-company-toolbar > * {
  width: 100%;
  min-width: 0;
}

.jb-company-filters {
  --jb-card-padding: clamp(24px, 2.8vw, 32px);
  display: grid;
  width: 100%;
  max-width: none;
  justify-self: stretch;
  gap: 18px;
}

.jb-company-filters__row {
  display: grid;
  grid-template-columns: minmax(340px, 1.7fr) minmax(220px, .9fr) auto auto;
  gap: 16px 18px;
  align-items: center;
}

.jb-company-filters__search {
  position: relative;
  min-width: 0;
}

.jb-company-filters__search .material-symbols-rounded {
  position: absolute;
  left: 16px;
  top: 50%;
  transform: translateY(-50%);
  color: var(--jb-text-muted);
}

.jb-company-filters__search .jb-input {
  min-height: 60px;
  padding-left: 48px;
}

.jb-company-filters__row > .jb-input {
  min-width: 0;
  min-height: 60px;
}

.jb-company-filters__row .jb-chip,
.jb-company-filters__row .jb-button {
  min-height: 52px;
  padding-inline: 18px;
}

.jb-company-filters__chips {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  padding-top: 4px;
}

.jb-company-filter-chip {
  display: inline-flex;
  align-items: center;
  min-height: 44px;
  padding: 0 18px;
  border-radius: 999px;
  border: 1px solid var(--jb-border);
  background: var(--jb-surface);
  color: var(--jb-text);
  box-shadow: var(--jb-shadow-soft);
  font-weight: 700;
  cursor: pointer;
  transition: transform .22s ease, border-color .22s ease, background .22s ease, color .22s ease;
}

.jb-company-filter-chip:hover {
  transform: translateY(-1px);
}

.jb-company-filter-chip.is-active {
  color: var(--jb-primary);
  background: color-mix(in srgb, var(--jb-primary) 10%, var(--jb-surface));
  border-color: color-mix(in srgb, var(--jb-primary) 18%, var(--jb-border));
}

.jb-company-listing {
  display: grid;
  gap: 28px;
}

.jb-company-grid {
  display: grid;
  grid-template-columns: repeat(12, minmax(0, 1fr));
  gap: 20px;
}

.jb-company-card {
  grid-column: span 6;
  min-height: 100%;
  display: grid;
  gap: 18px;
  isolation: isolate;
}

.jb-company-card--featured {
  grid-column: span 12;
  grid-template-columns: minmax(0, 1.1fr) minmax(280px, .9fr);
  align-items: stretch;
  background:
    radial-gradient(circle at top right, color-mix(in srgb, var(--jb-primary) 10%, transparent), transparent 34%),
    linear-gradient(180deg, color-mix(in srgb, var(--jb-surface) 98%, transparent), color-mix(in srgb, var(--jb-surface-soft) 92%, transparent));
}

.jb-company-card__head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 18px;
}

.jb-company-card__main,
.jb-company-card__side {
  display: grid;
  gap: 18px;
  min-width: 0;
}

.jb-company-card__identity {
  display: flex;
  align-items: flex-start;
  gap: 18px;
}

.jb-company-card__logo,
.jb-company-logo {
  width: 74px;
  height: 74px;
  border-radius: 24px;
  object-fit: cover;
  border: 1px solid color-mix(in srgb, var(--jb-border) 84%, transparent);
  box-shadow: var(--jb-shadow-soft);
  background: var(--jb-surface-soft);
}

.jb-company-card__logo--fallback,
.jb-company-logo--fallback {
  display: grid;
  place-items: center;
  background: var(--jb-gradient-brand);
  color: #fff;
  font-weight: 900;
  letter-spacing: -.04em;
}

.jb-company-card__name {
  margin: 0;
  font-size: clamp(1.5rem, 2.6vw, 2rem);
  line-height: 1;
  letter-spacing: -.04em;
}

.jb-company-card__meta {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.jb-company-card__summary {
  margin: 0;
  color: var(--jb-text-muted);
  line-height: 1.8;
  max-width: 64ch;
}

.jb-company-card__quickstats {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
}

.jb-company-card__metric,
.jb-company-stat {
  padding: 16px 18px;
  border-radius: 22px;
  background: color-mix(in srgb, var(--jb-surface-soft) 92%, transparent);
  border: 1px solid color-mix(in srgb, var(--jb-border) 84%, transparent);
}

.jb-company-card__metric span,
.jb-company-stat span {
  display: block;
  color: var(--jb-text-muted);
  font-size: .82rem;
  margin-bottom: 6px;
}

.jb-company-card__metric strong,
.jb-company-stat strong {
  display: block;
  font-size: 1.08rem;
  line-height: 1.1;
}

.jb-company-card__stretched-link {
  position: absolute;
  inset: 0;
  z-index: 2;
  border-radius: inherit;
}

.jb-company-card__cta {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-weight: 800;
  color: var(--jb-primary);
}

.jb-company-card__cta .material-symbols-rounded {
  transition: transform .22s ease;
}

.jb-company-card:hover .jb-company-card__cta .material-symbols-rounded {
  transform: translateX(2px);
}

.jb-company-card__members {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.jb-company-avatar {
  width: 44px;
  height: 44px;
  border-radius: 999px;
  display: grid;
  place-items: center;
  background: color-mix(in srgb, var(--jb-primary) 12%, var(--jb-surface));
  color: var(--jb-primary);
  border: 1px solid color-mix(in srgb, var(--jb-primary) 18%, var(--jb-border));
  font-size: .84rem;
  font-weight: 900;
  box-shadow: var(--jb-shadow-soft);
}

.jb-company-spotlight {
  position: absolute;
  inset: 0;
  pointer-events: none;
  border-radius: inherit;
  opacity: 0;
  background: radial-gradient(circle at var(--mx, 50%) var(--my, 50%), rgba(255,255,255,.24), transparent 32%);
  transition: opacity .22s ease;
  z-index: 0;
}

.jb-company-card:hover .jb-company-spotlight {
  opacity: 1;
}

.jb-company-empty {
  display: grid;
  place-items: center;
  padding: 42px;
  text-align: center;
}

.jb-company-show {
  padding-top: clamp(20px, 3vw, 34px);
  padding-bottom: clamp(64px, 8vw, 104px);
}

.jb-company-show__hero {
  padding-bottom: clamp(30px, 4vw, 56px);
}

.jb-company-show__profile {
  --jb-company-cover-pad: clamp(24px, 4vw, 48px);
  --jb-company-logo-size: clamp(124px, 12vw, 164px);
  --jb-company-logo-lift: clamp(44px, 4.4vw, 80px);
  display: grid;
  gap: clamp(22px, 3vw, 36px);
}

.jb-company-show__cover {
  position: relative;
  min-height: clamp(260px, 26vw, 360px);
  display: grid;
  align-content: space-between;
  gap: 24px;
  overflow: visible;
  padding: var(--jb-company-cover-pad) var(--jb-company-cover-pad) clamp(106px, 9vw, 142px);
  border-radius: clamp(34px, 4vw, 58px);
  color: #fff;
  background:
    radial-gradient(circle at 14% 20%, rgba(255, 255, 255, .2), transparent 24%),
    radial-gradient(circle at 82% 18%, rgba(255, 255, 255, .16), transparent 30%),
    linear-gradient(135deg, #ff3b3b 0%, #c81f2f 52%, #101217 100%);
  border: 1px solid rgba(var(--jb-surface-rgb), .22);
  box-shadow: var(--jb-shadow-hero);
}

.jb-company-show__cover > :not(.jb-company-hero__halo):not(.jb-company-hero__halo--two):not(.jb-company-show__logo-shell):not(.jb-company-show__identity) {
  position: relative;
  z-index: 1;
}

.jb-company-show__cover-copy {
  display: grid;
  justify-items: end;
  gap: 10px;
  max-width: 520px;
  margin-left: auto;
  text-align: right;
}

.jb-company-show__cover-copy p {
  margin: 0;
  color: rgba(255, 255, 255, .82);
  line-height: 1.7;
  max-width: 56ch;
}

.jb-company-show__profile-body {
  position: relative;
  z-index: 2;
  display: flex;
  justify-content: flex-end;
  gap: clamp(18px, 3vw, 34px);
  align-items: center;
  margin-top: calc(var(--jb-company-logo-size) - var(--jb-company-logo-lift) + clamp(18px, 3vw, 30px));
  padding: 0 clamp(18px, 4vw, 54px);
}

.jb-company-show__logo-shell {
  position: absolute;
  left: 0;
  top: calc(100% - var(--jb-company-logo-lift));
  /* right: calc(100% - var(--jb-company-logo-size) - var(--jb-company-cover-pad)); */
  z-index: 3;
  width: var(--jb-company-logo-size);
  aspect-ratio: 1;
  display: grid;
  place-items: center;
  padding: 8px;
  border-radius: 999px;
  background: var(--jb-surface);
  border: 1px solid color-mix(in srgb, var(--jb-border) 80%, transparent);
  box-shadow: var(--jb-shadow);
}

.jb-company-show__logo-shell .jb-company-logo,
.jb-company-show__logo-shell .jb-company-logo--fallback {
  width: 100%;
  height: 100%;
  border-radius: 999px;
}

.jb-company-show__cover .jb-company-show__identity {
  position: absolute;
  left: calc(var(--jb-company-logo-size) + var(--jb-company-cover-pad));
  right: var(--jb-company-cover-pad);
  bottom: clamp(26px, 4vw, 52px);
  z-index: 2;
  display: grid;
  gap: 10px;
  min-width: 0;
  max-width: none;
  margin: 0;
}

.jb-company-show__cover .jb-company-show__identity .jb-kicker {
  color: var(--jb-surface-alt);
}

.jb-company-show__cover .jb-company-show__identity .jb-pill {
  border-color: rgba(255, 255, 255, .22);
  background: rgba(255, 255, 255, .12);
  color: #fff;
}

.jb-company-show__profile-body .jb-company-show__actions {
  justify-self: end;
  margin-top: 0;
  padding-bottom: 16px;
}

.jb-company-show__profile .jb-company-show__title {
  max-width: 920px;
  margin: 0;
  color: var(--jb-text);
  overflow-wrap: anywhere;
}

.jb-company-show__cover .jb-company-show__title {
  color: #fff;
  letter-spacing: 0;
  text-shadow: 0 16px 34px rgba(16, 18, 24, .24);
}

.jb-company-show__profile .jb-company-show__lead {
  max-width: 74ch;
  margin: 0;
  padding: 0 clamp(18px, 4vw, 54px);
  color: var(--jb-text-muted);
  font-size: clamp(.98rem, 1.15vw, 1.06rem);
  line-height: 1.9;
}

.jb-company-show__hero-meta {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: clamp(20px, 3vw, 30px);
  align-items: start;
}

.jb-company-show__hero-cards {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: clamp(16px, 2vw, 22px);
  align-items: start;
}

.jb-company-show__profile .jb-company-show__stats {
  margin-top: 0;
}

.jb-company-show__hero-cards .jb-company-glance__metric strong {
  font-size: 1rem;
  line-height: 1.35;
  letter-spacing: 0;
  overflow-wrap: anywhere;
}

.jb-company-show__profile .jb-company-show__stat {
  min-width: 0;
  background: color-mix(in srgb, var(--jb-surface-soft) 94%, transparent);
  border: 1px solid color-mix(in srgb, var(--jb-border) 84%, transparent);
  color: var(--jb-text);
  box-shadow: var(--jb-shadow-soft);
}

.jb-company-show__profile .jb-company-show__stat span {
  color: var(--jb-text-muted);
}

.jb-company-show__profile .jb-company-show__stat strong {
  display: block;
  color: var(--jb-text);
  overflow-wrap: anywhere;
}

.jb-company-show__hero-grid,
.jb-company-show__layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(280px, 360px);
  gap: clamp(30px, 4vw, 56px);
  align-items: start;
}

.jb-company-show__layout > .jb-stack {
  min-width: 0;
}

.jb-company-show__main {
  background: var(--jb-gradient-hero);
  color: #fff;
  box-shadow: var(--jb-shadow-hero);
}

.jb-company-show__side {
  position: sticky;
  top: 118px;
  display: grid;
  gap: clamp(18px, 2vw, 24px);
}

.jb-company-breadcrumbs {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  align-items: center;
  margin-bottom: 18px;
  color: rgba(255,255,255,.74);
}

.jb-company-breadcrumbs strong { color: #fff; }

.jb-company-show__identity {
  display: flex;
  align-items: center;
  gap: 18px;
}

.jb-company-show__identity .jb-company-logo,
.jb-company-show__identity .jb-company-logo--fallback {
  width: 92px;
  height: 92px;
  border-radius: 28px;
}

.jb-company-show__title {
  margin: 18px 0 12px;
  font-size: clamp(2.5rem, 4vw, 4.3rem);
  line-height: .95;
  letter-spacing: -.06em;
}

.jb-company-show__lead {
  margin: 0;
  color: rgba(255,255,255,.8);
  line-height: 1.82;
  max-width: 64ch;
}

.jb-company-show__stats {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(min(180px, 100%), 1fr));
  gap: clamp(14px, 2vw, 18px);
  margin-top: clamp(18px, 3vw, 28px);
}

.jb-company-show__stat {
  min-height: 118px;
  padding: clamp(16px, 2vw, 22px);
  border-radius: 20px;
  background: rgba(255,255,255,.08);
  border: 1px solid rgba(255,255,255,.12);
}

.jb-company-show__stat span {
  display: block;
  color: rgba(255,255,255,.66);
  font-size: .82rem;
  margin-bottom: 8px;
}

.jb-company-show__stat strong {
  font-size: clamp(1.4rem, 2vw, 2rem);
  line-height: 1;
}

.jb-company-show__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 24px;
}

.jb-company-panel {
  display: grid;
  gap: clamp(18px, 2.6vw, 28px);
}

.jb-company-keyfacts {
  display: grid;
  gap: 0;
}

.jb-company-keyfacts__item {
  display: grid;
  grid-template-columns: minmax(120px, .38fr) minmax(0, 1fr);
  align-items: start;
  gap: clamp(12px, 2vw, 22px);
  padding: clamp(16px, 2vw, 20px) 0;
  border-bottom: 1px solid color-mix(in srgb, var(--jb-border) 86%, transparent);
}

.jb-company-keyfacts__item strong {
  min-width: 0;
  line-height: 1.55;
  text-align: right;
  overflow-wrap: anywhere;
}

.jb-company-keyfacts__item:last-child {
  padding-bottom: 0;
  border-bottom: 0;
}

.jb-company-members-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(min(260px, 100%), 1fr));
  gap: clamp(16px, 2.4vw, 22px);
}

.jb-company-member {
  display: grid;
  gap: 16px;
  min-height: 100%;
}

.jb-company-member__top {
  display: flex;
  align-items: flex-start;
  gap: 14px;
}

.jb-company-member__avatar {
  width: 58px;
  height: 58px;
  border-radius: 20px;
  display: grid;
  place-items: center;
  background: var(--jb-gradient-brand);
  color: #fff;
  font-weight: 900;
  box-shadow: 0 16px 30px rgba(255, 59, 59, 0.18);
}

.jb-company-roles-grid,
.jb-company-permissions-grid {
  display: grid;
  gap: clamp(16px, 2vw, 22px);
}

.jb-company-roles-grid {
  grid-template-columns: repeat(auto-fit, minmax(min(280px, 100%), 1fr));
}

.jb-company-permissions-grid {
  grid-template-columns: repeat(auto-fit, minmax(min(300px, 100%), 1fr));
}

.jb-company-role-card,
.jb-company-permission-group {
  min-width: 0;
  padding: clamp(18px, 2.4vw, 24px);
  border-radius: 22px;
  background: color-mix(in srgb, var(--jb-surface-soft) 94%, transparent);
  border: 1px solid color-mix(in srgb, var(--jb-border) 84%, transparent);
}

.jb-company-role-card__head,
.jb-company-permission-group__head {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 14px;
}

.jb-company-role-dot {
  width: 12px;
  height: 12px;
  border-radius: 999px;
  background: var(--role-color, var(--jb-primary));
  box-shadow: 0 0 0 6px color-mix(in srgb, var(--role-color, var(--jb-primary)) 14%, transparent);
}

.jb-company-permission-list {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.jb-company-permission-pill {
  display: inline-flex;
  align-items: center;
  min-height: 38px;
  padding: 0 12px;
  border-radius: 999px;
  background: var(--jb-surface);
  border: 1px solid color-mix(in srgb, var(--jb-border) 84%, transparent);
  font-size: .88rem;
  font-weight: 700;
}

.jb-company-glance {
  display: grid;
  gap: clamp(14px, 2vw, 18px);
}

.jb-company-glance__metric {
  position: relative;
  padding: clamp(16px, 2vw, 20px) clamp(18px, 2.4vw, 22px) clamp(16px, 2vw, 20px) clamp(22px, 2.8vw, 28px);
  border-radius: 22px;
  background: color-mix(in srgb, var(--jb-surface-soft) 92%, transparent);
  border: 1px solid color-mix(in srgb, var(--jb-border) 84%, transparent);
}

.jb-company-glance__metric::before {
  content: '';
  position: absolute;
  inset: 16px auto 16px 0;
  width: 4px;
  border-radius: 999px;
  background: var(--jb-gradient-brand);
}

.jb-company-glance__metric span {
  display: block;
  color: var(--jb-text-muted);
  font-size: .82rem;
  margin-bottom: 8px;
}

.jb-company-glance__metric strong {
  display: block;
  font-size: clamp(1.5rem, 2vw, 2.2rem);
  line-height: 1;
  letter-spacing: -.04em;
  overflow-wrap: anywhere;
}

.jb-company-show__floating {
  position: sticky;
  bottom: 24px;
  z-index: 28;
}

.jb-company-show__floating-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 18px 20px;
  border-radius: 26px;
  background: color-mix(in srgb, var(--jb-surface) 92%, transparent);
  border: 1px solid var(--jb-border);
  box-shadow: var(--jb-shadow);
  backdrop-filter: blur(18px);
}

.jb-company-metric-badge {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  min-height: 40px;
  padding: 0 14px;
  border-radius: 999px;
  background: color-mix(in srgb, var(--jb-primary) 10%, var(--jb-surface));
  border: 1px solid color-mix(in srgb, var(--jb-primary) 18%, var(--jb-border));
  color: var(--jb-primary);
  font-weight: 800;
}

.jb-company-card__quickpeek {
  display: grid;
  gap: 10px;
  align-content: start;
}

@media (max-width: 1100px) {
  .jb-company-hero__grid,
  .jb-company-show__hero-grid,
  .jb-company-show__layout,
  .jb-company-card--featured {
    grid-template-columns: 1fr;
  }

  .jb-company-filters__row {
    grid-template-columns: minmax(0, 1fr) minmax(220px, .85fr);
  }

  .jb-company-filters__row .jb-chip,
  .jb-company-filters__row .jb-button {
    justify-self: start;
  }

  .jb-company-show__side {
    position: static;
  }

  .jb-company-show__floating {
    position: static;
  }

  .jb-company-show__profile-body,
  .jb-company-show__hero-meta {
    grid-template-columns: 1fr;
  }

  .jb-company-show__hero-cards {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .jb-company-show__profile-body .jb-company-show__actions {
    justify-self: start;
    padding-bottom: 0;
  }
}

@media (max-width: 768px) {
  .jb-company-hero__title,
  .jb-company-show__title {
    max-width: none;
    font-size: clamp(2.2rem, 10vw, 3.2rem);
  }

  .jb-company-grid,
  .jb-company-members-grid,
  .jb-company-show__stats,
  .jb-company-card__quickstats,
  .jb-company-filters__row {
    grid-template-columns: 1fr;
  }

  .jb-company-card,
  .jb-company-card--featured {
    grid-column: auto;
  }

  .jb-company-show__floating-inner {
    flex-direction: column;
    align-items: stretch;
  }

  .jb-company-show__floating-inner .jb-button {
    width: 100%;
  }

  .jb-company-show__profile {
    --jb-company-cover-pad: 16px;
    --jb-company-logo-size: 108px;
    --jb-company-logo-lift: 18px;
  }

  .jb-company-show__cover {
    min-height: 260px;
    border-radius: 30px;
    padding: 20px var(--jb-company-cover-pad) 96px;
  }

  .jb-company-show__cover-copy {
    justify-items: start;
    margin-left: 0;
    text-align: left;
  }

  .jb-company-show__cover-copy p {
    max-width: 38ch;
  }

  .jb-company-show__profile-body {
    justify-content: stretch;
    margin-top: calc(var(--jb-company-logo-size) - var(--jb-company-logo-lift) + 18px);
    padding: 0 16px;
  }

  .jb-company-show__logo-shell {
    width: var(--jb-company-logo-size);
    left: 0;
    top: calc(100% - var(--jb-company-logo-lift));
    padding: 6px;
  }

  .jb-company-show__cover .jb-company-show__identity {
    left: calc(var(--jb-company-logo-size) + var(--jb-company-cover-pad));
    right: var(--jb-company-cover-pad);
    bottom: 16px;
  }

  .jb-company-show__profile-body .jb-company-show__actions {
    width: 100%;
  }

  .jb-company-show__profile .jb-company-show__lead {
    padding: 0 16px;
  }

  .jb-company-show__hero-cards {
    grid-template-columns: 1fr;
  }

  .jb-company-keyfacts__item {
    grid-template-columns: 1fr;
    gap: 6px;
  }

  .jb-company-keyfacts__item strong {
    text-align: left;
  }
}

@media (max-width: 560px) {
  .jb-company-show {
    padding-top: 16px;
  }

  .jb-company-show__profile {
    --jb-company-cover-pad: 14px;
    --jb-company-logo-size: 96px;
    --jb-company-logo-lift: 14px;
  }

  .jb-company-show__cover {
    min-height: 300px;
    padding: 18px var(--jb-company-cover-pad) 104px;
  }

  .jb-company-show__cover-copy {
    gap: 8px;
  }

  .jb-company-show__cover-copy p {
    font-size: .92rem;
    line-height: 1.6;
  }

  .jb-company-show__cover .jb-company-show__identity {
    left: var(--jb-company-cover-pad);
    right: var(--jb-company-cover-pad);
    bottom: 24px;
  }

  .jb-company-show__cover .jb-company-show__identity .jb-cluster {
    gap: 8px;
  }

  .jb-company-show__profile-body {
    margin-top: calc(var(--jb-company-logo-size) - var(--jb-company-logo-lift) + 20px);
    padding: 0;
  }

  .jb-company-show__profile-body .jb-company-show__actions {
    display: grid;
    width: 100%;
  }

  .jb-company-show__profile .jb-company-show__lead {
    padding: 0;
  }

  .jb-company-role-card__head,
  .jb-company-permission-group__head {
    align-items: flex-start;
  }
}

/* =========================
   COMPANIES CREATE WIZARD
   ========================= */

.jb-grid { display: grid; gap: 16px; }
.jb-grid-2 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.jb-grid-3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.jb-min-w-0 { min-width: 0; }

.jb-form-group { display: grid; gap: 8px; }
.jb-form-group--autocomplete { position: relative; }
.jb-label { font-size: .9rem; font-weight: 800; color: var(--jb-text); }
.jb-error { margin: 0; color: #d72d2d; font-size: .9rem; line-height: 1.5; }

.jb-company-location-suggestions {
  position: absolute;
  left: 0;
  right: 0;
  top: calc(100% + 8px);
  z-index: 30;
  display: grid;
  gap: 6px;
  max-height: 270px;
  overflow: auto;
  padding: 8px;
  border-radius: 18px;
  border: 1px solid color-mix(in srgb, var(--jb-border) 86%, transparent);
  background: color-mix(in srgb, var(--jb-surface) 98%, transparent);
  box-shadow: var(--jb-shadow);
}

.jb-company-location-suggestions[hidden] { display: none; }

.jb-company-location-suggestion {
  width: 100%;
  display: grid;
  gap: 3px;
  padding: 10px 12px;
  border: 0;
  border-radius: 12px;
  background: transparent;
  color: var(--jb-text);
  text-align: left;
  cursor: pointer;
}

.jb-company-location-suggestion:hover,
.jb-company-location-suggestion:focus-visible,
.jb-company-location-suggestion.is-active {
  outline: none;
  background: color-mix(in srgb, var(--jb-primary) 10%, var(--jb-surface-soft));
}

.jb-company-location-suggestion strong {
  font-size: .95rem;
  line-height: 1.25;
}

.jb-company-location-suggestion span,
.jb-company-location-suggestion small {
  color: var(--jb-text-muted);
  font-size: .82rem;
  line-height: 1.35;
}

.jb-textarea {
  width: 100%;
  min-height: 132px;
  padding: 14px 16px;
  border-radius: 20px;
  border: 1px solid var(--jb-border);
  background: var(--jb-surface);
  color: var(--jb-text);
  resize: vertical;
  box-shadow: var(--jb-shadow-soft);
}

.jb-textarea:focus {
  outline: none;
  border-color: color-mix(in srgb, var(--jb-primary) 34%, var(--jb-border));
  box-shadow: 0 0 0 4px color-mix(in srgb, var(--jb-primary) 12%, transparent);
}

.jb-company-logo-input {
  min-height: 54px;
  padding: 13px 16px;
}

.jb-input--color { min-height: 52px; padding: 8px; }

.jb-company-create-modal[hidden] { display: none !important; }

.jb-company-create-modal {
  position: fixed;
  inset: 0;
  z-index: 130;
  display: grid;
  place-items: center;
  padding: 24px;
  background:
    radial-gradient(circle at top left, color-mix(in srgb, var(--jb-primary) 12%, transparent), transparent 30%),
    rgba(10, 12, 16, .62);
  backdrop-filter: blur(14px);
}

.jb-company-create-modal__dialog,
.jb-company-create--page {
  width: min(1180px, 100%);
  max-height: min(94vh, 980px);
  overflow: hidden;
  border-radius: 34px;
  background: color-mix(in srgb, var(--jb-surface) 96%, transparent);
  border: 1px solid color-mix(in srgb, var(--jb-border) 84%, transparent);
  box-shadow: var(--jb-shadow);
  position: relative;
}

.jb-company-create--page { max-height: none; }

.jb-company-create {
  display: grid;
  grid-template-rows: auto 1fr auto;
  min-height: 680px;
}

.jb-company-create__close { position: absolute; top: 18px; right: 18px; z-index: 4; }

.jb-company-create__header {
  display: grid;
  gap: 18px;
  padding: 28px 30px 22px;
  border-bottom: 1px solid color-mix(in srgb, var(--jb-border) 80%, transparent);
  background:
    radial-gradient(circle at top right, color-mix(in srgb, var(--jb-primary) 10%, transparent), transparent 34%),
    linear-gradient(180deg, color-mix(in srgb, var(--jb-surface) 98%, transparent), color-mix(in srgb, var(--jb-surface-soft) 92%, transparent));
}

.jb-company-create__title {
  margin: 0;
  font-size: clamp(2rem, 3vw, 2.7rem);
  letter-spacing: -.05em;
  line-height: .98;
}

.jb-company-create__lead {
  margin: 0;
  color: var(--jb-text-muted);
  line-height: 1.8;
  max-width: 66ch;
}

.jb-company-create__progress {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
}

.jb-company-create__step {
  min-height: 72px;
  display: grid;
  grid-template-columns: 42px minmax(0, 1fr);
  gap: 12px;
  align-items: center;
  padding: 14px 16px;
  border-radius: 22px;
  border: 1px solid color-mix(in srgb, var(--jb-border) 84%, transparent);
  background: color-mix(in srgb, var(--jb-surface-soft) 92%, transparent);
  color: var(--jb-text);
  text-align: left;
  box-shadow: var(--jb-shadow-soft);
}

.jb-company-create__step span {
  width: 42px;
  height: 42px;
  border-radius: 999px;
  display: grid;
  place-items: center;
  background: var(--jb-surface);
  border: 1px solid var(--jb-border);
  font-weight: 900;
}

.jb-company-create__step strong {
  font-size: .96rem;
  line-height: 1.2;
  letter-spacing: -.02em;
}

.jb-company-create__step.is-active {
  color: var(--jb-primary);
  background: color-mix(in srgb, var(--jb-primary) 10%, var(--jb-surface));
  border-color: color-mix(in srgb, var(--jb-primary) 18%, var(--jb-border));
}

.jb-company-create__step.is-complete span {
  background: color-mix(in srgb, var(--jb-primary) 14%, var(--jb-surface));
  color: var(--jb-primary);
}

.jb-company-create__body { position: relative; overflow: visible; padding: 24px 24px 14px; }
.jb-company-create__screen { display: none; opacity: 0; transform: translateY(12px); }
.jb-company-create__screen.is-active { display: block; opacity: 1; transform: none; }

.jb-company-create__screen-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.1fr) minmax(280px, .9fr);
  gap: 24px;
}

.jb-company-create__screen-title {
  margin: 0;
  font-size: clamp(1.45rem, 2vw, 1.9rem);
  letter-spacing: -.04em;
}

.jb-company-create__aside { display: grid; gap: 16px; align-content: start; }
.jb-company-create__aside-card { display: grid; gap: 14px; }

.jb-company-create__preview-head {
  display: flex;
  align-items: center;
  gap: 14px;
  min-width: 0;
}

.jb-company-create__logo-preview {
  flex: 0 0 74px;
  width: 74px;
  height: 74px;
  display: grid;
  place-items: center;
  overflow: hidden;
  border-radius: 24px;
  background: var(--jb-gradient-brand);
  color: #fff;
  border: 1px solid rgba(255, 255, 255, .24);
  box-shadow: var(--jb-shadow-soft);
}

.jb-company-create__logo-preview span {
  font-size: 1.15rem;
  font-weight: 900;
  letter-spacing: .02em;
}

.jb-company-create__logo-preview img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.jb-company-create__aside-eyebrow {
  display: inline-flex;
  align-items: center;
  width: fit-content;
  min-height: 38px;
  padding: 0 12px;
  border-radius: 999px;
  background: color-mix(in srgb, var(--jb-primary) 10%, var(--jb-surface));
  border: 1px solid color-mix(in srgb, var(--jb-primary) 18%, var(--jb-border));
  color: var(--jb-primary);
  font-size: .82rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .06em;
}

.jb-company-create__preview-name {
  font-size: clamp(1.4rem, 2vw, 1.8rem);
  line-height: 1;
  letter-spacing: -.04em;
}

.jb-company-create__section-head {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 16px;
}

.jb-company-create__repeater { display: grid; gap: 16px; }
.jb-company-create__role-card,
.jb-company-create__invite-card,
.jb-company-create__review,
.jb-company-create__empty { display: grid; gap: 16px; }

.jb-company-create__role-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.jb-company-create__footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  padding: 18px 24px 24px;
  border-top: 1px solid color-mix(in srgb, var(--jb-border) 78%, transparent);
  background: color-mix(in srgb, var(--jb-surface) 98%, transparent);
}

@media (max-width: 1100px) {
  .jb-company-create__screen-grid { grid-template-columns: 1fr; }
}

@media (max-width: 768px) {
  .jb-grid-2, .jb-grid-3, .jb-company-create__progress { grid-template-columns: 1fr; }
  .jb-company-create-modal { padding: 12px; }
  .jb-company-create-modal__dialog, .jb-company-create--page { border-radius: 24px; max-height: 95vh; }
  .jb-company-create__header, .jb-company-create__body, .jb-company-create__footer { padding-left: 16px; padding-right: 16px; }
  .jb-company-create__footer, .jb-company-create__section-head { flex-direction: column; align-items: stretch; }
  .jb-company-create__footer .jb-button, .jb-company-create__section-head .jb-button { width: 100%; }
}

/* =========================
   JOBBRIDGE MERGED MODULE CSS: COMPANY CREATE MODAL FIX
   ========================= */

/* =========================
   JOBBRIDGE · COMPANY CREATE MODAL FIX
   ========================= */

/* Make the overlay itself scrollable and keep the dialog fully visible */
.jb-company-create-modal {
  overflow-y: auto;
  overflow-x: hidden;
  align-items: start;
  padding: clamp(12px, 2vw, 24px);
}

/* Keep the dialog centered, constrained to viewport, and independently scrollable */
.jb-company-create-modal__dialog {
  width: min(1100px, calc(100vw - 24px));
  max-height: calc(100dvh - 24px);
  margin: auto;
  display: block;
  overflow: hidden;
}

/* Let the wizard size itself to the viewport in modal mode */
.jb-company-create-modal__dialog .jb-company-create {
  min-height: 0;
  height: min(860px, calc(100dvh - 24px));
  overflow-x: hidden;
  overflow-y: auto;
  overscroll-behavior: contain;
  scrollbar-gutter: stable;
}

/* Keep page mode natural and avoid nested scroll traps in modal mode */
.jb-company-create-modal__dialog .jb-company-create__body {
  min-height: 0;
  overflow: visible;
  overscroll-behavior: auto;
  padding-bottom: 20px;
}

/* Keep top and bottom actions visible while the content scrolls */
.jb-company-create__header,
.jb-company-create__footer {
  position: relative;
  z-index: 2;
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--jb-surface) 98%, transparent), color-mix(in srgb, var(--jb-surface-soft) 92%, transparent));
}

.jb-company-create__footer {
  background: color-mix(in srgb, var(--jb-surface) 98%, transparent);
}

/* Modal-specific layout: stack the aside under the main form to avoid crushed columns */
.jb-company-create-modal__dialog .jb-company-create__screen-grid {
  grid-template-columns: minmax(0, 1fr);
  gap: 18px;
}

.jb-company-create-modal__dialog .jb-company-create__aside {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  align-content: start;
}

/* More compact header spacing for the modal */
.jb-company-create-modal__dialog .jb-company-create__header {
  position: sticky;
  top: 0;
  padding: 22px 24px 18px;
  gap: 14px;
}

.jb-company-create-modal__dialog .jb-company-create__title {
  font-size: clamp(1.8rem, 2.4vw, 2.35rem);
}

/* Close button should not sit on top of the title */
.jb-company-create__close {
  top: 14px;
  right: 14px;
}

.jb-company-create-modal__dialog .jb-company-create__progress {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.jb-company-create__step {
  min-width: 0;
}

.jb-company-create__step strong {
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

/* Prevent long content cards from stretching awkwardly */
.jb-company-create__aside-card,
.jb-company-create__role-card,
.jb-company-create__invite-card,
.jb-company-create__review,
.jb-company-create__empty {
  min-width: 0;
}

/* Better modal footer behavior */
.jb-company-create-modal__dialog .jb-company-create__footer {
  position: sticky;
  bottom: 0;
  padding: 14px 24px 20px;
}

/* Slightly calmer body spacing */
.jb-company-create-modal__dialog .jb-company-create__body {
  padding: 18px 24px 14px;
}

/* Ensure the page wizard keeps its large layout while the modal gets fixed */
.jb-company-create--page {
  width: 100%;
  max-height: none;
  min-height: 0;
  overflow: visible;
  grid-template-rows: auto auto auto;
}

.jb-company-create--page .jb-company-create__body {
  min-height: auto;
  overflow: visible;
  overscroll-behavior: auto;
}

/* Tablet */
@media (max-width: 980px) {
  .jb-company-create-modal__dialog {
    width: min(100%, calc(100vw - 20px));
    max-height: calc(100dvh - 20px);
    border-radius: 24px;
  }

  .jb-company-create-modal__dialog .jb-company-create {
    height: calc(100dvh - 20px);
  }

  .jb-company-create-modal__dialog .jb-company-create__aside {
    grid-template-columns: 1fr;
  }

  .jb-company-create-modal__dialog .jb-company-create__progress {
    grid-template-columns: 1fr;
  }

  .jb-company-create-modal__dialog .jb-company-create__footer {
    flex-direction: column;
    align-items: stretch;
  }

  .jb-company-create-modal__dialog .jb-company-create__footer .jb-button {
    width: 100%;
  }
}

/* Mobile */
@media (max-width: 640px) {
  .jb-company-create-modal {
    padding: 8px;
  }

  .jb-company-create-modal__dialog {
    width: calc(100vw - 16px);
    max-height: calc(100dvh - 16px);
    border-radius: 20px;
  }

  .jb-company-create-modal__dialog .jb-company-create {
    height: calc(100dvh - 16px);
  }

  .jb-company-create-modal__dialog .jb-company-create__header,
  .jb-company-create-modal__dialog .jb-company-create__body,
  .jb-company-create-modal__dialog .jb-company-create__footer {
    padding-left: 14px;
    padding-right: 14px;
  }

  .jb-company-create__close {
    top: 10px;
    right: 10px;
  }
}

/* =========================
   JOBBRIDGE TEAM DIRECTORY
   ========================= */

.jb-team-page--directory {
  --jb-team-text: var(--jb-text);
  --jb-team-muted: var(--jb-text-muted);
  --jb-team-bg-start: color-mix(in srgb, var(--jb-primary) 6%, var(--jb-surface-alt));
  --jb-team-bg-mid: color-mix(in srgb, var(--jb-primary) 3%, var(--jb-surface));
  --jb-team-bg-end: color-mix(in srgb, var(--jb-primary) 2%, var(--jb-surface-soft));
  --jb-team-border: color-mix(in srgb, var(--jb-border) 82%, transparent);
  --jb-team-border-soft: color-mix(in srgb, var(--jb-border) 70%, transparent);
  --jb-team-topbar-bg: color-mix(in srgb, var(--jb-surface) 86%, transparent);
  --jb-team-topbar-border: color-mix(in srgb, var(--jb-border) 72%, transparent);
  --jb-team-control-bg: color-mix(in srgb, var(--jb-surface) 94%, transparent);
  --jb-team-control-bg-hover: color-mix(in srgb, var(--jb-primary) 6%, var(--jb-surface));
  --jb-team-control-border: color-mix(in srgb, var(--jb-border) 74%, transparent);
  --jb-team-control-border-hover: color-mix(in srgb, var(--jb-primary) 16%, var(--jb-border));
  --jb-team-control-text: var(--jb-text);
  --jb-team-filter-bg: color-mix(in srgb, var(--jb-surface-soft) 96%, transparent);
  --jb-team-filter-bg-hover: color-mix(in srgb, var(--jb-primary) 5%, var(--jb-surface));
  --jb-team-filter-border: color-mix(in srgb, var(--jb-border) 76%, transparent);
  --jb-team-filter-border-hover: color-mix(in srgb, var(--jb-primary) 16%, var(--jb-border));
  --jb-team-filter-text: var(--jb-text-muted);
  --jb-team-card: color-mix(in srgb, var(--jb-primary) 3%, var(--jb-surface));
  --jb-team-card-alt: color-mix(in srgb, var(--jb-primary) 2%, var(--jb-surface-soft));
  --jb-team-card-hover: color-mix(in srgb, var(--jb-primary) 6%, var(--jb-surface));
  --jb-team-card-hover-alt: color-mix(in srgb, var(--jb-primary) 5%, var(--jb-surface-soft));
  --jb-team-card-shadow: var(--jb-shadow-soft);
  --jb-team-card-shadow-hover: var(--jb-shadow);
  --jb-team-ring: linear-gradient(180deg, #edf1f8, #dfe6f1);
  --jb-team-accent-shell: color-mix(in srgb, var(--jb-surface) 96%, transparent);
  --jb-team-role-bg: color-mix(in srgb, var(--jb-primary) 9%, var(--jb-surface));
  --jb-team-role-border: color-mix(in srgb, var(--jb-primary) 16%, var(--jb-border));
  --jb-team-role-text: color-mix(in srgb, var(--jb-primary-dark) 74%, var(--jb-text));
  --jb-team-tag-bg: color-mix(in srgb, var(--jb-surface-soft) 94%, transparent);
  --jb-team-tag-border: color-mix(in srgb, var(--jb-border) 74%, transparent);
  --jb-team-tag-text: var(--jb-text-muted);
  --jb-team-stat-border: color-mix(in srgb, var(--jb-border) 72%, transparent);
  color-scheme: light;
  background:
    radial-gradient(circle at top left, color-mix(in srgb, var(--jb-primary) 10%, transparent), transparent 24%),
    linear-gradient(180deg, var(--jb-team-bg-start) 0%, var(--jb-team-bg-mid) 28%, var(--jb-team-bg-end) 100%);
  color: var(--jb-team-text);
}

html[data-theme='dark'] .jb-team-page--directory {
  --jb-team-text: #f5f7fb;
  --jb-team-muted: #98a1b5;
  --jb-team-bg-start: #1a171d;
  --jb-team-bg-mid: #171a20;
  --jb-team-bg-end: #181a20;
  --jb-team-border: rgba(88, 95, 116, 0.42);
  --jb-team-border-soft: rgba(78, 84, 103, 0.24);
  --jb-team-topbar-bg: rgba(14, 16, 20, 0.92);
  --jb-team-topbar-border: rgba(88, 95, 116, 0.22);
  --jb-team-control-bg: rgba(28, 31, 39, 0.92);
  --jb-team-control-bg-hover: rgba(35, 39, 48, 0.98);
  --jb-team-control-border: rgba(88, 95, 116, 0.3);
  --jb-team-control-border-hover: rgba(255, 59, 59, 0.26);
  --jb-team-control-text: #f5f7fb;
  --jb-team-filter-bg: rgba(33, 37, 46, 0.96);
  --jb-team-filter-bg-hover: rgba(38, 42, 51, 1);
  --jb-team-filter-border: rgba(78, 84, 103, 0.24);
  --jb-team-filter-border-hover: rgba(255, 59, 59, 0.2);
  --jb-team-filter-text: #98a1b5;
  --jb-team-card: #1d2028;
  --jb-team-card-alt: #20242d;
  --jb-team-card-hover: #20242d;
  --jb-team-card-hover-alt: #232833;
  --jb-team-card-shadow: 0 24px 46px rgba(0, 0, 0, 0.18);
  --jb-team-card-shadow-hover: 0 28px 52px rgba(0, 0, 0, 0.24);
  --jb-team-ring: linear-gradient(180deg, #152235, #0f1625);
  --jb-team-accent-shell: rgba(49, 32, 38, 0.94);
  --jb-team-role-bg: rgba(63, 35, 42, 0.88);
  --jb-team-role-border: rgba(255, 59, 59, 0.12);
  --jb-team-role-text: #ff7d7d;
  --jb-team-tag-bg: rgba(28, 31, 39, 0.88);
  --jb-team-tag-border: rgba(78, 84, 103, 0.24);
  --jb-team-tag-text: #98a1b5;
  --jb-team-stat-border: rgba(78, 84, 103, 0.24);
  color-scheme: dark;
  background:
    radial-gradient(circle at top left, rgba(255, 59, 59, 0.14), transparent 24%),
    linear-gradient(180deg, var(--jb-team-bg-start) 0%, var(--jb-team-bg-mid) 28%, var(--jb-team-bg-end) 100%);
}

.jb-team-page--directory .jb-topbar {
  background: var(--jb-team-topbar-bg);
  border-bottom: 1px solid var(--jb-team-topbar-border);
  backdrop-filter: blur(18px);
}

.jb-team-page--directory :is(.jb-icon-button, .jb-nav__link, .jb-locale-switcher__trigger) {
  background: var(--jb-team-control-bg);
  border-color: var(--jb-team-control-border);
  color: var(--jb-team-control-text);
  box-shadow: none;
}

.jb-team-page--directory :is(.jb-icon-button, .jb-nav__link, .jb-locale-switcher__trigger):hover,
.jb-team-page--directory :is(.jb-icon-button, .jb-nav__link, .jb-locale-switcher__trigger):focus-visible {
  background: var(--jb-team-control-bg-hover);
  border-color: var(--jb-team-control-border-hover);
  color: var(--jb-team-text);
}

.jb-team-directory-page {
  min-height: calc(100vh - var(--jb-topbar-height));
  padding: clamp(28px, 4vw, 52px) 0 clamp(56px, 6vw, 84px);
}

.jb-team-directory-stage {
  display: grid;
  grid-template-columns: minmax(0, 1.08fr) minmax(260px, 360px);
  gap: clamp(36px, 6vw, 88px);
  align-items: start;
}

.jb-team-directory-stage__main {
  display: grid;
  gap: 22px;
  align-content: start;
}

.jb-team-directory-stage__header {
  display: grid;
  gap: 14px;
  max-width: 620px;
}

.jb-team-directory-stage__eyebrow,
.jb-team-directory-stage__aside-kicker {
  display: inline-flex;
  align-items: center;
  width: fit-content;
  min-height: 30px;
  padding: 0 12px;
  border-radius: 999px;
  background: rgba(255, 59, 59, 0.08);
  border: 1px solid rgba(255, 59, 59, 0.16);
  color: #ff4a4a;
  font-size: 0.78rem;
  font-weight: 900;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.jb-team-directory-stage__title {
  margin: 0;
  font-size: clamp(2.5rem, 5vw, 4rem);
  line-height: 0.94;
  letter-spacing: -0.07em;
  color: var(--jb-team-text);
}

.jb-team-directory-panel__filters {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
}

.jb-team-filter {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 42px;
  padding: 0 18px;
  border-radius: 999px;
  border: 1px solid var(--jb-team-filter-border);
  background: var(--jb-team-filter-bg);
  color: var(--jb-team-filter-text);
  font-size: 0.78rem;
  font-weight: 900;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  box-shadow: none;
  transition:
    transform 0.18s ease,
    border-color 0.18s ease,
    background 0.18s ease,
    color 0.18s ease,
    box-shadow 0.18s ease;
}

.jb-team-filter:hover,
.jb-team-filter:focus-visible {
  transform: translateY(-1px);
  background: var(--jb-team-filter-bg-hover);
  border-color: var(--jb-team-filter-border-hover);
  color: var(--jb-team-text);
  outline: none;
}

.jb-team-filter.is-active {
  background: linear-gradient(180deg, #ff4b43 0%, #f32828 100%);
  border-color: transparent;
  color: #fff;
  box-shadow: 0 14px 28px rgba(255, 59, 59, 0.22);
}

.jb-team-directory-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 260px));
  gap: 28px;
  justify-content: start;
  align-items: start;
}

.jb-team-directory-card {
  display: grid;
  gap: 18px;
  justify-items: center;
  text-align: center;
  min-height: 100%;
  width: 100%;
  max-width: 260px;
  padding: 28px 20px 22px;
  border-radius: 28px;
  border: 1px solid var(--jb-team-border);
  background: linear-gradient(180deg, var(--jb-team-card) 0%, var(--jb-team-card-alt) 100%);
  box-shadow: var(--jb-team-card-shadow);
  transition:
    transform 0.22s ease,
    border-color 0.22s ease,
    box-shadow 0.22s ease,
    background 0.22s ease;
}

.jb-team-directory-card:hover {
  transform: translateY(-6px);
  border-color: var(--jb-team-filter-border-hover);
  background: linear-gradient(180deg, var(--jb-team-card-hover) 0%, var(--jb-team-card-hover-alt) 100%);
  box-shadow: var(--jb-team-card-shadow-hover);
}

.jb-team-directory-card__portrait-shell {
  position: relative;
  width: min(100%, 176px);
  aspect-ratio: 1 / 1;
  display: grid;
  place-items: center;
}

.jb-team-directory-card__portrait-ring {
  position: absolute;
  inset: 8px;
  border-radius: 999px;
  background: var(--jb-team-ring);
}

.jb-team-directory-card__portrait {
  position: relative;
  z-index: 1;
  width: calc(100% - 16px);
  height: calc(100% - 16px);
  overflow: hidden;
  border-radius: 999px;
  background:
    linear-gradient(
      180deg,
      color-mix(in srgb, var(--team-accent, #ff3b3b) 78%, #ffffff),
      color-mix(in srgb, var(--team-accent, #ff3b3b) 72%, #7f1010)
    );
  display: grid;
  place-items: center;
  color: #fff;
  font-size: clamp(2rem, 3vw, 2.5rem);
  font-weight: 900;
  letter-spacing: 0.05em;
}

.jb-team-directory-card__portrait img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.jb-team-directory-card__accent {
  position: absolute;
  left: 10px;
  bottom: 16px;
  z-index: 2;
  width: 32px;
  height: 32px;
  display: grid;
  place-items: center;
  border-radius: 999px;
  background: var(--jb-team-accent-shell);
  border: 1px solid color-mix(in srgb, var(--jb-primary) 10%, var(--jb-team-border-soft));
}

.jb-team-directory-card__accent::after {
  content: '';
  width: 10px;
  height: 10px;
  border-radius: 999px;
  background: var(--team-accent, #ff3b3b);
  box-shadow: 0 0 0 6px color-mix(in srgb, var(--team-accent, #ff3b3b) 12%, transparent);
}

.jb-team-directory-card__body {
  display: grid;
  gap: 10px;
  justify-items: center;
}

.jb-team-directory-card__role {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  min-height: 36px;
  margin: 0;
  padding: 0 14px;
  border-radius: 999px;
  background: var(--jb-team-role-bg);
  border: 1px solid var(--jb-team-role-border);
  color: var(--jb-team-role-text);
  font-size: 0.72rem;
  font-weight: 900;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}

.jb-team-directory-card__role-dot {
  width: 10px;
  height: 10px;
  border-radius: 999px;
  background: var(--team-role-color, #ff3b3b);
  box-shadow: 0 0 0 6px color-mix(in srgb, var(--team-role-color, #ff3b3b) 12%, transparent);
}

.jb-team-directory-card__name {
  margin: 0;
  max-width: 10ch;
  color: var(--jb-team-text);
  font-size: 0.98rem;
  font-weight: 900;
  line-height: 1.18;
  letter-spacing: 0.03em;
  text-transform: uppercase;
}

.jb-team-directory-card__handle {
  margin: 0;
  color: var(--jb-team-muted);
  font-size: 0.84rem;
  font-weight: 700;
}

.jb-team-directory-card__tags {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 8px;
}

.jb-team-directory-card__tag {
  display: inline-flex;
  align-items: center;
  min-height: 30px;
  padding: 0 12px;
  border-radius: 999px;
  background: var(--jb-team-tag-bg);
  border: 1px solid var(--jb-team-tag-border);
  color: var(--jb-team-tag-text);
  font-size: 0.74rem;
  font-weight: 800;
}

.jb-team-directory-stage__aside {
  position: sticky;
  top: calc(var(--jb-topbar-height) + 36px);
  display: grid;
  gap: 24px;
  align-content: start;
  padding-top: clamp(92px, 10vw, 122px);
}

.jb-team-directory-stage__copy,
.jb-team-directory__empty {
  margin: 0;
  color: var(--jb-team-muted);
  line-height: 1.75;
}

.jb-team-directory-stage__copy {
  max-width: 22ch;
  font-size: clamp(1.22rem, 2vw, 1.72rem);
}

.jb-team-directory-stage__stats {
  display: grid;
  gap: 14px;
  max-width: 240px;
}

.jb-team-directory-stage__stat {
  display: grid;
  gap: 6px;
  padding-top: 14px;
  border-top: 1px solid var(--jb-team-stat-border);
}

.jb-team-directory-stage__stat:first-child {
  padding-top: 0;
  border-top: 0;
}

.jb-team-directory-stage__stat strong {
  color: var(--jb-team-text);
  font-size: 1.3rem;
  line-height: 1;
  letter-spacing: -0.04em;
}

.jb-team-directory-stage__stat span {
  color: var(--jb-team-muted);
  font-size: 0.78rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.jb-team-directory-stage__legend {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  max-width: 280px;
}

.jb-team-directory-stage__legend span {
  display: inline-flex;
  align-items: center;
  min-height: 32px;
  padding: 0 12px;
  border-radius: 999px;
  background: var(--jb-team-tag-bg);
  border: 1px solid var(--jb-team-tag-border);
  color: var(--jb-team-text);
  font-size: 0.76rem;
  font-weight: 800;
}

.jb-team-directory__empty {
  text-align: left;
}

.jb-team-directory-card[hidden] {
  display: none !important;
}

@media (max-width: 1080px) {
  .jb-team-directory-stage {
    grid-template-columns: 1fr;
    gap: 34px;
  }

  .jb-team-directory-stage__aside {
    position: static;
    padding-top: 0;
    max-width: 560px;
  }

  .jb-team-directory-stage__copy {
    max-width: 32ch;
  }
}

@media (max-width: 720px) {
  .jb-team-directory-page {
    padding-top: 22px;
  }

  .jb-team-directory-stage__title {
    font-size: clamp(2rem, 10vw, 3rem);
  }

  .jb-team-directory-grid {
    grid-template-columns: repeat(auto-fit, minmax(210px, 1fr));
    gap: 18px;
  }

  .jb-team-directory-card {
    max-width: none;
  }
}

@media (max-width: 520px) {
  .jb-team-directory-panel__filters {
    gap: 10px;
  }

  .jb-team-filter {
    width: 100%;
  }

  .jb-team-directory-grid {
    grid-template-columns: 1fr;
  }

  .jb-team-directory-card {
    max-width: 280px;
  }
}

@keyframes jb-verified-badge-fallback {
  0% {
    transform: translateY(0) rotate(0deg) scale(1);
  }

  24% {
    transform:
      translateY(var(--jb-verified-fallback-bounce-y, -10px))
      rotate(var(--jb-verified-fallback-rotate-a, -12deg))
      scale(var(--jb-verified-fallback-scale-a, 1.08));
  }

  58% {
    transform:
      translateY(0)
      rotate(var(--jb-verified-fallback-rotate-b, 12deg))
      scale(var(--jb-verified-fallback-scale-b, 0.98));
  }

  100% {
    transform: translateY(0) rotate(0deg) scale(1);
  }
}

@layer components {
  .jb-verified-badge {
    --jb-verified-size: 1.45rem;
    --jb-verified-icon-left: 10px;
    --jb-verified-fallback-bounce-y: -10px;
    --jb-verified-fallback-rotate-a: -12deg;
    --jb-verified-fallback-rotate-b: 12deg;
    --jb-verified-fallback-scale-a: 1.08;
    --jb-verified-fallback-scale-b: 0.98;
    --jb-verified-fallback-duration: 1.12s;
    position: relative;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: calc(var(--jb-verified-size) + 16px);
    padding: 8px 14px 8px calc(var(--jb-verified-size) + 20px);
    border: 0;
    border-radius: var(--jb-radius-pill);
    background: transparent;
    color: var(--jb-text);
    font-size: 0.84rem;
    font-weight: 800;
    letter-spacing: 0.01em;
    line-height: 1;
    white-space: nowrap;
    box-shadow: none;
    transform-origin: center center;
    transform-style: preserve-3d;
    backface-visibility: hidden;
    perspective: 1000px;
    will-change: transform;
    transition:
      box-shadow 0.24s ease,
      filter 0.24s ease,
      background-color 0.24s ease;
  }

  .jb-verified-badge::before {
    content: '';
    position: absolute;
    top: 50%;
    left: var(--jb-verified-icon-left);
    width: var(--jb-verified-size);
    height: var(--jb-verified-size);
    transform: translateY(-50%);
    clip-path: polygon(
      50% 0%,
      61% 8%,
      76% 5%,
      84% 17%,
      97% 24%,
      93% 39%,
      100% 50%,
      93% 61%,
      97% 76%,
      84% 83%,
      76% 95%,
      61% 92%,
      50% 100%,
      39% 92%,
      24% 95%,
      16% 83%,
      3% 76%,
      7% 61%,
      0% 50%,
      7% 39%,
      3% 24%,
      16% 17%,
      24% 5%,
      39% 8%
    );
    background:
      radial-gradient(circle at 30% 28%, rgba(255, 255, 255, 0.28), transparent 38%),
      linear-gradient(
        160deg,
        color-mix(in srgb, var(--jb-primary) 82%, #fff),
        color-mix(in srgb, var(--jb-primary-dark) 92%, #781515)
      );
    box-shadow:
      inset 0 1px 0 rgba(255, 255, 255, 0.22),
      0 8px 18px rgba(233, 46, 46, 0.28);
  }

  .jb-verified-badge::after {
    content: '';
    position: absolute;
    top: 50%;
    left: calc(var(--jb-verified-icon-left) + (var(--jb-verified-size) * 0.5));
    width: calc(var(--jb-verified-size) * 0.33);
    height: calc(var(--jb-verified-size) * 0.18);
    border-left: calc(var(--jb-verified-size) * 0.13) solid #fff;
    border-bottom: calc(var(--jb-verified-size) * 0.13) solid #fff;
    border-radius: 1px;
    transform: translate(-46%, -62%) rotate(-45deg);
    z-index: 1;
  }

  .jb-verified-badge:hover,
  .jb-verified-badge:focus-visible {
    box-shadow: none;
    filter: saturate(1.04) brightness(1.03);
  }

  .jb-verified-badge:focus-visible {
    outline: 0;
    box-shadow:
      0 0 0 3px color-mix(in srgb, var(--jb-primary) 18%, transparent),
      0 0 0 6px color-mix(in srgb, var(--jb-primary) 8%, transparent);
  }

  .jb-verified-badge--icon,
  .jb-verified-badge:empty {
    --jb-verified-size: 1.78rem;
    --jb-verified-icon-left: calc(50% - (var(--jb-verified-size) / 2));
    width: calc(var(--jb-verified-size) + 14px);
    min-width: calc(var(--jb-verified-size) + 14px);
    min-height: calc(var(--jb-verified-size) + 14px);
    padding: 0;
    border-radius: 50%;
  }

  .jb-verified-badge.is-animating {
    animation: jb-verified-badge-fallback var(--jb-verified-fallback-duration, 1.12s) cubic-bezier(0.2, 0.85, 0.25, 1) 1;
  }
}

@media (prefers-reduced-motion: reduce) {
  .jb-verified-badge {
    transition:
      box-shadow 0.2s ease,
      filter 0.2s ease,
      background-color 0.2s ease;
  }

  .jb-verified-badge.is-animating {
    animation: none;
  }
}

/* =========================================================================
   Tickets / Support center
   ========================================================================= */
@layer utilities {
  .jb-text-danger { color: #dc2626 !important; }
  .jb-text-success { color: var(--jb-success) !important; }
  .jb-flex-wrap { flex-wrap: wrap !important; }
  .jb-link {
    color: var(--jb-primary);
    text-decoration: none;
  }
  .jb-link:hover {
    text-decoration: underline;
  }
}

@layer components {
  /* Tabs (filter nav on tickets index) */
  .jb-tabs {
    display: flex;
    flex-wrap: wrap;
    gap: var(--jb-space-2);
    border-bottom: 1px solid var(--jb-border);
    padding-bottom: var(--jb-space-2);
  }

  .jb-tab {
    display: inline-flex;
    align-items: center;
    padding: 8px 16px;
    border-radius: var(--jb-radius-pill);
    border: 1px solid var(--jb-border);
    background: var(--jb-surface);
    color: var(--jb-text);
    font-weight: 600;
    font-size: 0.9rem;
    text-decoration: none;
    transition: background 0.15s ease, border-color 0.15s ease, color 0.15s ease;
  }

  .jb-tab:hover {
    background: var(--jb-surface-soft);
  }

  .jb-tab.is-active {
    color: var(--jb-primary);
    background: color-mix(in srgb, var(--jb-primary) 10%, var(--jb-surface));
    border-color: color-mix(in srgb, var(--jb-primary) 28%, var(--jb-border));
  }

  /* Status pill (color-coded per workflow state) */
  .jb-status {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 6px 12px;
    border-radius: var(--jb-radius-pill);
    font-size: 0.85rem;
    font-weight: 700;
    line-height: 1;
    text-transform: uppercase;
    letter-spacing: 0.02em;
    border: 1px solid transparent;
  }

  .jb-status::before {
    content: '';
    width: 7px;
    height: 7px;
    border-radius: 50%;
    background: currentColor;
  }

  .jb-status--new      { color: #1d4ed8; background: color-mix(in srgb, #1d4ed8 12%, var(--jb-surface)); border-color: color-mix(in srgb, #1d4ed8 26%, var(--jb-border)); }
  .jb-status--open     { color: #0891b2; background: color-mix(in srgb, #0891b2 12%, var(--jb-surface)); border-color: color-mix(in srgb, #0891b2 26%, var(--jb-border)); }
  .jb-status--pending  { color: #b45309; background: color-mix(in srgb, #f59e0b 14%, var(--jb-surface)); border-color: color-mix(in srgb, #f59e0b 30%, var(--jb-border)); }
  .jb-status--on_hold  { color: #4b5563; background: color-mix(in srgb, #6b7280 12%, var(--jb-surface)); border-color: color-mix(in srgb, #6b7280 26%, var(--jb-border)); }
  .jb-status--resolved { color: #047857; background: color-mix(in srgb, var(--jb-success) 14%, var(--jb-surface)); border-color: color-mix(in srgb, var(--jb-success) 30%, var(--jb-border)); }
  .jb-status--closed   { color: #475569; background: color-mix(in srgb, #475569 12%, var(--jb-surface)); border-color: color-mix(in srgb, #475569 26%, var(--jb-border)); }

  /* Priority pill */
  .jb-priority {
    display: inline-flex;
    align-items: center;
    padding: 5px 11px;
    border-radius: var(--jb-radius-pill);
    font-size: 0.8rem;
    font-weight: 700;
    line-height: 1;
    border: 1px solid transparent;
  }

  .jb-priority--low     { color: #475569; background: color-mix(in srgb, #94a3b8 14%, var(--jb-surface)); border-color: color-mix(in srgb, #94a3b8 30%, var(--jb-border)); }
  .jb-priority--normal  { color: #475569; background: var(--jb-surface-soft); border-color: var(--jb-border); }
  .jb-priority--high    { color: #c2410c; background: color-mix(in srgb, #f97316 14%, var(--jb-surface)); border-color: color-mix(in srgb, #f97316 30%, var(--jb-border)); }
  .jb-priority--urgent  { color: #b91c1c; background: color-mix(in srgb, #ef4444 14%, var(--jb-surface)); border-color: color-mix(in srgb, #ef4444 32%, var(--jb-border)); }

  /* Tag / alert warning variants */
  .jb-tag--warning {
    color: #b45309;
    background: color-mix(in srgb, #f59e0b 14%, var(--jb-surface));
    border-color: color-mix(in srgb, #f59e0b 30%, var(--jb-border));
  }

  .jb-alert--warning {
    background: color-mix(in srgb, #f59e0b 12%, var(--jb-surface));
    border: 1px solid color-mix(in srgb, #f59e0b 30%, var(--jb-border));
    color: #92400e;
    padding: var(--jb-space-4);
    border-radius: var(--jb-radius-md);
  }

  /* Empty state */
  .jb-empty-state {
    text-align: center;
    padding: var(--jb-space-12) var(--jb-space-8);
  }

  .jb-empty-state__icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 72px;
    height: 72px;
    border-radius: 50%;
    background: var(--jb-surface-soft);
    color: var(--jb-primary);
    font-size: 36px;
    margin-bottom: var(--jb-space-5);
  }

  .jb-empty-state h2 {
    margin: 0 0 var(--jb-space-2);
    font-size: 1.25rem;
  }

  .jb-empty-state p {
    color: var(--jb-text-muted);
    margin: 0;
  }

  /* Tickets list table */
  .jb-tickets-list {
    overflow-x: auto;
  }

  .jb-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 0.92rem;
  }

  .jb-table thead th {
    text-align: left;
    text-transform: uppercase;
    font-size: 0.72rem;
    letter-spacing: 0.04em;
    color: var(--jb-text-muted);
    padding: var(--jb-space-3) var(--jb-space-4);
    border-bottom: 1px solid var(--jb-border);
    font-weight: 700;
  }

  .jb-table tbody td {
    padding: var(--jb-space-4);
    border-bottom: 1px solid color-mix(in srgb, var(--jb-border) 70%, transparent);
    vertical-align: middle;
  }

  .jb-table tbody tr:last-child td {
    border-bottom: 0;
  }

  .jb-table tbody tr:hover {
    background: var(--jb-surface-soft);
  }

  /* Ticket conversation thread */
  .jb-ticket-thread {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: var(--jb-space-4);
  }

  .jb-ticket-message {
    border-radius: var(--jb-radius-md);
    border: 1px solid var(--jb-border);
    padding: var(--jb-space-5);
    background: var(--jb-surface);
    box-shadow: var(--jb-shadow-soft);
  }

  .jb-ticket-message--staff {
    background: color-mix(in srgb, var(--jb-primary) 4%, var(--jb-surface));
    border-color: color-mix(in srgb, var(--jb-primary) 18%, var(--jb-border));
  }

  .jb-ticket-message--note {
    background: color-mix(in srgb, #f59e0b 8%, var(--jb-surface));
    border-color: color-mix(in srgb, #f59e0b 28%, var(--jb-border));
    border-style: dashed;
  }

  .jb-ticket-message header {
    margin-bottom: var(--jb-space-3);
  }

  .jb-ticket-message header time {
    font-size: 0.85rem;
  }

  .jb-ticket-message__body {
    color: var(--jb-text);
    line-height: 1.65;
    white-space: pre-wrap;
    word-wrap: break-word;
  }

  .jb-ticket-message__attachments {
    list-style: none;
    padding: 0;
    margin: var(--jb-space-4) 0 0;
    display: flex;
    flex-wrap: wrap;
    gap: var(--jb-space-2);
  }

  .jb-ticket-message__attachments li a {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 6px 12px;
    border-radius: var(--jb-radius-sm);
    background: var(--jb-surface-soft);
    border: 1px solid var(--jb-border);
    color: var(--jb-text);
    text-decoration: none;
    font-size: 0.88rem;
  }

  .jb-ticket-message__attachments li a:hover {
    border-color: color-mix(in srgb, var(--jb-primary) 30%, var(--jb-border));
  }

  /* Activity log (sidebar) */
  .jb-activity-log {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: var(--jb-space-3);
  }

  .jb-activity-log li {
    display: flex;
    flex-direction: column;
    gap: 2px;
    padding: var(--jb-space-3);
    border-radius: var(--jb-radius-sm);
    background: var(--jb-surface-soft);
    font-size: 0.88rem;
    line-height: 1.4;
    border-left: 3px solid color-mix(in srgb, var(--jb-primary) 30%, var(--jb-border));
  }

  .jb-activity-log li strong {
    color: var(--jb-text);
    font-size: 0.85rem;
  }

  .jb-activity-log li time {
    font-size: 0.78rem;
    color: var(--jb-text-muted);
  }

  /* Page-level container for tickets show */
  .jb-tickets-page .jb-job-hero__grid {
    display: grid;
    grid-template-columns: minmax(0, 2fr) minmax(0, 1fr);
    gap: var(--jb-space-grid);
    align-items: start;
  }

  @media (max-width: 1024px) {
    .jb-tickets-page .jb-job-hero__grid {
      grid-template-columns: 1fr;
    }
  }

  /* ============================================================
     Ticket show — modern helpdesk layout
     ============================================================ */
  .jb-ticket-show {
    display: flex;
    flex-direction: column;
    gap: var(--jb-space-grid);
    margin-top: var(--jb-space-grid);
  }

  /* Hero */
  .jb-ticket-hero {
    position: relative;
    padding: clamp(28px, 3vw, 44px);
    border-radius: var(--jb-radius-lg);
    background:
      radial-gradient(circle at top right, color-mix(in srgb, var(--jb-primary) 14%, transparent), transparent 55%),
      linear-gradient(180deg, color-mix(in srgb, var(--jb-primary) 4%, var(--jb-surface)), var(--jb-surface) 60%);
    border: 1px solid var(--jb-border);
    box-shadow: var(--jb-shadow);
    overflow: hidden;
  }

  .jb-ticket-hero::after {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(120deg, transparent 60%, color-mix(in srgb, var(--jb-primary) 6%, transparent));
    pointer-events: none;
  }

  .jb-ticket-hero > * { position: relative; z-index: 1; }

  .jb-ticket-hero__top {
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-wrap: wrap;
    gap: var(--jb-space-4);
  }

  .jb-ticket-hero__ref {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 8px 16px;
    border-radius: var(--jb-radius-pill);
    background: var(--jb-surface);
    border: 1px solid var(--jb-border);
    font-weight: 700;
    font-size: 0.82rem;
    letter-spacing: 0.08em;
    color: var(--jb-text);
    box-shadow: var(--jb-shadow-soft);
  }

  .jb-ticket-hero__ref .material-symbols-rounded {
    font-size: 18px;
    color: var(--jb-primary);
  }

  .jb-ticket-hero__pills {
    display: inline-flex;
    align-items: center;
    gap: var(--jb-space-2);
    flex-wrap: wrap;
  }

  .jb-ticket-hero__title {
    margin: var(--jb-space-6) 0 0;
    font-size: clamp(1.55rem, 2.4vw, 2.15rem);
    line-height: 1.15;
    letter-spacing: -0.025em;
    font-weight: 800;
    color: var(--jb-text);
  }

  .jb-ticket-hero__meta {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: var(--jb-space-2) var(--jb-space-6);
    margin-top: var(--jb-space-4);
    color: var(--jb-text-muted);
    font-size: 0.92rem;
  }

  .jb-ticket-hero__meta-item {
    display: inline-flex;
    align-items: center;
    gap: 6px;
  }

  .jb-ticket-hero__meta-item .material-symbols-rounded {
    font-size: 18px;
    color: var(--jb-primary);
    opacity: 0.85;
  }

  /* Two-column layout */
  .jb-ticket-grid {
    display: grid;
    grid-template-columns: minmax(0, 1.75fr) minmax(0, 1fr);
    gap: var(--jb-space-grid);
    align-items: start;
  }

  .jb-ticket-grid > * {
    display: flex;
    flex-direction: column;
    gap: var(--jb-space-grid);
    min-width: 0;
  }

  @media (max-width: 1024px) {
    .jb-ticket-grid {
      grid-template-columns: 1fr;
    }
  }

  /* Generic card */
  .jb-ticket-card {
    position: relative;
    padding: clamp(22px, 2.2vw, 32px);
    border-radius: var(--jb-radius-lg);
    background: var(--jb-surface);
    border: 1px solid var(--jb-border);
    box-shadow: var(--jb-shadow-soft);
    transition: transform 0.35s ease, box-shadow 0.35s ease, border-color 0.35s ease;
  }

  .jb-ticket-card:hover {
    box-shadow: var(--jb-shadow);
  }

  .jb-ticket-card--reply {
    background:
      radial-gradient(circle at top right, color-mix(in srgb, var(--jb-primary) 8%, transparent), transparent 60%),
      var(--jb-surface);
    border-color: color-mix(in srgb, var(--jb-primary) 18%, var(--jb-border));
  }

  .jb-ticket-card__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: var(--jb-space-3);
    margin-bottom: var(--jb-space-5);
  }

  .jb-ticket-card__title {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    margin: 0;
    font-size: 0.78rem;
    font-weight: 700;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--jb-text-muted);
  }

  .jb-ticket-card__title::before {
    content: "";
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: var(--jb-primary);
    box-shadow: 0 0 0 4px color-mix(in srgb, var(--jb-primary) 18%, transparent);
  }

  .jb-ticket-card__count {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 28px;
    height: 24px;
    padding: 0 8px;
    border-radius: var(--jb-radius-pill);
    background: color-mix(in srgb, var(--jb-primary) 10%, var(--jb-surface));
    color: var(--jb-primary);
    font-size: 0.78rem;
    font-weight: 700;
  }

  /* Initial request — field grid */
  .jb-ticket-fields {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--jb-space-3);
  }

  @media (min-width: 640px) {
    .jb-ticket-fields {
      grid-template-columns: 1fr 1fr;
    }
  }

  .jb-ticket-field {
    padding: var(--jb-space-4) var(--jb-space-5);
    border-radius: var(--jb-radius-md);
    background: var(--jb-surface-soft);
    border: 1px solid var(--jb-border);
    transition: border-color 0.2s ease, transform 0.2s ease;
  }

  .jb-ticket-field:hover {
    border-color: color-mix(in srgb, var(--jb-primary) 24%, var(--jb-border));
    transform: translateY(-1px);
  }

  .jb-ticket-field__label {
    display: block;
    font-size: 0.7rem;
    font-weight: 700;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--jb-text-muted);
    margin-bottom: 6px;
  }

  .jb-ticket-field__value {
    display: block;
    font-weight: 600;
    color: var(--jb-text);
    word-break: break-word;
    line-height: 1.5;
  }

  /* Form-answer rendering — images inline + file chips */
  .jb-ticket-answer-image {
    display: inline-block;
    max-width: 100%;
    border-radius: var(--jb-radius-sm);
    overflow: hidden;
    border: 1px solid var(--jb-border);
    background: var(--jb-surface-soft);
    transition: transform 0.2s ease, border-color 0.2s ease;
  }

  .jb-ticket-answer-image:hover {
    transform: translateY(-1px);
    border-color: color-mix(in srgb, var(--jb-primary) 30%, var(--jb-border));
  }

  .jb-ticket-answer-image img {
    display: block;
    max-width: 100%;
    max-height: 260px;
    width: auto;
    height: auto;
    object-fit: contain;
  }

  .jb-ticket-answer-file {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 8px 14px;
    border-radius: var(--jb-radius-pill);
    background: var(--jb-surface-soft);
    border: 1px solid var(--jb-border);
    color: var(--jb-text);
    text-decoration: none;
    font-weight: 600;
    font-size: 0.88rem;
    transition: border-color 0.2s ease, transform 0.2s ease;
    max-width: 100%;
  }

  .jb-ticket-answer-file:hover {
    border-color: color-mix(in srgb, var(--jb-primary) 32%, var(--jb-border));
    transform: translateY(-1px);
  }

  .jb-ticket-answer-file .material-symbols-rounded {
    font-size: 18px;
    color: var(--jb-primary);
    flex-shrink: 0;
  }

  .jb-ticket-answer-file__name {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    min-width: 0;
  }

  .jb-ticket-answer-file__size {
    color: var(--jb-text-muted);
    font-weight: 500;
  }

  .jb-ticket-answer-files {
    display: flex;
    flex-wrap: wrap;
    gap: var(--jb-space-2);
  }

  /* Conversation — bubbles */
  .jb-ticket-conversation {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: var(--jb-space-6);
  }

  .jb-ticket-bubble {
    display: grid;
    grid-template-columns: 44px 1fr;
    gap: var(--jb-space-4);
    align-items: flex-start;
  }

  .jb-ticket-bubble__avatar {
    width: 44px;
    height: 44px;
    border-radius: 50%;
    background: linear-gradient(135deg,
        color-mix(in srgb, var(--jb-primary) 18%, var(--jb-surface)),
        color-mix(in srgb, var(--jb-primary) 5%, var(--jb-surface)));
    border: 1px solid color-mix(in srgb, var(--jb-primary) 18%, var(--jb-border));
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 700;
    font-size: 0.95rem;
    color: var(--jb-primary);
    flex-shrink: 0;
  }

  .jb-ticket-bubble--staff .jb-ticket-bubble__avatar {
    background: linear-gradient(135deg, var(--jb-primary), var(--jb-primary-dark));
    color: #fff;
    border-color: transparent;
    box-shadow: 0 6px 18px color-mix(in srgb, var(--jb-primary) 28%, transparent);
  }

  .jb-ticket-bubble--note .jb-ticket-bubble__avatar {
    background: linear-gradient(135deg, #fbbf24, #f59e0b);
    color: #fff;
    border-color: transparent;
  }

  .jb-ticket-bubble__content {
    position: relative;
    padding: var(--jb-space-5);
    border-radius: var(--jb-radius-md);
    background: var(--jb-surface-soft);
    border: 1px solid var(--jb-border);
    min-width: 0;
  }

  .jb-ticket-bubble--staff .jb-ticket-bubble__content {
    background: color-mix(in srgb, var(--jb-primary) 5%, var(--jb-surface));
    border-color: color-mix(in srgb, var(--jb-primary) 22%, var(--jb-border));
  }

  .jb-ticket-bubble--note .jb-ticket-bubble__content {
    background: color-mix(in srgb, #f59e0b 9%, var(--jb-surface));
    border: 1px dashed color-mix(in srgb, #f59e0b 38%, var(--jb-border));
  }

  .jb-ticket-bubble__header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-wrap: wrap;
    gap: var(--jb-space-3);
    margin-bottom: var(--jb-space-3);
  }

  .jb-ticket-bubble__author {
    display: inline-flex;
    align-items: baseline;
    gap: 8px;
    flex-wrap: wrap;
    min-width: 0;
  }

  .jb-ticket-bubble__name {
    font-weight: 700;
    color: var(--jb-text);
  }

  .jb-ticket-bubble__company {
    font-size: 0.82rem;
    color: var(--jb-text-muted);
  }

  .jb-ticket-bubble__badge {
    display: inline-flex;
    align-items: center;
    padding: 3px 10px;
    border-radius: var(--jb-radius-pill);
    background: color-mix(in srgb, #f59e0b 16%, var(--jb-surface));
    border: 1px solid color-mix(in srgb, #f59e0b 34%, var(--jb-border));
    color: #b45309;
    font-size: 0.68rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
  }

  .jb-ticket-bubble__time {
    font-size: 0.82rem;
    color: var(--jb-text-muted);
    white-space: nowrap;
  }

  .jb-ticket-bubble__body {
    color: var(--jb-text);
    line-height: 1.7;
    white-space: pre-wrap;
    word-wrap: break-word;
  }

  .jb-ticket-bubble__attachments {
    list-style: none;
    padding: 0;
    margin: var(--jb-space-4) 0 0;
    display: flex;
    flex-wrap: wrap;
    gap: var(--jb-space-2);
  }

  .jb-ticket-bubble__attachments a {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 6px 12px;
    border-radius: var(--jb-radius-sm);
    background: var(--jb-surface);
    border: 1px solid var(--jb-border);
    color: var(--jb-text);
    text-decoration: none;
    font-size: 0.86rem;
    transition: border-color 0.2s ease, transform 0.2s ease;
  }

  .jb-ticket-bubble__attachments a:hover {
    border-color: color-mix(in srgb, var(--jb-primary) 36%, var(--jb-border));
    transform: translateY(-1px);
  }

  .jb-ticket-bubble__attachments .material-symbols-rounded {
    font-size: 16px;
    color: var(--jb-primary);
  }

  /* Empty states */
  .jb-ticket-empty {
    margin: 0;
    padding: var(--jb-space-6);
    border-radius: var(--jb-radius-md);
    background: var(--jb-surface-soft);
    border: 1px dashed var(--jb-border);
    color: var(--jb-text-muted);
    text-align: center;
  }

  /* Reply editor */
  .jb-ticket-reply__editor {
    position: relative;
    border-radius: var(--jb-radius-md);
    border: 1px solid var(--jb-border);
    background: var(--jb-surface);
    transition: border-color 0.2s ease, box-shadow 0.25s ease;
    overflow: hidden;
  }

  .jb-ticket-reply__editor:focus-within {
    border-color: color-mix(in srgb, var(--jb-primary) 55%, var(--jb-border));
    box-shadow: 0 0 0 4px color-mix(in srgb, var(--jb-primary) 12%, transparent);
  }

  .jb-ticket-reply__textarea {
    width: 100%;
    min-height: 160px;
    padding: var(--jb-space-5);
    border: 0;
    background: transparent;
    resize: vertical;
    font: inherit;
    color: var(--jb-text);
    outline: none;
  }

  .jb-ticket-reply__toolbar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: var(--jb-space-3);
    padding: var(--jb-space-3) var(--jb-space-4);
    border-top: 1px solid var(--jb-border);
    background: var(--jb-surface-soft);
  }

  .jb-ticket-reply__file {
    position: relative;
    display: inline-flex;
    align-items: center;
    gap: 10px;
    cursor: pointer;
    margin: 0;
  }

  .jb-ticket-reply__file input[type="file"] {
    position: absolute;
    width: 1px;
    height: 1px;
    overflow: hidden;
    clip: rect(0 0 0 0);
    white-space: nowrap;
    border: 0;
  }

  .jb-ticket-reply__file-trigger {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 8px 14px;
    border-radius: var(--jb-radius-pill);
    background: var(--jb-surface);
    border: 1px solid var(--jb-border);
    font-weight: 600;
    font-size: 0.86rem;
    color: var(--jb-text);
    transition: border-color 0.2s ease, transform 0.2s ease;
  }

  .jb-ticket-reply__file:hover .jb-ticket-reply__file-trigger,
  .jb-ticket-reply__file:focus-within .jb-ticket-reply__file-trigger {
    border-color: color-mix(in srgb, var(--jb-primary) 38%, var(--jb-border));
    transform: translateY(-1px);
  }

  .jb-ticket-reply__file-trigger .material-symbols-rounded {
    font-size: 18px;
    color: var(--jb-primary);
  }

  .jb-ticket-reply__file-count {
    font-size: 0.82rem;
    color: var(--jb-text-muted);
    font-weight: 600;
  }

  .jb-ticket-reply__note {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    font-size: 0.88rem;
    color: var(--jb-text);
    cursor: pointer;
    user-select: none;
  }

  .jb-ticket-reply__submit {
    display: flex;
    justify-content: flex-end;
    margin-top: var(--jb-space-5);
  }

  /* Status actions */
  .jb-ticket-actions {
    display: flex;
    flex-wrap: wrap;
    gap: var(--jb-space-3);
  }

  .jb-ticket-actions form { margin: 0; }

  .jb-ticket-action-btn {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 10px 16px;
    border-radius: var(--jb-radius-pill);
    background: var(--jb-surface-soft);
    border: 1px solid var(--jb-border);
    color: var(--jb-text);
    font-weight: 600;
    font-size: 0.88rem;
    cursor: pointer;
    transition: transform 0.2s ease, border-color 0.2s ease, background 0.2s ease;
  }

  .jb-ticket-action-btn .material-symbols-rounded {
    font-size: 18px;
    color: var(--jb-primary);
  }

  .jb-ticket-action-btn:hover {
    transform: translateY(-1px);
    border-color: color-mix(in srgb, var(--jb-primary) 36%, var(--jb-border));
    background: var(--jb-surface);
  }

  /* Sidebar — requester */
  .jb-ticket-requester {
    display: flex;
    align-items: center;
    gap: var(--jb-space-4);
  }

  .jb-ticket-requester__avatar {
    width: 54px;
    height: 54px;
    border-radius: 50%;
    background: linear-gradient(135deg, var(--jb-primary), var(--jb-primary-dark));
    color: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 700;
    font-size: 1.15rem;
    flex-shrink: 0;
    box-shadow: 0 6px 18px color-mix(in srgb, var(--jb-primary) 30%, transparent);
  }

  .jb-ticket-requester__body {
    min-width: 0;
    flex: 1;
  }

  .jb-ticket-requester__name {
    display: block;
    font-weight: 700;
    font-size: 1.02rem;
    color: var(--jb-text);
    line-height: 1.25;
    word-break: break-word;
  }

  .jb-ticket-requester__detail {
    display: block;
    font-size: 0.86rem;
    color: var(--jb-text-muted);
    margin-top: 4px;
    word-break: break-word;
  }

  .jb-ticket-submitter {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    margin-top: 8px;
    font-size: 0.86rem;
    color: var(--jb-text-muted);
    flex-wrap: wrap;
  }

  .jb-ticket-detail .jb-ticket-submitter {
    margin-top: 0;
    color: inherit;
    font-size: inherit;
  }

  .jb-ticket-submitter__avatar {
    width: 24px;
    height: 24px;
    border-radius: 50%;
    background: linear-gradient(135deg,
        color-mix(in srgb, var(--jb-primary) 22%, var(--jb-surface)),
        color-mix(in srgb, var(--jb-primary) 8%, var(--jb-surface)));
    border: 1px solid color-mix(in srgb, var(--jb-primary) 22%, var(--jb-border));
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-weight: 700;
    font-size: 0.68rem;
    color: var(--jb-primary);
    flex-shrink: 0;
    overflow: hidden;
  }

  .jb-ticket-submitter__avatar img {
    width: 100%;
    height: 100%;
    object-fit: cover;
  }

  /* Sidebar — details */
  .jb-ticket-details {
    display: flex;
    flex-direction: column;
  }

  .jb-ticket-detail {
    display: flex;
    align-items: flex-start;
    gap: var(--jb-space-3);
    padding: var(--jb-space-4) 0;
    border-bottom: 1px solid var(--jb-border);
  }

  .jb-ticket-detail:first-child { padding-top: 0; }
  .jb-ticket-detail:last-child { border-bottom: 0; padding-bottom: 0; }

  .jb-ticket-detail__icon {
    width: 36px;
    height: 36px;
    border-radius: 10px;
    background: color-mix(in srgb, var(--jb-primary) 10%, var(--jb-surface));
    border: 1px solid color-mix(in srgb, var(--jb-primary) 18%, var(--jb-border));
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--jb-primary);
    flex-shrink: 0;
  }

  .jb-ticket-detail__icon .material-symbols-rounded { font-size: 20px; }

  .jb-ticket-detail__body {
    flex: 1;
    min-width: 0;
  }

  .jb-ticket-detail__label {
    display: block;
    font-size: 0.7rem;
    font-weight: 700;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--jb-text-muted);
    margin-bottom: 4px;
  }

  .jb-ticket-detail__value {
    display: block;
    font-weight: 600;
    color: var(--jb-text);
    word-break: break-word;
    line-height: 1.45;
  }

  .jb-ticket-detail__value + .jb-ticket-detail__value {
    margin-top: 4px;
  }

  .jb-ticket-detail__value--muted {
    color: var(--jb-text-muted);
    font-weight: 500;
  }

  .jb-ticket-detail__value--danger {
    color: var(--jb-primary);
  }

  /* Markdown rendering inside ticket messages */
  .jb-ticket-markdown > :first-child { margin-top: 0; }
  .jb-ticket-markdown > :last-child { margin-bottom: 0; }

  .jb-ticket-markdown p {
    margin: 0 0 var(--jb-space-3);
    line-height: 1.7;
  }

  .jb-ticket-markdown p:last-child { margin-bottom: 0; }

  .jb-ticket-markdown a {
    color: var(--jb-primary);
    text-decoration: underline;
    text-underline-offset: 2px;
  }

  .jb-ticket-markdown a:hover { text-decoration: none; }

  .jb-ticket-markdown strong { font-weight: 700; }
  .jb-ticket-markdown em { font-style: italic; }

  .jb-ticket-markdown ul,
  .jb-ticket-markdown ol {
    margin: 0 0 var(--jb-space-3);
    padding-left: 1.4em;
  }

  .jb-ticket-markdown li { margin: 2px 0; }

  .jb-ticket-markdown code {
    padding: 2px 6px;
    border-radius: 6px;
    background: var(--jb-surface-soft);
    border: 1px solid var(--jb-border);
    font-family: ui-monospace, SFMono-Regular, Menlo, monospace;
    font-size: 0.88em;
  }

  .jb-ticket-markdown pre {
    margin: 0 0 var(--jb-space-3);
    padding: var(--jb-space-4);
    border-radius: var(--jb-radius-sm);
    background: var(--jb-surface-soft);
    border: 1px solid var(--jb-border);
    overflow-x: auto;
  }

  .jb-ticket-markdown pre code {
    padding: 0;
    background: transparent;
    border: 0;
    font-size: 0.86em;
  }

  .jb-ticket-markdown blockquote {
    margin: 0 0 var(--jb-space-3);
    padding: var(--jb-space-3) var(--jb-space-4);
    border-left: 3px solid color-mix(in srgb, var(--jb-primary) 40%, var(--jb-border));
    background: var(--jb-surface-soft);
    border-radius: 0 var(--jb-radius-sm) var(--jb-radius-sm) 0;
    color: var(--jb-text-muted);
  }

  .jb-ticket-markdown h1,
  .jb-ticket-markdown h2,
  .jb-ticket-markdown h3,
  .jb-ticket-markdown h4 {
    margin: var(--jb-space-4) 0 var(--jb-space-2);
    font-weight: 700;
    line-height: 1.3;
  }

  .jb-ticket-markdown h1 { font-size: 1.35rem; }
  .jb-ticket-markdown h2 { font-size: 1.2rem; }
  .jb-ticket-markdown h3 { font-size: 1.05rem; }
  .jb-ticket-markdown h4 { font-size: 0.95rem; }

  /* ============================================================
     Knowledge Base — public pages
     ============================================================ */
  .jb-kb-hero {
    text-align: center;
    padding: clamp(28px, 4vw, 56px) clamp(16px, 3vw, 32px);
    border-radius: var(--jb-radius-lg);
    background:
      radial-gradient(circle at top, color-mix(in srgb, var(--jb-primary) 12%, transparent), transparent 60%),
      var(--jb-surface);
    border: 1px solid var(--jb-border);
    box-shadow: var(--jb-shadow-soft);
  }

  .jb-kb-hero__icon {
    font-size: 48px !important;
    color: var(--jb-primary);
  }

  .jb-kb-hero__title {
    margin: var(--jb-space-3) 0 var(--jb-space-2);
    font-size: clamp(1.8rem, 3.2vw, 2.6rem);
    font-weight: 800;
    letter-spacing: -0.02em;
    line-height: 1.15;
  }

  .jb-kb-hero__subtitle {
    margin: 0 auto;
    max-width: 60ch;
    color: var(--jb-text-muted);
    font-size: 1.05rem;
  }

  .jb-kb-section-title {
    margin: 0 0 var(--jb-space-4);
    font-size: 0.78rem;
    font-weight: 700;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--jb-text-muted);
    display: inline-flex;
    align-items: center;
    gap: 10px;
  }

  .jb-kb-section-title::before {
    content: "";
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: var(--jb-primary);
    box-shadow: 0 0 0 4px color-mix(in srgb, var(--jb-primary) 18%, transparent);
  }

  .jb-kb-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(324px, 1fr));
    gap: var(--jb-space-4);
  }

  .jb-kb-card {
    display: flex;
    flex-direction: column;
    gap: var(--jb-space-2);
    padding: var(--jb-space-12);
    border-radius: var(--jb-radius-md);
    background: var(--jb-surface);
    border: 1px solid var(--jb-border);
    box-shadow: var(--jb-shadow-soft);
    align-items: center;
    color: var(--jb-text);
    text-decoration: none;
    transition: transform 0.25s ease, box-shadow 0.25s ease, border-color 0.25s ease;
  }

  .jb-kb-card:hover {
    transform: translateY(-3px);
    border-color: color-mix(in srgb, var(--jb-kb-card-accent, var(--jb-primary)) 32%, var(--jb-border));
    box-shadow: var(--jb-shadow);
  }

  .jb-kb-card__icon {
    font-size: 124px !important;
    color: var(--jb-kb-card-accent, var(--jb-primary));
  }

  .jb-kb-card--featured .jb-kb-card__icon {
    color: #f59e0b;
  }

  .jb-kb-card__title {
    font-weight: 700;
    font-size: 2.05rem;
    color: var(--jb-text);
  }

  .jb-kb-card__excerpt {
    margin: 0;
    color: var(--jb-text-muted);
    font-size: 0.9rem;
    line-height: 1.5;
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
  }

  .jb-kb-card__meta {
    margin-top: auto;
    color: var(--jb-text-muted);
    font-size: 0.82rem;
    font-weight: 600;
  }

  .jb-kb-empty {
    margin: 0;
    padding: var(--jb-space-7);
    border-radius: var(--jb-radius-md);
    background: var(--jb-surface-soft);
    border: 1px dashed var(--jb-border);
    color: var(--jb-text-muted);
    text-align: center;
  }

  /* Category page — grid of subgroup blocks (auto-fits 1/2/3 cols by width) */
  .jb-kb-subgroup-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: clamp(20px, 2.6vw, 32px);
    align-items: start;
  }

  /* Category page — subgroup blocks (heading + articles list below) */
  .jb-kb-subgroup-block {
    min-width: 0;
  }

  .jb-kb-subgroup-block__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--jb-space-3);
    flex-wrap: wrap;
    margin-bottom: var(--jb-space-3);
  }

  .jb-kb-subgroup-block__header .jb-kb-section-title {
    margin: 0;
    text-transform: none;
    letter-spacing: -0.01em;
    font-size: 1.05rem;
    color: var(--jb-text);
  }

  .jb-kb-subgroup-block__icon {
    font-size: 22px !important;
    color: var(--jb-primary);
  }

  .jb-kb-subgroup-block__title {
    color: inherit;
    text-decoration: none;
  }

  .jb-kb-subgroup-block__title:hover {
    color: var(--jb-primary);
  }

  .jb-kb-subgroup-block__see-all {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    color: var(--jb-text-muted);
    text-decoration: none;
    font-size: 0.86rem;
    font-weight: 600;
    transition: color 0.2s ease, transform 0.2s ease;
  }

  .jb-kb-subgroup-block__see-all:hover {
    color: var(--jb-primary);
    transform: translateX(2px);
  }

  .jb-kb-subgroup-block__see-all .material-symbols-rounded {
    font-size: 18px;
  }

  .jb-kb-subgroup-block__description {
    margin: 0 0 var(--jb-space-3);
    color: var(--jb-text-muted);
    font-size: 0.94rem;
    line-height: 1.55;
  }

  /* Category page — subgroups (legacy card layout, kept for other usages) */
  .jb-kb-subgroup-list {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
    gap: var(--jb-space-5);
  }

  .jb-kb-subgroup {
    padding: var(--jb-space-6);
    border-radius: var(--jb-radius-md);
    background: var(--jb-surface);
    border: 1px solid var(--jb-border);
    box-shadow: var(--jb-shadow-soft);
  }

  .jb-kb-subgroup__header {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-bottom: var(--jb-space-3);
  }

  .jb-kb-subgroup__icon {
    font-size: 24px !important;
    color: var(--jb-primary);
  }

  .jb-kb-subgroup__title {
    font-weight: 700;
    color: var(--jb-text);
    text-decoration: none;
    font-size: 2.1rem;
  }

  .jb-kb-subgroup__title:hover {
    color: var(--jb-primary);
  }

  .jb-kb-subgroup__description {
    margin: 0 0 var(--jb-space-3);
    color: var(--jb-text-muted);
    font-size: 0.92rem;
  }

  .jb-kb-subgroup__articles {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: 4px;
  }

  .jb-kb-subgroup__articles a {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 6px 8px;
    border-radius: var(--jb-radius-sm);
    color: var(--jb-text);
    text-decoration: none;
    font-size: 0.92rem;
    transition: background 0.15s ease;
  }

  .jb-kb-subgroup__articles a:hover {
    background: var(--jb-surface-soft);
    color: var(--jb-primary);
  }

  .jb-kb-subgroup__articles .material-symbols-rounded {
    font-size: 18px;
    color: var(--jb-text-muted);
  }

  /* Subgroup page — flat article list */
  .jb-kb-article-list {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: var(--jb-space-2);
  }

  .jb-kb-article-list__item {
    display: flex;
    align-items: center;
    gap: var(--jb-space-3);
    padding: var(--jb-space-4) var(--jb-space-5);
    border-radius: var(--jb-radius-md);
    background: var(--jb-surface);
    border: 1px solid var(--jb-border);
    color: var(--jb-text);
    text-decoration: none;
    transition: transform 0.2s ease, border-color 0.2s ease, box-shadow 0.2s ease;
  }

  .jb-kb-article-list__item:hover {
    transform: translateX(2px);
    border-color: color-mix(in srgb, var(--jb-primary) 32%, var(--jb-border));
    box-shadow: var(--jb-shadow-soft);
  }

  .jb-kb-article-list__item > .material-symbols-rounded {
    font-size: 22px;
    color: var(--jb-primary);
    flex-shrink: 0;
  }

  .jb-kb-article-list__body {
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: 2px;
    min-width: 0;
  }

  .jb-kb-article-list__excerpt {
    color: var(--jb-text-muted);
    font-size: 0.88rem;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
  }

  .jb-kb-article-list__chevron {
    color: var(--jb-text-muted);
    flex-shrink: 0;
  }

  /* ============================================================
     Article page — Assan-inspired blog layout
     ============================================================ */
  /* .jb-kb-article-page main { background: var(--jb-surface); } */

  /* Hero — soft tinted band with 2-column grid */
  .jb-kb-article-hero {
    --jb-kb-hero-accent: var(--jb-primary);
    position: relative;
    padding: clamp(32px, 5vw, 72px) 0 clamp(48px, 7vw, 96px);
    background:
      radial-gradient(ellipse at top right, color-mix(in srgb, var(--jb-kb-hero-accent) 10%, transparent), transparent 55%),
      var(--jb-surface-soft);
    border-bottom: 1px solid var(--jb-border);
  }

  .jb-kb-article-hero__grid {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
    gap: clamp(24px, 4vw, 56px);
    align-items: center;
    margin-top: var(--jb-space-6);
  }

  @media (max-width: 860px) {
    .jb-kb-article-hero__grid {
      grid-template-columns: 1fr;
    }
  }

  .jb-kb-article-hero__illu {
    position: relative;
    aspect-ratio: 16 / 10;
    border-radius: var(--jb-radius-lg);
    background:
      radial-gradient(circle at 30% 20%, color-mix(in srgb, var(--jb-kb-hero-accent) 32%, transparent), transparent 55%),
      linear-gradient(135deg, color-mix(in srgb, var(--jb-kb-hero-accent) 14%, var(--jb-surface)), var(--jb-surface));
    border: 1px solid var(--jb-border);
    box-shadow: var(--jb-shadow);
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
  }

  .jb-kb-article-hero__illu::after {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(120deg, transparent 55%, color-mix(in srgb, var(--jb-kb-hero-accent) 6%, transparent));
    pointer-events: none;
  }

  .jb-kb-article-hero__icon {
    font-size: clamp(96px, 14vw, 180px) !important;
    color: var(--jb-kb-hero-accent);
    opacity: 0.92;
    filter: drop-shadow(0 12px 28px color-mix(in srgb, var(--jb-kb-hero-accent) 28%, transparent));
  }

  .jb-kb-article-hero__pills {
    display: flex;
    align-items: center;
    gap: var(--jb-space-3);
    flex-wrap: wrap;
    margin-bottom: var(--jb-space-4);
  }

  .jb-kb-article-hero__badge {
    --jb-kb-badge-accent: var(--jb-primary);
    display: inline-flex;
    align-items: center;
    padding: 6px 14px;
    border-radius: var(--jb-radius-pill);
    background: color-mix(in srgb, var(--jb-kb-badge-accent) 14%, var(--jb-surface));
    border: 1px solid color-mix(in srgb, var(--jb-kb-badge-accent) 30%, var(--jb-border));
    color: var(--jb-kb-badge-accent);
    text-decoration: none;
    font-weight: 700;
    font-size: 0.82rem;
    letter-spacing: 0.04em;
    transition: transform 0.2s ease, background 0.2s ease;
  }

  .jb-kb-article-hero__badge:hover {
    transform: translateY(-1px);
    background: color-mix(in srgb, var(--jb-kb-badge-accent) 22%, var(--jb-surface));
  }

  .jb-kb-article-hero__date {
    color: var(--jb-text-muted);
    font-size: 0.92rem;
  }

  .jb-kb-article-hero__title {
    margin: 0 0 var(--jb-space-4);
    font-size: clamp(1.9rem, 4vw, 3rem);
    font-weight: 800;
    line-height: 1.1;
    letter-spacing: -0.025em;
    text-wrap: balance;
    color: var(--jb-text);
  }

  .jb-kb-article-hero__lead {
    margin: 0 0 var(--jb-space-5);
    font-size: 1.1rem;
    line-height: 1.6;
    color: var(--jb-text-muted);
    max-width: 56ch;
  }

  .jb-kb-article-hero__author {
    display: inline-flex;
    align-items: center;
    gap: var(--jb-space-3);
    padding: var(--jb-space-2) var(--jb-space-4) var(--jb-space-2) var(--jb-space-2);
    border-radius: var(--jb-radius-pill);
    background: var(--jb-surface);
    border: 1px solid var(--jb-border);
    box-shadow: var(--jb-shadow-soft);
  }

  .jb-kb-article-hero__avatar {
    width: 42px;
    height: 42px;
    border-radius: 50%;
    background: linear-gradient(135deg, var(--jb-primary), var(--jb-primary-dark));
    color: #fff;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-weight: 700;
    font-size: 0.92rem;
    overflow: hidden;
    flex-shrink: 0;
  }

  .jb-kb-article-hero__avatar img {
    width: 100%;
    height: 100%;
    object-fit: cover;
  }

  .jb-kb-article-hero__author-text {
    display: flex;
    flex-direction: column;
    font-size: 0.94rem;
    line-height: 1.2;
  }

  .jb-kb-article-hero__author-label {
    color: var(--jb-text-muted);
    font-size: 0.74rem;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    font-weight: 700;
  }

  /* Body — narrow centered reading column with dropcap */
  .jb-kb-article-body-section {
    padding: clamp(40px, 6vw, 88px) 0;
  }

  .jb-kb-article-body {
    max-width: 720px;
    margin: 0 auto;
    font-size: 1.06rem;
    line-height: 1.78;
    color: var(--jb-text);
  }

  .jb-kb-article-body > p:first-of-type::first-letter {
    float: left;
    font-size: 4.4em;
    line-height: 0.86;
    padding: 6px 14px 0 0;
    font-weight: 800;
    color: var(--jb-primary);
    font-family: Georgia, "Times New Roman", serif;
  }

  /* Inline share row at end of body */
  .jb-kb-article-share {
    max-width: 720px;
    margin: var(--jb-space-9) auto 0;
    padding-top: var(--jb-space-5);
    border-top: 1px solid var(--jb-border);
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: var(--jb-space-3);
  }

  .jb-kb-article-share__label {
    font-size: 0.74rem;
    font-weight: 700;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--jb-text-muted);
  }

  .jb-kb-article-share__links {
    display: inline-flex;
    align-items: center;
    gap: var(--jb-space-2);
  }

  .jb-kb-share-btn {
    width: 40px;
    height: 40px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    background: var(--jb-surface-soft);
    border: 1px solid var(--jb-border);
    color: var(--jb-text);
    text-decoration: none;
    cursor: pointer;
    transition: transform 0.2s ease, border-color 0.2s ease, background 0.2s ease, color 0.2s ease, box-shadow 0.2s ease;
  }

  .jb-kb-share-btn:hover {
    transform: translateY(-2px);
    background: var(--jb-primary);
    border-color: var(--jb-primary);
    color: #fff;
    box-shadow: 0 8px 20px color-mix(in srgb, var(--jb-primary) 28%, transparent);
  }

  .jb-kb-share-btn.is-copied {
    background: #16a34a;
    border-color: #16a34a;
    color: #fff;
  }

  .jb-kb-share-btn .material-symbols-rounded {
    font-size: 20px;
  }

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

  /* Related articles strip */
  .jb-kb-article-related {
    background: var(--jb-surface-soft);
    padding: clamp(40px, 6vw, 88px) 0;
    border-top: 1px solid var(--jb-border);
  }

  .jb-kb-related-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
    gap: var(--jb-space-4);
    margin-top: var(--jb-space-5);
  }

  .jb-kb-related-card {
    --jb-kb-related-accent: var(--jb-primary);
    display: flex;
    align-items: center;
    gap: var(--jb-space-4);
    padding: var(--jb-space-4);
    border-radius: var(--jb-radius-md);
    background: var(--jb-surface);
    border: 1px solid var(--jb-border);
    text-decoration: none;
    color: var(--jb-text);
    transition: transform 0.25s ease, box-shadow 0.25s ease, border-color 0.25s ease;
    min-width: 0;
  }

  .jb-kb-related-card:hover {
    transform: translateY(-3px);
    border-color: color-mix(in srgb, var(--jb-kb-related-accent) 32%, var(--jb-border));
    box-shadow: var(--jb-shadow);
  }

  .jb-kb-related-card__thumb {
    width: 88px;
    height: 88px;
    flex-shrink: 0;
    border-radius: var(--jb-radius-sm);
    background:
      radial-gradient(circle at 30% 30%, color-mix(in srgb, var(--jb-kb-related-accent) 25%, transparent), transparent 60%),
      linear-gradient(135deg, color-mix(in srgb, var(--jb-kb-related-accent) 12%, var(--jb-surface)), var(--jb-surface));
    border: 1px solid var(--jb-border);
    display: flex;
    align-items: center;
    justify-content: center;
  }

  .jb-kb-related-card__thumb .material-symbols-rounded {
    font-size: 38px;
    color: var(--jb-kb-related-accent);
  }

  .jb-kb-related-card__body {
    display: flex;
    flex-direction: column;
    gap: 4px;
    min-width: 0;
    flex: 1;
  }

  .jb-kb-related-card__category {
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--jb-kb-related-accent);
  }

  .jb-kb-related-card__title {
    font-size: 1.02rem;
    font-weight: 700;
    line-height: 1.3;
    color: var(--jb-text);
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
  }

  .jb-kb-related-card__date {
    color: var(--jb-text-muted);
    font-size: 0.84rem;
  }

  /* Admin dashboard — KB */
  .jb-kb-stats {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
    gap: var(--jb-space-3);
  }

  .jb-kb-stat {
    display: flex;
    flex-direction: column;
    gap: 4px;
    padding: var(--jb-space-4) var(--jb-space-5);
    border-radius: var(--jb-radius-md);
    background: var(--jb-surface);
    border: 1px solid var(--jb-border);
    color: var(--jb-text);
    text-decoration: none;
    transition: transform 0.2s ease, border-color 0.2s ease, box-shadow 0.2s ease;
  }

  a.jb-kb-stat:hover {
    transform: translateY(-2px);
    border-color: color-mix(in srgb, var(--jb-primary) 28%, var(--jb-border));
    box-shadow: var(--jb-shadow-soft);
  }

  .jb-kb-stat > .material-symbols-rounded {
    font-size: 22px;
    color: var(--jb-primary);
  }

  .jb-kb-stat--success > .material-symbols-rounded { color: #16a34a; }
  .jb-kb-stat--warning > .material-symbols-rounded { color: #d97706; }
  .jb-kb-stat--muted   > .material-symbols-rounded { color: var(--jb-text-muted); }

  .jb-kb-stat__value {
    font-size: 1.6rem;
    font-weight: 800;
    line-height: 1.1;
    letter-spacing: -0.02em;
  }

  .jb-kb-stat__label {
    font-size: 0.78rem;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: var(--jb-text-muted);
    font-weight: 700;
  }

  .jb-kb-dashboard-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(380px, 1fr));
    gap: var(--jb-space-4);
  }

  .jb-kb-list {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: var(--jb-space-2);
  }

  .jb-kb-list__item {
    padding: var(--jb-space-3) var(--jb-space-4);
    border-radius: var(--jb-radius-sm);
    border: 1px solid var(--jb-border);
    background: var(--jb-surface-soft);
    transition: border-color 0.2s ease, transform 0.2s ease;
  }

  .jb-kb-list__item:hover {
    border-color: color-mix(in srgb, var(--jb-primary) 28%, var(--jb-border));
    transform: translateX(2px);
  }

  .jb-kb-list__title {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    color: var(--jb-text);
    text-decoration: none;
    font-weight: 700;
    line-height: 1.3;
  }

  .jb-kb-list__title:hover {
    color: var(--jb-primary);
  }

  .jb-kb-list__title .material-symbols-rounded {
    font-size: 18px;
    color: var(--jb-primary);
  }

  .jb-kb-list__meta {
    margin-top: 4px;
    display: flex;
    flex-wrap: wrap;
    gap: 4px 8px;
    color: var(--jb-text-muted);
    font-size: 0.84rem;
  }

  /* GSAP entry initial states */
  html.js [data-ticket-animate] {
    opacity: 0;
    transform: translateY(20px);
    will-change: transform, opacity;
  }

  html.js [data-ticket-bubble] {
    opacity: 0;
    transform: translateY(14px);
    will-change: transform, opacity;
  }

  @media (prefers-reduced-motion: reduce) {
    html.js [data-ticket-animate],
    html.js [data-ticket-bubble] {
      opacity: 1;
      transform: none;
    }
  }

  /* ============================================================
     Assistance hub — immersive landing with GSAP + Three.js
     ============================================================ */
  .jb-assistance-hub main { background: var(--jb-surface-alt); }

  /* Custom cursor takes over on this page only */
  html.jb-assistance-cursor-on body,
  html.jb-assistance-cursor-on a,
  html.jb-assistance-cursor-on button,
  html.jb-assistance-cursor-on [data-assistance-card] { cursor: none; }

  .jb-assistance-cursor {
    position: fixed;
    inset: 0;
    pointer-events: none;
    z-index: 9999;
  }

  .jb-assistance-cursor.is-out { opacity: 0; }
  .jb-assistance-cursor { transition: opacity 0.2s ease; }

  .jb-assistance-cursor__dot,
  .jb-assistance-cursor__ring {
    position: absolute;
    top: 0;
    left: 0;
    will-change: transform;
  }

  .jb-assistance-cursor__dot {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: var(--jb-primary);
    box-shadow: 0 0 12px color-mix(in srgb, var(--jb-primary) 60%, transparent);
    transition: width 0.25s ease, height 0.25s ease, background 0.25s ease;
  }

  .jb-assistance-cursor__ring {
    width: 38px;
    height: 38px;
    border-radius: 50%;
    border: 1.5px solid color-mix(in srgb, var(--jb-primary) 55%, transparent);
    transition: width 0.3s ease, height 0.3s ease, border-color 0.3s ease, opacity 0.3s ease, transform 0.05s linear;
  }

  .jb-assistance-cursor.is-hover .jb-assistance-cursor__dot {
    width: 4px;
    height: 4px;
    background: #fff;
  }

  .jb-assistance-cursor.is-hover .jb-assistance-cursor__ring {
    width: 64px;
    height: 64px;
    border-color: var(--jb-primary);
    border-width: 2px;
    background: color-mix(in srgb, var(--jb-primary) 8%, transparent);
  }

  .jb-assistance-cursor.is-press .jb-assistance-cursor__ring {
    width: 28px;
    height: 28px;
  }

  .jb-assistance-hero {
    position: relative;
    padding: clamp(72px, 10vw, 140px) 0 clamp(80px, 12vw, 160px);
    overflow: hidden;
    isolation: isolate;
    background: var(--jb-surface-alt);
  }

  /* Smooth fade from the (darker) topbar surface-alt into the hero body */
  .jb-assistance-hero::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 220px;
    background: linear-gradient(180deg, var(--jb-surface-alt), transparent);
    pointer-events: none;
    z-index: 1;
  }

  /* Soft fade on the way out so the next section blends back to surface-alt */
  .jb-assistance-hero::after {
    content: "";
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    height: 200px;
    background: linear-gradient(0deg, var(--jb-surface-alt), transparent);
    pointer-events: none;
    z-index: 1;
  }

  /* Three.js canvas — sits behind everything inside the hero */
  .jb-assistance-canvas {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    z-index: 0;
    pointer-events: none;
    opacity: 0.85;
  }

  .jb-assistance-bg {
    position: absolute;
    inset: 0;
    pointer-events: none;
    z-index: 1;
    overflow: hidden;
    mix-blend-mode: screen;
  }

  [data-theme='dark'] .jb-assistance-bg { mix-blend-mode: lighten; }

  .jb-assistance-blob {
    position: absolute;
    border-radius: 50%;
    filter: blur(70px);
    will-change: transform;
  }

  .jb-assistance-blob--1 {
    width: 420px;
    height: 420px;
    background: radial-gradient(circle, var(--jb-primary), transparent 70%);
    top: -120px;
    left: 8%;
    opacity: 0.38;
  }

  .jb-assistance-blob--2 {
    width: 520px;
    height: 520px;
    background: radial-gradient(circle, #f59e0b, transparent 70%);
    top: 28%;
    right: -140px;
    opacity: 0.22;
  }

  .jb-assistance-blob--3 {
    width: 340px;
    height: 340px;
    background: radial-gradient(circle, #7c3aed, transparent 70%);
    bottom: -80px;
    left: 26%;
    opacity: 0.26;
  }

  .jb-assistance-grid {
    position: absolute;
    inset: 0;
    background-image:
      linear-gradient(to right, color-mix(in srgb, var(--jb-text) 5%, transparent) 1px, transparent 1px),
      linear-gradient(to bottom, color-mix(in srgb, var(--jb-text) 5%, transparent) 1px, transparent 1px);
    background-size: 56px 56px;
    mask-image: radial-gradient(ellipse at center, #000 0%, #000 50%, transparent 80%);
    -webkit-mask-image: radial-gradient(ellipse at center, #000 0%, #000 50%, transparent 80%);
    opacity: 0.5;
  }

  .jb-assistance-hero__inner {
    position: relative;
    z-index: 2;
    text-align: center;
  }

  .jb-assistance-word {
    display: inline-block;
    white-space: nowrap;
    margin: 0 0.06em;
  }

  .jb-assistance-char {
    display: inline-block;
    will-change: transform, opacity, color;
  }

  .jb-assistance-hero__eyebrow {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    padding: 8px 18px;
    border-radius: var(--jb-radius-pill);
    background: var(--jb-surface);
    border: 1px solid var(--jb-border);
    font-size: 0.82rem;
    font-weight: 700;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--jb-text);
    box-shadow: var(--jb-shadow-soft);
  }

  .jb-assistance-hero__eyebrow-dot {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: var(--jb-primary);
    box-shadow: 0 0 0 4px color-mix(in srgb, var(--jb-primary) 20%, transparent);
    animation: jb-assistance-pulse 2.2s ease-in-out infinite;
  }

  @keyframes jb-assistance-pulse {
    0%, 100% { box-shadow: 0 0 0 4px color-mix(in srgb, var(--jb-primary) 20%, transparent); }
    50%      { box-shadow: 0 0 0 10px color-mix(in srgb, var(--jb-primary) 4%, transparent); }
  }

  .jb-assistance-hero__title {
    margin: var(--jb-space-5) 0 var(--jb-space-4);
    font-size: clamp(2.4rem, 7vw, 5rem);
    font-weight: 900;
    line-height: 1.02;
    letter-spacing: -0.035em;
    color: var(--jb-text);
    text-shadow:
      0 4px 20px color-mix(in srgb, var(--jb-text) 18%, transparent),
      0 18px 60px color-mix(in srgb, var(--jb-primary) 18%, transparent);
  }

  .jb-assistance-char {
    display: inline-block;
    will-change: transform, opacity;
  }

  .jb-assistance-hero__subtitle {
    margin: 0 auto;
    max-width: 60ch;
    font-size: clamp(1.05rem, 1.7vw, 1.25rem);
    color: var(--jb-text-muted);
    line-height: 1.6;
  }

  /* Choices grid — 2 big cards */
  .jb-assistance-choices {
    display: grid;
    grid-template-columns: 1fr;
    gap: clamp(20px, 3vw, 32px);
    max-width: 1100px;
    margin: clamp(48px, 7vw, 96px) auto 0;
  }

  @media (min-width: 768px) {
    .jb-assistance-choices {
      grid-template-columns: repeat(2, minmax(0, 1fr));
    }
  }

  .jb-assistance-card {
    --jb-card-accent: var(--jb-primary);
    position: relative;
    display: flex;
    flex-direction: column;
    gap: var(--jb-space-3);
    padding: clamp(28px, 4vw, 48px);
    border-radius: var(--jb-radius-lg);
    background: var(--jb-surface);
    border: 1px solid var(--jb-border);
    box-shadow: var(--jb-shadow-soft);
    text-decoration: none;
    color: var(--jb-text);
    text-align: left;
    overflow: hidden;
    transform-style: preserve-3d;
    transition: box-shadow 0.4s ease, border-color 0.4s ease;
    isolation: isolate;
  }

  .jb-assistance-card:hover {
    box-shadow: 0 28px 60px color-mix(in srgb, var(--jb-card-accent) 22%, transparent), var(--jb-shadow-soft);
    border-color: color-mix(in srgb, var(--jb-card-accent) 36%, var(--jb-border));
  }

  .jb-assistance-card__glow {
    position: absolute;
    inset: -1px;
    border-radius: inherit;
    background: radial-gradient(circle at var(--glow-x, 50%) var(--glow-y, 50%),
        color-mix(in srgb, var(--jb-card-accent) 36%, transparent),
        transparent 55%);
    opacity: 0;
    transition: opacity 0.3s ease;
    pointer-events: none;
    z-index: 0;
  }

  /* Animated rotating gradient ring around the card */
  .jb-assistance-card__ribbon {
    position: absolute;
    inset: -2px;
    border-radius: inherit;
    background: conic-gradient(
        from 0deg,
        transparent 0deg,
        color-mix(in srgb, var(--jb-card-accent) 75%, transparent) 60deg,
        transparent 140deg,
        color-mix(in srgb, var(--jb-card-accent) 45%, transparent) 220deg,
        transparent 300deg,
        transparent 360deg);
    opacity: 0;
    z-index: 0;
    pointer-events: none;
    -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
            mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
    -webkit-mask-composite: xor;
            mask-composite: exclude;
    padding: 1.5px;
    transition: opacity 0.45s ease;
    animation: jb-assistance-ribbon-spin 6s linear infinite;
  }

  .jb-assistance-card:hover .jb-assistance-card__ribbon {
    opacity: 1;
  }

  @keyframes jb-assistance-ribbon-spin {
    to { transform: rotate(360deg); }
  }

  .jb-assistance-card > *:not(.jb-assistance-card__glow):not(.jb-assistance-card__ribbon) {
    position: relative;
    z-index: 1;
  }

  /* Inner wrapper that parallaxes opposite to the card tilt */
  .jb-assistance-card__inner {
    display: flex;
    flex-direction: column;
    gap: var(--jb-space-3);
    will-change: transform;
    transform: translateZ(40px);
  }

  .jb-assistance-card--kb { --jb-card-accent: #7c3aed; }
  .jb-assistance-card--tickets { --jb-card-accent: var(--jb-primary); }

  .jb-assistance-card__badge {
    position: absolute;
    top: clamp(20px, 2.5vw, 28px);
    right: clamp(20px, 2.5vw, 28px);
    padding: 5px 12px;
    border-radius: var(--jb-radius-pill);
    background: color-mix(in srgb, var(--jb-card-accent) 14%, var(--jb-surface));
    border: 1px solid color-mix(in srgb, var(--jb-card-accent) 26%, var(--jb-border));
    color: var(--jb-card-accent);
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.06em;
    z-index: 2;
  }

  .jb-assistance-card__icon {
    width: 68px;
    height: 68px;
    border-radius: var(--jb-radius-md);
    background: linear-gradient(135deg,
        color-mix(in srgb, var(--jb-card-accent) 22%, var(--jb-surface)),
        color-mix(in srgb, var(--jb-card-accent) 6%, var(--jb-surface)));
    border: 1px solid color-mix(in srgb, var(--jb-card-accent) 28%, var(--jb-border));
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--jb-card-accent);
    box-shadow: 0 10px 28px color-mix(in srgb, var(--jb-card-accent) 25%, transparent);
    margin-bottom: var(--jb-space-2);
  }

  .jb-assistance-card__icon .material-symbols-rounded {
    font-size: 34px;
  }

  .jb-assistance-card__eyebrow {
    font-size: 0.74rem;
    font-weight: 700;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--jb-card-accent);
  }

  .jb-assistance-card__title {
    margin: 0;
    font-size: clamp(1.4rem, 2.4vw, 1.8rem);
    font-weight: 800;
    letter-spacing: -0.02em;
    line-height: 1.15;
    color: var(--jb-text);
  }

  .jb-assistance-card__description {
    margin: 0;
    color: var(--jb-text-muted);
    line-height: 1.6;
    font-size: 1rem;
  }

  .jb-assistance-card__cta {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    margin-top: var(--jb-space-3);
    color: var(--jb-card-accent);
    font-weight: 700;
    transition: gap 0.25s ease;
    align-self: flex-start;
  }

  .jb-assistance-card:hover .jb-assistance-card__cta {
    gap: 14px;
  }

  .jb-assistance-card__cta .material-symbols-rounded {
    font-size: 20px;
  }

  /* Stats strip */
  .jb-assistance-stats {
    display: flex;
    justify-content: center;
    align-items: flex-start;
    flex-wrap: wrap;
    gap: clamp(28px, 5vw, 80px);
    margin: clamp(56px, 8vw, 96px) auto 0;
    padding-top: clamp(32px, 4vw, 48px);
    border-top: 1px solid var(--jb-border);
    max-width: 860px;
  }

  .jb-assistance-stat {
    text-align: center;
    will-change: transform, opacity;
  }

  .jb-assistance-stat__value {
    display: block;
    font-size: clamp(2rem, 4.2vw, 3rem);
    font-weight: 900;
    letter-spacing: -0.025em;
    background: linear-gradient(135deg, var(--jb-primary), var(--jb-primary-dark));
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
    line-height: 1;
  }

  .jb-assistance-stat__label {
    display: block;
    margin-top: 8px;
    font-size: 0.84rem;
    color: var(--jb-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.1em;
    font-weight: 700;
  }

  @media (prefers-reduced-motion: reduce) {
    .jb-assistance-blob,
    .jb-assistance-hero__eyebrow-dot { animation: none !important; }
  }
}

/* Dark mode tuning */
[data-theme='dark'] .jb-status--pending  { color: #fbbf24; }
[data-theme='dark'] .jb-status--resolved { color: #34d399; }
[data-theme='dark'] .jb-status--closed   { color: #94a3b8; }
[data-theme='dark'] .jb-status--on_hold  { color: #cbd5e1; }
[data-theme='dark'] .jb-priority--high   { color: #fb923c; }
[data-theme='dark'] .jb-priority--urgent { color: #f87171; }
[data-theme='dark'] .jb-alert--warning   { color: #fbbf24; }
[data-theme='dark'] .jb-text-danger      { color: #f87171 !important; }
[data-theme='dark'] .jb-ticket-message__attachments li a {
  background: rgba(255, 255, 255, 0.04);
}
