/*! tailwindcss v4.3.0 | MIT License | https://tailwindcss.com */
@layer properties;
@layer theme, base, components, utilities;
@layer theme {
  :root, :host {
    --font-sans: "Inter Variable", "Inter", system-ui, -apple-system, sans-serif;
    --font-mono: "JetBrains Mono", "Fira Code", monospace;
    --color-red-50: oklch(97.1% 0.013 17.38);
    --color-red-100: oklch(93.6% 0.032 17.717);
    --color-red-200: oklch(88.5% 0.062 18.334);
    --color-red-500: oklch(63.7% 0.237 25.331);
    --color-red-600: oklch(57.7% 0.245 27.325);
    --color-red-700: oklch(50.5% 0.213 27.518);
    --color-red-800: oklch(44.4% 0.177 26.899);
    --color-yellow-50: oklch(98.7% 0.026 102.212);
    --color-yellow-100: oklch(97.3% 0.071 103.193);
    --color-yellow-200: oklch(94.5% 0.129 101.54);
    --color-yellow-600: oklch(68.1% 0.162 75.834);
    --color-yellow-800: oklch(47.6% 0.114 61.907);
    --color-green-50: oklch(98.2% 0.018 155.826);
    --color-green-100: oklch(96.2% 0.044 156.743);
    --color-green-200: oklch(92.5% 0.084 155.995);
    --color-green-500: oklch(72.3% 0.219 149.579);
    --color-green-600: oklch(62.7% 0.194 149.214);
    --color-green-700: oklch(52.7% 0.154 150.069);
    --color-green-800: oklch(44.8% 0.119 151.328);
    --color-blue-50: oklch(97% 0.014 254.604);
    --color-blue-100: oklch(93.2% 0.032 255.585);
    --color-blue-200: oklch(88.2% 0.059 254.128);
    --color-blue-400: oklch(70.7% 0.165 254.624);
    --color-blue-500: oklch(62.3% 0.214 259.815);
    --color-blue-600: oklch(54.6% 0.245 262.881);
    --color-blue-700: oklch(48.8% 0.243 264.376);
    --color-blue-800: oklch(42.4% 0.199 265.638);
    --color-slate-50: oklch(98.4% 0.003 247.858);
    --color-slate-100: oklch(96.8% 0.007 247.896);
    --color-slate-200: oklch(92.9% 0.013 255.508);
    --color-slate-400: oklch(70.4% 0.04 256.788);
    --color-slate-500: oklch(55.4% 0.046 257.417);
    --color-slate-800: oklch(27.9% 0.041 260.031);
    --color-slate-900: oklch(20.8% 0.042 265.755);
    --color-gray-50: oklch(98.5% 0.002 247.839);
    --color-gray-100: oklch(96.7% 0.003 264.542);
    --color-gray-200: oklch(92.8% 0.006 264.531);
    --color-gray-300: oklch(87.2% 0.01 258.338);
    --color-gray-400: oklch(70.7% 0.022 261.325);
    --color-gray-500: oklch(55.1% 0.027 264.364);
    --color-gray-600: oklch(44.6% 0.03 256.802);
    --color-gray-700: oklch(37.3% 0.034 259.733);
    --color-gray-800: oklch(27.8% 0.033 256.848);
    --color-gray-900: oklch(21% 0.034 264.665);
    --color-zinc-100: oklch(96.7% 0.001 286.375);
    --color-zinc-200: oklch(92% 0.004 286.32);
    --color-zinc-700: oklch(37% 0.013 285.805);
    --color-zinc-900: oklch(21% 0.006 285.885);
    --color-white: #fff;
    --spacing: 0.25rem;
    --breakpoint-sm: 36rem;
    --breakpoint-md: 48rem;
    --breakpoint-lg: 64rem;
    --breakpoint-xl: 80rem;
    --breakpoint-2xl: 96rem;
    --container-6xl: 72rem;
    --container-7xl: 80rem;
    --text-xs: 0.75rem;
    --text-xs--line-height: calc(1 / 0.75);
    --text-sm: 0.875rem;
    --text-sm--line-height: calc(1.25 / 0.875);
    --text-base: 1rem;
    --text-base--line-height: calc(1.5 / 1);
    --text-lg: 1.125rem;
    --text-lg--line-height: calc(1.75 / 1.125);
    --text-xl: 1.25rem;
    --text-xl--line-height: calc(1.75 / 1.25);
    --text-2xl: 1.5rem;
    --text-2xl--line-height: calc(2 / 1.5);
    --text-3xl: 1.875rem;
    --text-3xl--line-height: calc(2.25 / 1.875);
    --text-4xl: 2.25rem;
    --text-4xl--line-height: calc(2.5 / 2.25);
    --text-5xl: 3rem;
    --text-5xl--line-height: 1;
    --font-weight-medium: 500;
    --font-weight-semibold: 600;
    --font-weight-bold: 700;
    --tracking-wide: 0.025em;
    --leading-relaxed: 1.625;
    --radius-sm: 0.25rem;
    --radius-md: 0.375rem;
    --radius-lg: 0.5rem;
    --radius-xl: 0.625rem;
    --shadow-xs: 0 1px 2px 0 rgb(0 0 0 / 0.05);
    --shadow-sm: 0 1px 3px 0 rgb(0 0 0 / 0.1), 0 1px 2px -1px rgb(0 0 0 / 0.1);
    --shadow-md: 0 4px 6px -1px rgb(0 0 0 / 0.1), 0 2px 4px -2px rgb(0 0 0 / 0.1);
    --shadow-lg: 0 10px 15px -3px rgb(0 0 0 / 0.1), 0 4px 6px -4px rgb(0 0 0 / 0.1);
    --shadow-xl: 0 20px 25px -5px rgb(0 0 0 / 0.1), 0 8px 10px -6px rgb(0 0 0 / 0.1);
    --ease-in: cubic-bezier(0.4, 0, 1, 1);
    --ease-out: cubic-bezier(0, 0, 0.2, 1);
    --ease-in-out: cubic-bezier(0.4, 0, 0.2, 1);
    --animate-spin: spin 1s linear infinite;
    --animate-ping: ping 1s cubic-bezier(0, 0, 0.2, 1) infinite;
    --animate-pulse: pulse 2s cubic-bezier(0.4, 0, 0.6, 1) infinite;
    --animate-bounce: bounce 1s infinite;
    --default-transition-duration: 150ms;
    --default-transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
    --default-font-family: var(--font-sans);
    --default-mono-font-family: var(--font-mono);
    --color-brand: oklch(45% 0.18 250);
    --color-brand-hover: oklch(38% 0.18 250);
    --color-brand-light: oklch(60% 0.15 250);
    --color-brand-dark: oklch(30% 0.18 250);
    --color-brand-subtle: oklch(96% 0.04 250);
    --color-accent: oklch(65% 0.22 35);
    --color-brand-orange: oklch(69% 0.21 44);
    --color-success: oklch(52% 0.14 145);
    --color-success-hover: oklch(44% 0.14 145);
    --color-success-subtle: oklch(96% 0.05 145);
    --color-on-success: oklch(98% 0 0);
    --color-danger: oklch(52% 0.18 25);
    --color-danger-hover: oklch(44% 0.18 25);
    --color-danger-subtle: oklch(96% 0.06 25);
    --color-on-danger: oklch(98% 0 0);
    --color-warning: oklch(70% 0.15 80);
    --color-warning-hover: oklch(60% 0.15 80);
    --color-warning-subtle: oklch(97% 0.05 80);
    --color-info: oklch(55% 0.14 230);
    --color-purple-hover: oklch(45% 0.19 295);
    --color-purple-subtle: oklch(97% 0.04 295);
    --color-on-brand: oklch(98% 0 0);
    --color-on-surface: oklch(20% 0.01 250);
    --color-text: oklch(15% 0 0);
    --color-text-primary: oklch(20% 0.01 250);
    --color-text-secondary: oklch(45% 0.02 250);
    --color-text-muted: oklch(55% 0 0);
    --color-muted: oklch(55% 0 0);
    --color-text-disabled: oklch(75% 0.01 250);
    --color-text-inverse: oklch(98% 0 0);
    --color-surface: oklch(99% 0 0);
    --color-surface-alt: oklch(96% 0 0);
    --color-surface-2: oklch(97% 0.005 250);
    --color-surface-3: oklch(94% 0.005 250);
    --color-surface-inverse: oklch(18% 0.02 250);
    --color-border: oklch(88% 0 0);
    --color-border-strong: oklch(75% 0.01 250);
    --font-display: "Poppins", "Inter Variable", "Inter", system-ui, sans-serif;
    --spacing-xs: 0.25rem;
    --spacing-sm: 0.5rem;
    --spacing-md: 0.75rem;
    --spacing-lg: 1rem;
    --spacing-xl: 1.5rem;
    --spacing-2xl: 2rem;
    --spacing-3xl: 3rem;
    --radius-full: 9999px;
    --shadow-card: 0 1px 3px oklch(0% 0 0 / 8%), 0 1px 2px oklch(0% 0 0 / 6%);
    --shadow-modal: 0 20px 60px oklch(0% 0 0 / 20%);
    --z-base: 0;
    --z-raised: 10;
    --z-dropdown: 100;
    --z-sticky: 200;
    --z-fixed: 300;
    --z-modal: 400;
    --z-toast: 500;
    --z-tooltip: 600;
    --z-overlay: 10100;
  }
}
@layer base {
  *, ::after, ::before, ::backdrop, ::file-selector-button {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
    border: 0 solid;
  }
  html, :host {
    line-height: 1.5;
    -webkit-text-size-adjust: 100%;
    tab-size: 4;
    font-family: var(--default-font-family, ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji");
    font-feature-settings: var(--default-font-feature-settings, normal);
    font-variation-settings: var(--default-font-variation-settings, normal);
    -webkit-tap-highlight-color: transparent;
  }
  hr {
    height: 0;
    color: inherit;
    border-top-width: 1px;
  }
  abbr:where([title]) {
    -webkit-text-decoration: underline dotted;
    text-decoration: underline dotted;
  }
  h1, h2, h3, h4, h5, h6 {
    font-size: inherit;
    font-weight: inherit;
  }
  a {
    color: inherit;
    -webkit-text-decoration: inherit;
    text-decoration: inherit;
  }
  b, strong {
    font-weight: bolder;
  }
  code, kbd, samp, pre {
    font-family: var(--default-mono-font-family, ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace);
    font-feature-settings: var(--default-mono-font-feature-settings, normal);
    font-variation-settings: var(--default-mono-font-variation-settings, normal);
    font-size: 1em;
  }
  small {
    font-size: 80%;
  }
  sub, sup {
    font-size: 75%;
    line-height: 0;
    position: relative;
    vertical-align: baseline;
  }
  sub {
    bottom: -0.25em;
  }
  sup {
    top: -0.5em;
  }
  table {
    text-indent: 0;
    border-color: inherit;
    border-collapse: collapse;
  }
  :-moz-focusring {
    outline: auto;
  }
  progress {
    vertical-align: baseline;
  }
  summary {
    display: list-item;
  }
  ol, ul, menu {
    list-style: none;
  }
  img, svg, video, canvas, audio, iframe, embed, object {
    display: block;
    vertical-align: middle;
  }
  img, video {
    max-width: 100%;
    height: auto;
  }
  button, input, select, optgroup, textarea, ::file-selector-button {
    font: inherit;
    font-feature-settings: inherit;
    font-variation-settings: inherit;
    letter-spacing: inherit;
    color: inherit;
    border-radius: 0;
    background-color: transparent;
    opacity: 1;
  }
  :where(select:is([multiple], [size])) optgroup {
    font-weight: bolder;
  }
  :where(select:is([multiple], [size])) optgroup option {
    padding-inline-start: 20px;
  }
  ::file-selector-button {
    margin-inline-end: 4px;
  }
  ::placeholder {
    opacity: 1;
  }
  @supports (not (-webkit-appearance: -apple-pay-button))  or (contain-intrinsic-size: 1px) {
    ::placeholder {
      color: currentcolor;
      @supports (color: color-mix(in lab, red, red)) {
        color: color-mix(in oklab, currentcolor 50%, transparent);
      }
    }
  }
  textarea {
    resize: vertical;
  }
  ::-webkit-search-decoration {
    -webkit-appearance: none;
  }
  ::-webkit-date-and-time-value {
    min-height: 1lh;
    text-align: inherit;
  }
  ::-webkit-datetime-edit {
    display: inline-flex;
  }
  ::-webkit-datetime-edit-fields-wrapper {
    padding: 0;
  }
  ::-webkit-datetime-edit, ::-webkit-datetime-edit-year-field, ::-webkit-datetime-edit-month-field, ::-webkit-datetime-edit-day-field, ::-webkit-datetime-edit-hour-field, ::-webkit-datetime-edit-minute-field, ::-webkit-datetime-edit-second-field, ::-webkit-datetime-edit-millisecond-field, ::-webkit-datetime-edit-meridiem-field {
    padding-block: 0;
  }
  ::-webkit-calendar-picker-indicator {
    line-height: 1;
  }
  :-moz-ui-invalid {
    box-shadow: none;
  }
  button, input:where([type="button"], [type="reset"], [type="submit"]), ::file-selector-button {
    appearance: button;
  }
  ::-webkit-inner-spin-button, ::-webkit-outer-spin-button {
    height: auto;
  }
  [hidden]:where(:not([hidden="until-found"])) {
    display: none !important;
  }
}
@layer utilities {
  .\@container\/card {
    container-type: inline-size;
    container-name: card;
  }
  .\@container {
    container-type: inline-size;
  }
  .pointer-events-none {
    pointer-events: none;
  }
  .\!visible {
    visibility: visible !important;
  }
  .collapse {
    visibility: collapse;
  }
  .invisible {
    visibility: hidden;
  }
  .visible {
    visibility: visible;
  }
  .sr-only {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip-path: inset(50%);
    white-space: nowrap;
    border-width: 0;
  }
  .absolute {
    position: absolute;
  }
  .fixed {
    position: fixed;
  }
  .fixed\! {
    position: fixed !important;
  }
  .relative {
    position: relative;
  }
  .static {
    position: static;
  }
  .sticky {
    position: sticky;
  }
  .top-0 {
    top: calc(var(--spacing) * 0);
  }
  .top-4 {
    top: calc(var(--spacing) * 4);
  }
  .top-20 {
    top: calc(var(--spacing) * 20);
  }
  .right-0 {
    right: calc(var(--spacing) * 0);
  }
  .right-4 {
    right: calc(var(--spacing) * 4);
  }
  .left-0 {
    left: calc(var(--spacing) * 0);
  }
  .left-4 {
    left: calc(var(--spacing) * 4);
  }
  .isolate {
    isolation: isolate;
  }
  .z-10 {
    z-index: 10;
  }
  .z-20 {
    z-index: 20;
  }
  .z-30 {
    z-index: 30;
  }
  .z-40 {
    z-index: 40;
  }
  .z-50 {
    z-index: 50;
  }
  .float-left {
    float: left;
  }
  .float-right {
    float: right;
  }
  .container {
    width: 100%;
    @media (width >= 36rem) {
      max-width: 36rem;
    }
    @media (width >= 48rem) {
      max-width: 48rem;
    }
    @media (width >= 64rem) {
      max-width: 64rem;
    }
    @media (width >= 80rem) {
      max-width: 80rem;
    }
    @media (width >= 96rem) {
      max-width: 96rem;
    }
  }
  .m-6 {
    margin: calc(var(--spacing) * 6);
  }
  .mx-4 {
    margin-inline: calc(var(--spacing) * 4);
  }
  .mx-auto {
    margin-inline: auto;
  }
  .my-md {
    margin-block: var(--spacing-md);
  }
  .mt-1 {
    margin-top: calc(var(--spacing) * 1);
  }
  .mt-2 {
    margin-top: calc(var(--spacing) * 2);
  }
  .mt-4 {
    margin-top: calc(var(--spacing) * 4);
  }
  .mt-8 {
    margin-top: calc(var(--spacing) * 8);
  }
  .mr-1 {
    margin-right: calc(var(--spacing) * 1);
  }
  .mb-1 {
    margin-bottom: calc(var(--spacing) * 1);
  }
  .mb-2 {
    margin-bottom: calc(var(--spacing) * 2);
  }
  .mb-3 {
    margin-bottom: calc(var(--spacing) * 3);
  }
  .mb-4 {
    margin-bottom: calc(var(--spacing) * 4);
  }
  .mb-8 {
    margin-bottom: calc(var(--spacing) * 8);
  }
  .ml-2 {
    margin-left: calc(var(--spacing) * 2);
  }
  .line-clamp-2 {
    overflow: hidden;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
  }
  .block {
    display: block;
  }
  .contents {
    display: contents;
  }
  .flex {
    display: flex;
  }
  .grid {
    display: grid;
  }
  .hidden {
    display: none;
  }
  .inline {
    display: inline;
  }
  .inline\! {
    display: inline !important;
  }
  .inline-block {
    display: inline-block;
  }
  .inline-flex {
    display: inline-flex;
  }
  .table {
    display: table;
  }
  .table-row {
    display: table-row;
  }
  .size-6 {
    width: calc(var(--spacing) * 6);
    height: calc(var(--spacing) * 6);
  }
  .size-8 {
    width: calc(var(--spacing) * 8);
    height: calc(var(--spacing) * 8);
  }
  .h-4 {
    height: calc(var(--spacing) * 4);
  }
  .h-5 {
    height: calc(var(--spacing) * 5);
  }
  .h-6 {
    height: calc(var(--spacing) * 6);
  }
  .h-8 {
    height: calc(var(--spacing) * 8);
  }
  .h-12 {
    height: calc(var(--spacing) * 12);
  }
  .h-14 {
    height: calc(var(--spacing) * 14);
  }
  .h-48 {
    height: calc(var(--spacing) * 48);
  }
  .h-\[1-9\] {
    height: 1-9;
  }
  .min-h-screen {
    min-height: 100vh;
  }
  .w-1\/2 {
    width: calc(1 / 2 * 100%);
  }
  .w-3\/4 {
    width: calc(3 / 4 * 100%);
  }
  .w-4 {
    width: calc(var(--spacing) * 4);
  }
  .w-5 {
    width: calc(var(--spacing) * 5);
  }
  .w-5\/6 {
    width: calc(5 / 6 * 100%);
  }
  .w-6 {
    width: calc(var(--spacing) * 6);
  }
  .w-8 {
    width: calc(var(--spacing) * 8);
  }
  .w-12 {
    width: calc(var(--spacing) * 12);
  }
  .w-32 {
    width: calc(var(--spacing) * 32);
  }
  .w-64 {
    width: calc(var(--spacing) * 64);
  }
  .w-80 {
    width: calc(var(--spacing) * 80);
  }
  .w-\[200px\] {
    width: 200px;
  }
  .w-\[372px\] {
    width: 372px;
  }
  .w-full {
    width: 100%;
  }
  .max-w-2xl {
    max-width: var(--spacing-2xl);
  }
  .max-w-6xl {
    max-width: var(--container-6xl);
  }
  .max-w-7xl {
    max-width: var(--container-7xl);
  }
  .max-w-full {
    max-width: 100%;
  }
  .max-w-lg {
    max-width: var(--spacing-lg);
  }
  .max-w-md {
    max-width: var(--spacing-md);
  }
  .max-w-none {
    max-width: none;
  }
  .max-w-prose {
    max-width: 65ch;
  }
  .min-w-full {
    min-width: 100%;
  }
  .flex-shrink {
    flex-shrink: 1;
  }
  .flex-shrink-0 {
    flex-shrink: 0;
  }
  .shrink {
    flex-shrink: 1;
  }
  .shrink-0 {
    flex-shrink: 0;
  }
  .grow {
    flex-grow: 1;
  }
  .transform {
    transform: var(--tw-rotate-x,) var(--tw-rotate-y,) var(--tw-rotate-z,) var(--tw-skew-x,) var(--tw-skew-y,);
  }
  .animate-bounce {
    animation: var(--animate-bounce);
  }
  .animate-ping {
    animation: var(--animate-ping);
  }
  .animate-pulse {
    animation: var(--animate-pulse);
  }
  .animate-spin {
    animation: var(--animate-spin);
  }
  .cursor-pointer {
    cursor: pointer;
  }
  .resize {
    resize: both;
  }
  .grid-cols-1 {
    grid-template-columns: repeat(1, minmax(0, 1fr));
  }
  .grid-cols-2 {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .grid-cols-3 {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
  .grid-cols-4 {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }
  .grid-cols-\[auto_1fr\] {
    grid-template-columns: auto 1fr;
  }
  .grid-cols-\[repeat\(auto-fit\,minmax\(250px\,1fr\)\)\] {
    grid-template-columns: repeat(auto-fit,minmax(250px,1fr));
  }
  .grid-rows-2 {
    grid-template-rows: repeat(2, minmax(0, 1fr));
  }
  .flex-col {
    flex-direction: column;
  }
  .flex-row {
    flex-direction: row;
  }
  .flex-wrap {
    flex-wrap: wrap;
  }
  .items-center {
    align-items: center;
  }
  .items-start {
    align-items: flex-start;
  }
  .justify-between {
    justify-content: space-between;
  }
  .justify-center {
    justify-content: center;
  }
  .justify-end {
    justify-content: flex-end;
  }
  .gap-2 {
    gap: calc(var(--spacing) * 2);
  }
  .gap-3 {
    gap: calc(var(--spacing) * 3);
  }
  .gap-4 {
    gap: calc(var(--spacing) * 4);
  }
  .gap-6 {
    gap: calc(var(--spacing) * 6);
  }
  .space-y-1 {
    :where(& > :not(:last-child)) {
      --tw-space-y-reverse: 0;
      margin-block-start: calc(calc(var(--spacing) * 1) * var(--tw-space-y-reverse));
      margin-block-end: calc(calc(var(--spacing) * 1) * calc(1 - var(--tw-space-y-reverse)));
    }
  }
  .space-y-2 {
    :where(& > :not(:last-child)) {
      --tw-space-y-reverse: 0;
      margin-block-start: calc(calc(var(--spacing) * 2) * var(--tw-space-y-reverse));
      margin-block-end: calc(calc(var(--spacing) * 2) * calc(1 - var(--tw-space-y-reverse)));
    }
  }
  .space-y-4 {
    :where(& > :not(:last-child)) {
      --tw-space-y-reverse: 0;
      margin-block-start: calc(calc(var(--spacing) * 4) * var(--tw-space-y-reverse));
      margin-block-end: calc(calc(var(--spacing) * 4) * calc(1 - var(--tw-space-y-reverse)));
    }
  }
  .space-y-6 {
    :where(& > :not(:last-child)) {
      --tw-space-y-reverse: 0;
      margin-block-start: calc(calc(var(--spacing) * 6) * var(--tw-space-y-reverse));
      margin-block-end: calc(calc(var(--spacing) * 6) * calc(1 - var(--tw-space-y-reverse)));
    }
  }
  .divide-y {
    :where(& > :not(:last-child)) {
      --tw-divide-y-reverse: 0;
      border-bottom-style: var(--tw-border-style);
      border-top-style: var(--tw-border-style);
      border-top-width: calc(1px * var(--tw-divide-y-reverse));
      border-bottom-width: calc(1px * calc(1 - var(--tw-divide-y-reverse)));
    }
  }
  .divide-slate-200 {
    :where(& > :not(:last-child)) {
      border-color: var(--color-slate-200);
    }
  }
  .truncate {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
  }
  .overflow-hidden {
    overflow: hidden;
  }
  .overflow-visible {
    overflow: visible;
  }
  .\!rounded-full {
    border-radius: var(--radius-full) !important;
  }
  .rounded {
    border-radius: 0.25rem;
  }
  .rounded-full {
    border-radius: var(--radius-full);
  }
  .rounded-lg {
    border-radius: var(--radius-lg);
  }
  .rounded-md {
    border-radius: var(--radius-md);
  }
  .rounded-xl {
    border-radius: var(--radius-xl);
  }
  .border {
    border-style: var(--tw-border-style);
    border-width: 1px;
  }
  .border\! {
    border-style: var(--tw-border-style) !important;
    border-width: 1px !important;
  }
  .border-t {
    border-top-style: var(--tw-border-style);
    border-top-width: 1px;
  }
  .border-r {
    border-right-style: var(--tw-border-style);
    border-right-width: 1px;
  }
  .border-b {
    border-bottom-style: var(--tw-border-style);
    border-bottom-width: 1px;
  }
  .border-b-2 {
    border-bottom-style: var(--tw-border-style);
    border-bottom-width: 2px;
  }
  .border-none {
    --tw-border-style: none;
    border-style: none;
  }
  .border-blue-200 {
    border-color: var(--color-blue-200);
  }
  .border-blue-600 {
    border-color: var(--color-blue-600);
  }
  .border-gray-200 {
    border-color: var(--color-gray-200);
  }
  .border-gray-300 {
    border-color: var(--color-gray-300);
  }
  .border-green-200 {
    border-color: var(--color-green-200);
  }
  .border-red-200 {
    border-color: var(--color-red-200);
  }
  .border-white\/10 {
    border-color: color-mix(in srgb, #fff 10%, transparent);
    @supports (color: color-mix(in lab, red, red)) {
      border-color: color-mix(in oklab, var(--color-white) 10%, transparent);
    }
  }
  .border-yellow-200 {
    border-color: var(--color-yellow-200);
  }
  .border-zinc-200 {
    border-color: var(--color-zinc-200);
  }
  .bg-blue-50 {
    background-color: var(--color-blue-50);
  }
  .bg-blue-100 {
    background-color: var(--color-blue-100);
  }
  .bg-blue-500 {
    background-color: var(--color-blue-500);
  }
  .bg-blue-600 {
    background-color: var(--color-blue-600);
  }
  .bg-gray-50 {
    background-color: var(--color-gray-50);
  }
  .bg-gray-100 {
    background-color: var(--color-gray-100);
  }
  .bg-gray-200 {
    background-color: var(--color-gray-200);
  }
  .bg-green-50 {
    background-color: var(--color-green-50);
  }
  .bg-green-100 {
    background-color: var(--color-green-100);
  }
  .bg-green-500 {
    background-color: var(--color-green-500);
  }
  .bg-red-50 {
    background-color: var(--color-red-50);
  }
  .bg-red-100 {
    background-color: var(--color-red-100);
  }
  .bg-red-500 {
    background-color: var(--color-red-500);
  }
  .bg-red-600 {
    background-color: var(--color-red-600);
  }
  .bg-slate-50 {
    background-color: var(--color-slate-50);
  }
  .bg-slate-100 {
    background-color: var(--color-slate-100);
  }
  .bg-success {
    background-color: var(--color-success);
  }
  .bg-transparent {
    background-color: transparent;
  }
  .bg-warning {
    background-color: var(--color-warning);
  }
  .bg-white {
    background-color: var(--color-white);
  }
  .bg-white\/10 {
    background-color: color-mix(in srgb, #fff 10%, transparent);
    @supports (color: color-mix(in lab, red, red)) {
      background-color: color-mix(in oklab, var(--color-white) 10%, transparent);
    }
  }
  .bg-white\/80 {
    background-color: color-mix(in srgb, #fff 80%, transparent);
    @supports (color: color-mix(in lab, red, red)) {
      background-color: color-mix(in oklab, var(--color-white) 80%, transparent);
    }
  }
  .bg-yellow-50 {
    background-color: var(--color-yellow-50);
  }
  .bg-yellow-100 {
    background-color: var(--color-yellow-100);
  }
  .from-blue-500 {
    --tw-gradient-from: var(--color-blue-500);
    --tw-gradient-stops: var(--tw-gradient-via-stops, var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position));
  }
  .fill-white {
    fill: var(--color-white);
  }
  .object-cover {
    object-fit: cover;
  }
  .p-2 {
    padding: calc(var(--spacing) * 2);
  }
  .p-3 {
    padding: calc(var(--spacing) * 3);
  }
  .p-4 {
    padding: calc(var(--spacing) * 4);
  }
  .p-6 {
    padding: calc(var(--spacing) * 6);
  }
  .p-8 {
    padding: calc(var(--spacing) * 8);
  }
  .px-2 {
    padding-inline: calc(var(--spacing) * 2);
  }
  .px-2\.5 {
    padding-inline: calc(var(--spacing) * 2.5);
  }
  .px-3 {
    padding-inline: calc(var(--spacing) * 3);
  }
  .px-4 {
    padding-inline: calc(var(--spacing) * 4);
  }
  .px-6 {
    padding-inline: calc(var(--spacing) * 6);
  }
  .px-8 {
    padding-inline: calc(var(--spacing) * 8);
  }
  .py-0\.5 {
    padding-block: calc(var(--spacing) * 0.5);
  }
  .py-1 {
    padding-block: calc(var(--spacing) * 1);
  }
  .py-2 {
    padding-block: calc(var(--spacing) * 2);
  }
  .py-3 {
    padding-block: calc(var(--spacing) * 3);
  }
  .py-4 {
    padding-block: calc(var(--spacing) * 4);
  }
  .py-8 {
    padding-block: calc(var(--spacing) * 8);
  }
  .py-12 {
    padding-block: calc(var(--spacing) * 12);
  }
  .pt-4 {
    padding-top: calc(var(--spacing) * 4);
  }
  .text-center {
    text-align: center;
  }
  .text-left {
    text-align: left;
  }
  .font-display {
    font-family: var(--font-display);
  }
  .font-mono {
    font-family: var(--font-mono);
  }
  .text-2xl {
    font-size: var(--text-2xl);
    line-height: var(--tw-leading, var(--text-2xl--line-height));
  }
  .text-3xl {
    font-size: var(--text-3xl);
    line-height: var(--tw-leading, var(--text-3xl--line-height));
  }
  .text-4xl {
    font-size: var(--text-4xl);
    line-height: var(--tw-leading, var(--text-4xl--line-height));
  }
  .text-5xl {
    font-size: var(--text-5xl);
    line-height: var(--tw-leading, var(--text-5xl--line-height));
  }
  .text-base {
    font-size: var(--text-base);
    line-height: var(--tw-leading, var(--text-base--line-height));
  }
  .text-lg {
    font-size: var(--text-lg);
    line-height: var(--tw-leading, var(--text-lg--line-height));
  }
  .text-sm {
    font-size: var(--text-sm);
    line-height: var(--tw-leading, var(--text-sm--line-height));
  }
  .text-xl {
    font-size: var(--text-xl);
    line-height: var(--tw-leading, var(--text-xl--line-height));
  }
  .text-xs {
    font-size: var(--text-xs);
    line-height: var(--tw-leading, var(--text-xs--line-height));
  }
  .leading-relaxed {
    --tw-leading: var(--leading-relaxed);
    line-height: var(--leading-relaxed);
  }
  .font-bold {
    --tw-font-weight: var(--font-weight-bold);
    font-weight: var(--font-weight-bold);
  }
  .font-medium {
    --tw-font-weight: var(--font-weight-medium);
    font-weight: var(--font-weight-medium);
  }
  .font-semibold {
    --tw-font-weight: var(--font-weight-semibold);
    font-weight: var(--font-weight-semibold);
  }
  .tracking-wide {
    --tw-tracking: var(--tracking-wide);
    letter-spacing: var(--tracking-wide);
  }
  .whitespace-nowrap {
    white-space: nowrap;
  }
  .text-blue-400 {
    color: var(--color-blue-400);
  }
  .text-blue-600 {
    color: var(--color-blue-600);
  }
  .text-blue-700 {
    color: var(--color-blue-700);
  }
  .text-blue-800 {
    color: var(--color-blue-800);
  }
  .text-gray-400 {
    color: var(--color-gray-400);
  }
  .text-gray-500 {
    color: var(--color-gray-500);
  }
  .text-gray-600 {
    color: var(--color-gray-600);
  }
  .text-gray-700 {
    color: var(--color-gray-700);
  }
  .text-gray-800 {
    color: var(--color-gray-800);
  }
  .text-gray-900 {
    color: var(--color-gray-900);
  }
  .text-green-600 {
    color: var(--color-green-600);
  }
  .text-green-700 {
    color: var(--color-green-700);
  }
  .text-green-800 {
    color: var(--color-green-800);
  }
  .text-muted {
    color: var(--color-muted);
  }
  .text-red-500 {
    color: var(--color-red-500);
  }
  .text-red-600 {
    color: var(--color-red-600);
  }
  .text-red-700 {
    color: var(--color-red-700);
  }
  .text-red-800 {
    color: var(--color-red-800);
  }
  .text-slate-400 {
    color: var(--color-slate-400);
  }
  .text-slate-500 {
    color: var(--color-slate-500);
  }
  .text-slate-800 {
    color: var(--color-slate-800);
  }
  .text-slate-900 {
    color: var(--color-slate-900);
  }
  .text-success {
    color: var(--color-success);
  }
  .text-white {
    color: var(--color-white);
  }
  .text-yellow-600 {
    color: var(--color-yellow-600);
  }
  .text-yellow-800 {
    color: var(--color-yellow-800);
  }
  .text-zinc-900 {
    color: var(--color-zinc-900);
  }
  .capitalize {
    text-transform: capitalize;
  }
  .lowercase {
    text-transform: lowercase;
  }
  .uppercase {
    text-transform: uppercase;
  }
  .italic {
    font-style: italic;
  }
  .ordinal {
    --tw-ordinal: ordinal;
    font-variant-numeric: var(--tw-ordinal,) var(--tw-slashed-zero,) var(--tw-numeric-figure,) var(--tw-numeric-spacing,) var(--tw-numeric-fraction,);
  }
  .tabular-nums {
    --tw-numeric-spacing: tabular-nums;
    font-variant-numeric: var(--tw-ordinal,) var(--tw-slashed-zero,) var(--tw-numeric-figure,) var(--tw-numeric-spacing,) var(--tw-numeric-fraction,);
  }
  .line-through {
    text-decoration-line: line-through;
  }
  .overline {
    text-decoration-line: overline;
  }
  .underline {
    text-decoration-line: underline;
  }
  .antialiased {
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
  }
  .opacity-25 {
    opacity: 25%;
  }
  .opacity-50 {
    opacity: 50%;
  }
  .opacity-75 {
    opacity: 75%;
  }
  .shadow {
    --tw-shadow: 0 1px 3px 0 var(--tw-shadow-color, rgb(0 0 0 / 0.1)), 0 1px 2px -1px var(--tw-shadow-color, rgb(0 0 0 / 0.1));
    box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
  }
  .shadow-\[0_4px_20px_rgba\(0\,0\,0\,0\.1\)\] {
    --tw-shadow: 0 4px 20px var(--tw-shadow-color, rgba(0,0,0,0.1));
    box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
  }
  .shadow-card {
    --tw-shadow: 0 1px 3px var(--tw-shadow-color, oklch(0% 0 0 / 8%)), 0 1px 2px var(--tw-shadow-color, oklch(0% 0 0 / 6%));
    box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
  }
  .shadow-lg {
    --tw-shadow: 0 10px 15px -3px var(--tw-shadow-color, rgb(0 0 0 / 0.1)), 0 4px 6px -4px var(--tw-shadow-color, rgb(0 0 0 / 0.1));
    box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
  }
  .shadow-md {
    --tw-shadow: 0 4px 6px -1px var(--tw-shadow-color, rgb(0 0 0 / 0.1)), 0 2px 4px -2px var(--tw-shadow-color, rgb(0 0 0 / 0.1));
    box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
  }
  .ring {
    --tw-ring-shadow: var(--tw-ring-inset,) 0 0 0 calc(1px + var(--tw-ring-offset-width)) var(--tw-ring-color, currentcolor);
    box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
  }
  .outline {
    outline-style: var(--tw-outline-style);
    outline-width: 1px;
  }
  .blur {
    --tw-blur: blur(8px);
    filter: var(--tw-blur,) var(--tw-brightness,) var(--tw-contrast,) var(--tw-grayscale,) var(--tw-hue-rotate,) var(--tw-invert,) var(--tw-saturate,) var(--tw-sepia,) var(--tw-drop-shadow,);
  }
  .invert {
    --tw-invert: invert(100%);
    filter: var(--tw-blur,) var(--tw-brightness,) var(--tw-contrast,) var(--tw-grayscale,) var(--tw-hue-rotate,) var(--tw-invert,) var(--tw-saturate,) var(--tw-sepia,) var(--tw-drop-shadow,);
  }
  .filter {
    filter: var(--tw-blur,) var(--tw-brightness,) var(--tw-contrast,) var(--tw-grayscale,) var(--tw-hue-rotate,) var(--tw-invert,) var(--tw-saturate,) var(--tw-sepia,) var(--tw-drop-shadow,);
  }
  .backdrop-filter {
    -webkit-backdrop-filter: var(--tw-backdrop-blur,) var(--tw-backdrop-brightness,) var(--tw-backdrop-contrast,) var(--tw-backdrop-grayscale,) var(--tw-backdrop-hue-rotate,) var(--tw-backdrop-invert,) var(--tw-backdrop-opacity,) var(--tw-backdrop-saturate,) var(--tw-backdrop-sepia,);
    backdrop-filter: var(--tw-backdrop-blur,) var(--tw-backdrop-brightness,) var(--tw-backdrop-contrast,) var(--tw-backdrop-grayscale,) var(--tw-backdrop-hue-rotate,) var(--tw-backdrop-invert,) var(--tw-backdrop-opacity,) var(--tw-backdrop-saturate,) var(--tw-backdrop-sepia,);
  }
  .transition {
    transition-property: color, background-color, border-color, outline-color, text-decoration-color, fill, stroke, --tw-gradient-from, --tw-gradient-via, --tw-gradient-to, opacity, box-shadow, transform, translate, scale, rotate, filter, -webkit-backdrop-filter, backdrop-filter, display, content-visibility, overlay, pointer-events;
    transition-timing-function: var(--tw-ease, var(--default-transition-timing-function));
    transition-duration: var(--tw-duration, var(--default-transition-duration));
  }
  .transition-all {
    transition-property: all;
    transition-timing-function: var(--tw-ease, var(--default-transition-timing-function));
    transition-duration: var(--tw-duration, var(--default-transition-duration));
  }
  .transition-colors {
    transition-property: color, background-color, border-color, outline-color, text-decoration-color, fill, stroke, --tw-gradient-from, --tw-gradient-via, --tw-gradient-to;
    transition-timing-function: var(--tw-ease, var(--default-transition-timing-function));
    transition-duration: var(--tw-duration, var(--default-transition-duration));
  }
  .transition-transform {
    transition-property: transform, translate, scale, rotate;
    transition-timing-function: var(--tw-ease, var(--default-transition-timing-function));
    transition-duration: var(--tw-duration, var(--default-transition-duration));
  }
  .duration-150 {
    --tw-duration: 150ms;
    transition-duration: 150ms;
  }
  .duration-200 {
    --tw-duration: 200ms;
    transition-duration: 200ms;
  }
  .duration-300 {
    --tw-duration: 300ms;
    transition-duration: 300ms;
  }
  .ease-in {
    --tw-ease: var(--ease-in);
    transition-timing-function: var(--ease-in);
  }
  .ease-in-out {
    --tw-ease: var(--ease-in-out);
    transition-timing-function: var(--ease-in-out);
  }
  .ease-out {
    --tw-ease: var(--ease-out);
    transition-timing-function: var(--ease-out);
  }
  .outline-none {
    --tw-outline-style: none;
    outline-style: none;
  }
  .select-all {
    -webkit-user-select: all;
    user-select: all;
  }
  .\[file\:line\] {
    file: line;
  }
  .\[images\:export\] {
    images: export;
  }
  .\[seed\:ng-workplace-invitations-for-app-user\] {
    seed: ng-workplace-invitations-for-app-user;
  }
  .placeholder\:text-gray-400 {
    &::placeholder {
      color: var(--color-gray-400);
    }
  }
  .hover\:-translate-y-1 {
    &:hover {
      @media (hover: hover) {
        --tw-translate-y: calc(var(--spacing) * -1);
        translate: var(--tw-translate-x) var(--tw-translate-y);
      }
    }
  }
  .hover\:scale-105 {
    &:hover {
      @media (hover: hover) {
        --tw-scale-x: 105%;
        --tw-scale-y: 105%;
        --tw-scale-z: 105%;
        scale: var(--tw-scale-x) var(--tw-scale-y);
      }
    }
  }
  .hover\:bg-blue-700 {
    &:hover {
      @media (hover: hover) {
        background-color: var(--color-blue-700);
      }
    }
  }
  .hover\:bg-gray-100 {
    &:hover {
      @media (hover: hover) {
        background-color: var(--color-gray-100);
      }
    }
  }
  .hover\:bg-gray-200 {
    &:hover {
      @media (hover: hover) {
        background-color: var(--color-gray-200);
      }
    }
  }
  .hover\:bg-red-700 {
    &:hover {
      @media (hover: hover) {
        background-color: var(--color-red-700);
      }
    }
  }
  .hover\:text-blue-600 {
    &:hover {
      @media (hover: hover) {
        color: var(--color-blue-600);
      }
    }
  }
  .hover\:text-blue-800 {
    &:hover {
      @media (hover: hover) {
        color: var(--color-blue-800);
      }
    }
  }
  .hover\:text-gray-600 {
    &:hover {
      @media (hover: hover) {
        color: var(--color-gray-600);
      }
    }
  }
  .hover\:text-gray-800 {
    &:hover {
      @media (hover: hover) {
        color: var(--color-gray-800);
      }
    }
  }
  .hover\:no-underline {
    &:hover {
      @media (hover: hover) {
        text-decoration-line: none;
      }
    }
  }
  .hover\:underline {
    &:hover {
      @media (hover: hover) {
        text-decoration-line: underline;
      }
    }
  }
  .hover\:shadow-xl {
    &:hover {
      @media (hover: hover) {
        --tw-shadow: 0 20px 25px -5px var(--tw-shadow-color, rgb(0 0 0 / 0.1)), 0 8px 10px -6px var(--tw-shadow-color, rgb(0 0 0 / 0.1));
        box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
      }
    }
  }
  .focus\:border-blue-500 {
    &:focus {
      border-color: var(--color-blue-500);
    }
  }
  .focus\:ring-2 {
    &:focus {
      --tw-ring-shadow: var(--tw-ring-inset,) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color, currentcolor);
      box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
    }
  }
  .focus\:ring-blue-500 {
    &:focus {
      --tw-ring-color: var(--color-blue-500);
    }
  }
  .focus\:ring-gray-500 {
    &:focus {
      --tw-ring-color: var(--color-gray-500);
    }
  }
  .focus\:ring-red-500 {
    &:focus {
      --tw-ring-color: var(--color-red-500);
    }
  }
  .focus\:ring-offset-2 {
    &:focus {
      --tw-ring-offset-width: 2px;
      --tw-ring-offset-shadow: var(--tw-ring-inset,) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);
    }
  }
  .focus\:outline-none {
    &:focus {
      --tw-outline-style: none;
      outline-style: none;
    }
  }
  .focus-visible\:ring-2 {
    &:focus-visible {
      --tw-ring-shadow: var(--tw-ring-inset,) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color, currentcolor);
      box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
    }
  }
  .focus-visible\:ring-blue-500 {
    &:focus-visible {
      --tw-ring-color: var(--color-blue-500);
    }
  }
  .active\:bg-blue-800 {
    &:active {
      background-color: var(--color-blue-800);
    }
  }
  .active\:bg-gray-300 {
    &:active {
      background-color: var(--color-gray-300);
    }
  }
  .active\:bg-red-800 {
    &:active {
      background-color: var(--color-red-800);
    }
  }
  .disabled\:cursor-not-allowed {
    &:disabled {
      cursor: not-allowed;
    }
  }
  .disabled\:opacity-50 {
    &:disabled {
      opacity: 50%;
    }
  }
  .sm\:px-6 {
    @media (width >= 36rem) {
      padding-inline: calc(var(--spacing) * 6);
    }
  }
  .sm\:text-3xl {
    @media (width >= 36rem) {
      font-size: var(--text-3xl);
      line-height: var(--tw-leading, var(--text-3xl--line-height));
    }
  }
  .md\:block {
    @media (width >= 48rem) {
      display: block;
    }
  }
  .md\:w-1\/2 {
    @media (width >= 48rem) {
      width: calc(1 / 2 * 100%);
    }
  }
  .md\:grid-cols-1 {
    @media (width >= 48rem) {
      grid-template-columns: repeat(1, minmax(0, 1fr));
    }
  }
  .md\:grid-cols-2 {
    @media (width >= 48rem) {
      grid-template-columns: repeat(2, minmax(0, 1fr));
    }
  }
  .md\:grid-cols-3 {
    @media (width >= 48rem) {
      grid-template-columns: repeat(3, minmax(0, 1fr));
    }
  }
  .md\:px-6 {
    @media (width >= 48rem) {
      padding-inline: calc(var(--spacing) * 6);
    }
  }
  .md\:px-8 {
    @media (width >= 48rem) {
      padding-inline: calc(var(--spacing) * 8);
    }
  }
  .md\:text-2xl {
    @media (width >= 48rem) {
      font-size: var(--text-2xl);
      line-height: var(--tw-leading, var(--text-2xl--line-height));
    }
  }
  .md\:text-3xl {
    @media (width >= 48rem) {
      font-size: var(--text-3xl);
      line-height: var(--tw-leading, var(--text-3xl--line-height));
    }
  }
  .md\:text-4xl {
    @media (width >= 48rem) {
      font-size: var(--text-4xl);
      line-height: var(--tw-leading, var(--text-4xl--line-height));
    }
  }
  .lg\:w-1\/3 {
    @media (width >= 64rem) {
      width: calc(1 / 3 * 100%);
    }
  }
  .lg\:grid-cols-3 {
    @media (width >= 64rem) {
      grid-template-columns: repeat(3, minmax(0, 1fr));
    }
  }
  .lg\:px-8 {
    @media (width >= 64rem) {
      padding-inline: calc(var(--spacing) * 8);
    }
  }
  .lg\:px-12 {
    @media (width >= 64rem) {
      padding-inline: calc(var(--spacing) * 12);
    }
  }
  .lg\:text-5xl {
    @media (width >= 64rem) {
      font-size: var(--text-5xl);
      line-height: var(--tw-leading, var(--text-5xl--line-height));
    }
  }
  .dark\:border-zinc-700 {
    @media (prefers-color-scheme: dark) {
      border-color: var(--color-zinc-700);
    }
  }
  .dark\:bg-zinc-900 {
    @media (prefers-color-scheme: dark) {
      background-color: var(--color-zinc-900);
    }
  }
  .dark\:text-zinc-100 {
    @media (prefers-color-scheme: dark) {
      color: var(--color-zinc-100);
    }
  }
  .\[tracking\=\"true\"\]\:visible {
    &:is(tracking="true") {
      visibility: visible;
    }
  }
}
.ag-filter-panel-buttons {
  display: flex;
  justify-content: flex-end;
  overflow: hidden;
  padding: var(--ag-widget-container-vertical-padding) var(--ag-widget-container-horizontal-padding) 0;
  flex-wrap: wrap;
  gap: var(--ag-widget-vertical-spacing) var(--ag-widget-horizontal-spacing);
}
.ag-filter-panel-buttons-button {
  line-height: 1.5;
}
.ag-filter-panel .ag-standard-button.ag-filter-panel-buttons-apply-button {
  color: var(--ag-filter-panel-apply-button-color);
  background-color: var(--ag-filter-panel-apply-button-background-color);
}
.ag-filter-panel > *:where(:last-child) {
  padding-bottom: var(--ag-widget-container-vertical-padding);
}
.ag-row.ag-row-pinned-source {
  color: var(--ag-pinned-source-row-text-color);
  background-color: var(--ag-pinned-source-row-background-color);
  font-weight: var(--ag-pinned-source-row-font-weight);
}
.ag-row.ag-row-pinned {
  color: var(--ag-pinned-row-text-color);
  background-color: var(--ag-pinned-row-background-color);
  font-weight: var(--ag-pinned-row-font-weight);
}
.ag-floating-top-viewport {
  border-bottom: var(--ag-pinned-row-border);
}
.ag-floating-bottom-viewport {
  border-top: var(--ag-pinned-row-border);
}
.ag-measurement-container {
  --ag-legacy-styles-loaded: "true";
}
.ag-icon {
  font-family: var(--ag-icon-font-family);
  font-weight: var(--ag-icon-font-weight);
  color: var(--ag-icon-font-color);
  font-size: var(--ag-icon-size);
  line-height: var(--ag-icon-size);
  font-style: normal;
  font-variant: normal;
  text-transform: none;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  width: var(--ag-icon-size);
  height: var(--ag-icon-size);
  position: relative;
}
.ag-icon::before {
  content: "";
  font-family: inherit;
}
.ag-icon::after {
  background: transparent var(--ag-icon-image, none) center/contain no-repeat;
  display: var(--ag-icon-image-display);
  opacity: var(--ag-icon-image-opacity, 0.9);
  position: absolute;
  inset: 0;
  content: "";
}
.ag-icon-aggregation {
  font-family: var(--ag-icon-font-family-aggregation, var(--ag-icon-font-family));
  font-weight: var(--ag-icon-font-weight-aggregation, var(--ag-icon-font-weight));
  color: var(--ag-icon-font-color-aggregation, var(--ag-icon-font-color));
}
.ag-icon-aggregation::before {
  content: var(--ag-icon-font-code-aggregation, "\f101");
  display: var(--ag-icon-font-display-aggregation, var(--ag-icon-font-display));
}
.ag-icon-aggregation::after {
  background-image: var(--ag-icon-image-aggregation, var(--ag-icon-image));
  display: var(--ag-icon-image-display-aggregation, var(--ag-icon-image-display));
  opacity: var(--ag-icon-image-opacity-aggregation, var(--ag-icon-image-opacity, 0.9));
}
.ag-icon-arrows {
  font-family: var(--ag-icon-font-family-arrows, var(--ag-icon-font-family));
  font-weight: var(--ag-icon-font-weight-arrows, var(--ag-icon-font-weight));
  color: var(--ag-icon-font-color-arrows, var(--ag-icon-font-color));
}
.ag-icon-arrows::before {
  content: var(--ag-icon-font-code-arrows, "\f102");
  display: var(--ag-icon-font-display-arrows, var(--ag-icon-font-display));
}
.ag-icon-arrows::after {
  background-image: var(--ag-icon-image-arrows, var(--ag-icon-image));
  display: var(--ag-icon-image-display-arrows, var(--ag-icon-image-display));
  opacity: var(--ag-icon-image-opacity-arrows, var(--ag-icon-image-opacity, 0.9));
}
.ag-icon-asc {
  font-family: var(--ag-icon-font-family-asc, var(--ag-icon-font-family));
  font-weight: var(--ag-icon-font-weight-asc, var(--ag-icon-font-weight));
  color: var(--ag-icon-font-color-asc, var(--ag-icon-font-color));
}
.ag-icon-asc::before {
  content: var(--ag-icon-font-code-asc, "\f103");
  display: var(--ag-icon-font-display-asc, var(--ag-icon-font-display));
}
.ag-icon-asc::after {
  background-image: var(--ag-icon-image-asc, var(--ag-icon-image));
  display: var(--ag-icon-image-display-asc, var(--ag-icon-image-display));
  opacity: var(--ag-icon-image-opacity-asc, var(--ag-icon-image-opacity, 0.9));
}
.ag-icon-aasc {
  font-family: var(--ag-icon-font-family-aasc, var(--ag-icon-font-family));
  font-weight: var(--ag-icon-font-weight-aasc, var(--ag-icon-font-weight));
  color: var(--ag-icon-font-color-aasc, var(--ag-icon-font-color));
}
.ag-icon-aasc::before {
  content: var(--ag-icon-font-code-aasc, "\f13c");
  display: var(--ag-icon-font-display-aasc, var(--ag-icon-font-display));
}
.ag-icon-aasc::after {
  background-image: var(--ag-icon-image-aasc, var(--ag-icon-image));
  display: var(--ag-icon-image-display-aasc, var(--ag-icon-image-display));
  opacity: var(--ag-icon-image-opacity-aasc, var(--ag-icon-image-opacity, 0.9));
}
.ag-icon-adesc {
  font-family: var(--ag-icon-font-family-adesc, var(--ag-icon-font-family));
  font-weight: var(--ag-icon-font-weight-adesc, var(--ag-icon-font-weight));
  color: var(--ag-icon-font-color-adesc, var(--ag-icon-font-color));
}
.ag-icon-adesc::before {
  content: var(--ag-icon-font-code-adesc, "\f13d");
  display: var(--ag-icon-font-display-adesc, var(--ag-icon-font-display));
}
.ag-icon-adesc::after {
  background-image: var(--ag-icon-image-adesc, var(--ag-icon-image));
  display: var(--ag-icon-image-display-adesc, var(--ag-icon-image-display));
  opacity: var(--ag-icon-image-opacity-adesc, var(--ag-icon-image-opacity, 0.9));
}
.ag-icon-cancel {
  font-family: var(--ag-icon-font-family-cancel, var(--ag-icon-font-family));
  font-weight: var(--ag-icon-font-weight-cancel, var(--ag-icon-font-weight));
  color: var(--ag-icon-font-color-cancel, var(--ag-icon-font-color));
}
.ag-icon-cancel::before {
  content: var(--ag-icon-font-code-cancel, "\f104");
  display: var(--ag-icon-font-display-cancel, var(--ag-icon-font-display));
}
.ag-icon-cancel::after {
  background-image: var(--ag-icon-image-cancel, var(--ag-icon-image));
  display: var(--ag-icon-image-display-cancel, var(--ag-icon-image-display));
  opacity: var(--ag-icon-image-opacity-cancel, var(--ag-icon-image-opacity, 0.9));
}
.ag-icon-chart {
  font-family: var(--ag-icon-font-family-chart, var(--ag-icon-font-family));
  font-weight: var(--ag-icon-font-weight-chart, var(--ag-icon-font-weight));
  color: var(--ag-icon-font-color-chart, var(--ag-icon-font-color));
}
.ag-icon-chart::before {
  content: var(--ag-icon-font-code-chart, "\f105");
  display: var(--ag-icon-font-display-chart, var(--ag-icon-font-display));
}
.ag-icon-chart::after {
  background-image: var(--ag-icon-image-chart, var(--ag-icon-image));
  display: var(--ag-icon-image-display-chart, var(--ag-icon-image-display));
  opacity: var(--ag-icon-image-opacity-chart, var(--ag-icon-image-opacity, 0.9));
}
.ag-icon-checkbox-checked {
  font-family: var(--ag-icon-font-family-checkbox-checked, var(--ag-icon-font-family));
  font-weight: var(--ag-icon-font-weight-checkbox-checked, var(--ag-icon-font-weight));
  color: var(--ag-icon-font-color-checkbox-checked, var(--ag-icon-font-color));
}
.ag-icon-checkbox-checked::before {
  content: var(--ag-icon-font-code-checkbox-checked, "\f106");
  display: var(--ag-icon-font-display-checkbox-checked, var(--ag-icon-font-display));
}
.ag-icon-checkbox-checked::after {
  background-image: var(--ag-icon-image-checkbox-checked, var(--ag-icon-image));
  display: var(--ag-icon-image-display-checkbox-checked, var(--ag-icon-image-display));
  opacity: var(--ag-icon-image-opacity-checkbox-checked, var(--ag-icon-image-opacity, 0.9));
}
.ag-icon-checkbox-indeterminate {
  font-family: var(--ag-icon-font-family-checkbox-indeterminate, var(--ag-icon-font-family));
  font-weight: var(--ag-icon-font-weight-checkbox-indeterminate, var(--ag-icon-font-weight));
  color: var(--ag-icon-font-color-checkbox-indeterminate, var(--ag-icon-font-color));
}
.ag-icon-checkbox-indeterminate::before {
  content: var(--ag-icon-font-code-checkbox-indeterminate, "\f107");
  display: var(--ag-icon-font-display-checkbox-indeterminate, var(--ag-icon-font-display));
}
.ag-icon-checkbox-indeterminate::after {
  background-image: var(--ag-icon-image-checkbox-indeterminate, var(--ag-icon-image));
  display: var(--ag-icon-image-display-checkbox-indeterminate, var(--ag-icon-image-display));
  opacity: var(--ag-icon-image-opacity-checkbox-indeterminate, var(--ag-icon-image-opacity, 0.9));
}
.ag-icon-checkbox-unchecked {
  font-family: var(--ag-icon-font-family-checkbox-unchecked, var(--ag-icon-font-family));
  font-weight: var(--ag-icon-font-weight-checkbox-unchecked, var(--ag-icon-font-weight));
  color: var(--ag-icon-font-color-checkbox-unchecked, var(--ag-icon-font-color));
}
.ag-icon-checkbox-unchecked::before {
  content: var(--ag-icon-font-code-checkbox-unchecked, "\f108");
  display: var(--ag-icon-font-display-checkbox-unchecked, var(--ag-icon-font-display));
}
.ag-icon-checkbox-unchecked::after {
  background-image: var(--ag-icon-image-checkbox-unchecked, var(--ag-icon-image));
  display: var(--ag-icon-image-display-checkbox-unchecked, var(--ag-icon-image-display));
  opacity: var(--ag-icon-image-opacity-checkbox-unchecked, var(--ag-icon-image-opacity, 0.9));
}
.ag-icon-color-picker {
  font-family: var(--ag-icon-font-family-color-picker, var(--ag-icon-font-family));
  font-weight: var(--ag-icon-font-weight-color-picker, var(--ag-icon-font-weight));
  color: var(--ag-icon-font-color-color-picker, var(--ag-icon-font-color));
}
.ag-icon-color-picker::before {
  content: var(--ag-icon-font-code-color-picker, "\f109");
  display: var(--ag-icon-font-display-color-picker, var(--ag-icon-font-display));
}
.ag-icon-color-picker::after {
  background-image: var(--ag-icon-image-color-picker, var(--ag-icon-image));
  display: var(--ag-icon-image-display-color-picker, var(--ag-icon-image-display));
  opacity: var(--ag-icon-image-opacity-color-picker, var(--ag-icon-image-opacity, 0.9));
}
.ag-icon-columns {
  font-family: var(--ag-icon-font-family-columns, var(--ag-icon-font-family));
  font-weight: var(--ag-icon-font-weight-columns, var(--ag-icon-font-weight));
  color: var(--ag-icon-font-color-columns, var(--ag-icon-font-color));
}
.ag-icon-columns::before {
  content: var(--ag-icon-font-code-columns, "\f10a");
  display: var(--ag-icon-font-display-columns, var(--ag-icon-font-display));
}
.ag-icon-columns::after {
  background-image: var(--ag-icon-image-columns, var(--ag-icon-image));
  display: var(--ag-icon-image-display-columns, var(--ag-icon-image-display));
  opacity: var(--ag-icon-image-opacity-columns, var(--ag-icon-image-opacity, 0.9));
}
.ag-icon-contracted {
  font-family: var(--ag-icon-font-family-contracted, var(--ag-icon-font-family));
  font-weight: var(--ag-icon-font-weight-contracted, var(--ag-icon-font-weight));
  color: var(--ag-icon-font-color-contracted, var(--ag-icon-font-color));
}
.ag-icon-contracted::before {
  content: var(--ag-icon-font-code-contracted, "\f10b");
  display: var(--ag-icon-font-display-contracted, var(--ag-icon-font-display));
}
.ag-icon-contracted::after {
  background-image: var(--ag-icon-image-contracted, var(--ag-icon-image));
  display: var(--ag-icon-image-display-contracted, var(--ag-icon-image-display));
  opacity: var(--ag-icon-image-opacity-contracted, var(--ag-icon-image-opacity, 0.9));
}
.ag-icon-copy {
  font-family: var(--ag-icon-font-family-copy, var(--ag-icon-font-family));
  font-weight: var(--ag-icon-font-weight-copy, var(--ag-icon-font-weight));
  color: var(--ag-icon-font-color-copy, var(--ag-icon-font-color));
}
.ag-icon-copy::before {
  content: var(--ag-icon-font-code-copy, "\f10c");
  display: var(--ag-icon-font-display-copy, var(--ag-icon-font-display));
}
.ag-icon-copy::after {
  background-image: var(--ag-icon-image-copy, var(--ag-icon-image));
  display: var(--ag-icon-image-display-copy, var(--ag-icon-image-display));
  opacity: var(--ag-icon-image-opacity-copy, var(--ag-icon-image-opacity, 0.9));
}
.ag-icon-cross {
  font-family: var(--ag-icon-font-family-cross, var(--ag-icon-font-family));
  font-weight: var(--ag-icon-font-weight-cross, var(--ag-icon-font-weight));
  color: var(--ag-icon-font-color-cross, var(--ag-icon-font-color));
}
.ag-icon-cross::before {
  content: var(--ag-icon-font-code-cross, "\f10d");
  display: var(--ag-icon-font-display-cross, var(--ag-icon-font-display));
}
.ag-icon-cross::after {
  background-image: var(--ag-icon-image-cross, var(--ag-icon-image));
  display: var(--ag-icon-image-display-cross, var(--ag-icon-image-display));
  opacity: var(--ag-icon-image-opacity-cross, var(--ag-icon-image-opacity, 0.9));
}
.ag-icon-csv {
  font-family: var(--ag-icon-font-family-csv, var(--ag-icon-font-family));
  font-weight: var(--ag-icon-font-weight-csv, var(--ag-icon-font-weight));
  color: var(--ag-icon-font-color-csv, var(--ag-icon-font-color));
}
.ag-icon-csv::before {
  content: var(--ag-icon-font-code-csv, "\f10e");
  display: var(--ag-icon-font-display-csv, var(--ag-icon-font-display));
}
.ag-icon-csv::after {
  background-image: var(--ag-icon-image-csv, var(--ag-icon-image));
  display: var(--ag-icon-image-display-csv, var(--ag-icon-image-display));
  opacity: var(--ag-icon-image-opacity-csv, var(--ag-icon-image-opacity, 0.9));
}
.ag-icon-cut {
  font-family: var(--ag-icon-font-family-cut, var(--ag-icon-font-family));
  font-weight: var(--ag-icon-font-weight-cut, var(--ag-icon-font-weight));
  color: var(--ag-icon-font-color-cut, var(--ag-icon-font-color));
}
.ag-icon-cut::before {
  content: var(--ag-icon-font-code-cut, "\f10f");
  display: var(--ag-icon-font-display-cut, var(--ag-icon-font-display));
}
.ag-icon-cut::after {
  background-image: var(--ag-icon-image-cut, var(--ag-icon-image));
  display: var(--ag-icon-image-display-cut, var(--ag-icon-image-display));
  opacity: var(--ag-icon-image-opacity-cut, var(--ag-icon-image-opacity, 0.9));
}
.ag-icon-desc {
  font-family: var(--ag-icon-font-family-desc, var(--ag-icon-font-family));
  font-weight: var(--ag-icon-font-weight-desc, var(--ag-icon-font-weight));
  color: var(--ag-icon-font-color-desc, var(--ag-icon-font-color));
}
.ag-icon-desc::before {
  content: var(--ag-icon-font-code-desc, "\f110");
  display: var(--ag-icon-font-display-desc, var(--ag-icon-font-display));
}
.ag-icon-desc::after {
  background-image: var(--ag-icon-image-desc, var(--ag-icon-image));
  display: var(--ag-icon-image-display-desc, var(--ag-icon-image-display));
  opacity: var(--ag-icon-image-opacity-desc, var(--ag-icon-image-opacity, 0.9));
}
.ag-icon-excel {
  font-family: var(--ag-icon-font-family-excel, var(--ag-icon-font-family));
  font-weight: var(--ag-icon-font-weight-excel, var(--ag-icon-font-weight));
  color: var(--ag-icon-font-color-excel, var(--ag-icon-font-color));
}
.ag-icon-excel::before {
  content: var(--ag-icon-font-code-excel, "\f111");
  display: var(--ag-icon-font-display-excel, var(--ag-icon-font-display));
}
.ag-icon-excel::after {
  background-image: var(--ag-icon-image-excel, var(--ag-icon-image));
  display: var(--ag-icon-image-display-excel, var(--ag-icon-image-display));
  opacity: var(--ag-icon-image-opacity-excel, var(--ag-icon-image-opacity, 0.9));
}
.ag-icon-expanded {
  font-family: var(--ag-icon-font-family-expanded, var(--ag-icon-font-family));
  font-weight: var(--ag-icon-font-weight-expanded, var(--ag-icon-font-weight));
  color: var(--ag-icon-font-color-expanded, var(--ag-icon-font-color));
}
.ag-icon-expanded::before {
  content: var(--ag-icon-font-code-expanded, "\f112");
  display: var(--ag-icon-font-display-expanded, var(--ag-icon-font-display));
}
.ag-icon-expanded::after {
  background-image: var(--ag-icon-image-expanded, var(--ag-icon-image));
  display: var(--ag-icon-image-display-expanded, var(--ag-icon-image-display));
  opacity: var(--ag-icon-image-opacity-expanded, var(--ag-icon-image-opacity, 0.9));
}
.ag-icon-eye-slash {
  font-family: var(--ag-icon-font-family-eye-slash, var(--ag-icon-font-family));
  font-weight: var(--ag-icon-font-weight-eye-slash, var(--ag-icon-font-weight));
  color: var(--ag-icon-font-color-eye-slash, var(--ag-icon-font-color));
}
.ag-icon-eye-slash::before {
  content: var(--ag-icon-font-code-eye-slash, "\f113");
  display: var(--ag-icon-font-display-eye-slash, var(--ag-icon-font-display));
}
.ag-icon-eye-slash::after {
  background-image: var(--ag-icon-image-eye-slash, var(--ag-icon-image));
  display: var(--ag-icon-image-display-eye-slash, var(--ag-icon-image-display));
  opacity: var(--ag-icon-image-opacity-eye-slash, var(--ag-icon-image-opacity, 0.9));
}
.ag-icon-eye {
  font-family: var(--ag-icon-font-family-eye, var(--ag-icon-font-family));
  font-weight: var(--ag-icon-font-weight-eye, var(--ag-icon-font-weight));
  color: var(--ag-icon-font-color-eye, var(--ag-icon-font-color));
}
.ag-icon-eye::before {
  content: var(--ag-icon-font-code-eye, "\f114");
  display: var(--ag-icon-font-display-eye, var(--ag-icon-font-display));
}
.ag-icon-eye::after {
  background-image: var(--ag-icon-image-eye, var(--ag-icon-image));
  display: var(--ag-icon-image-display-eye, var(--ag-icon-image-display));
  opacity: var(--ag-icon-image-opacity-eye, var(--ag-icon-image-opacity, 0.9));
}
.ag-icon-filter {
  font-family: var(--ag-icon-font-family-filter, var(--ag-icon-font-family));
  font-weight: var(--ag-icon-font-weight-filter, var(--ag-icon-font-weight));
  color: var(--ag-icon-font-color-filter, var(--ag-icon-font-color));
}
.ag-icon-filter::before {
  content: var(--ag-icon-font-code-filter, "\f115");
  display: var(--ag-icon-font-display-filter, var(--ag-icon-font-display));
}
.ag-icon-filter::after {
  background-image: var(--ag-icon-image-filter, var(--ag-icon-image));
  display: var(--ag-icon-image-display-filter, var(--ag-icon-image-display));
  opacity: var(--ag-icon-image-opacity-filter, var(--ag-icon-image-opacity, 0.9));
}
.ag-icon-first {
  font-family: var(--ag-icon-font-family-first, var(--ag-icon-font-family));
  font-weight: var(--ag-icon-font-weight-first, var(--ag-icon-font-weight));
  color: var(--ag-icon-font-color-first, var(--ag-icon-font-color));
}
.ag-icon-first::before {
  content: var(--ag-icon-font-code-first, "\f116");
  display: var(--ag-icon-font-display-first, var(--ag-icon-font-display));
}
.ag-icon-first::after {
  background-image: var(--ag-icon-image-first, var(--ag-icon-image));
  display: var(--ag-icon-image-display-first, var(--ag-icon-image-display));
  opacity: var(--ag-icon-image-opacity-first, var(--ag-icon-image-opacity, 0.9));
}
.ag-icon-grip {
  font-family: var(--ag-icon-font-family-grip, var(--ag-icon-font-family));
  font-weight: var(--ag-icon-font-weight-grip, var(--ag-icon-font-weight));
  color: var(--ag-icon-font-color-grip, var(--ag-icon-font-color));
}
.ag-icon-grip::before {
  content: var(--ag-icon-font-code-grip, "\f117");
  display: var(--ag-icon-font-display-grip, var(--ag-icon-font-display));
}
.ag-icon-grip::after {
  background-image: var(--ag-icon-image-grip, var(--ag-icon-image));
  display: var(--ag-icon-image-display-grip, var(--ag-icon-image-display));
  opacity: var(--ag-icon-image-opacity-grip, var(--ag-icon-image-opacity, 0.9));
}
.ag-icon-group {
  font-family: var(--ag-icon-font-family-group, var(--ag-icon-font-family));
  font-weight: var(--ag-icon-font-weight-group, var(--ag-icon-font-weight));
  color: var(--ag-icon-font-color-group, var(--ag-icon-font-color));
}
.ag-icon-group::before {
  content: var(--ag-icon-font-code-group, "\f118");
  display: var(--ag-icon-font-display-group, var(--ag-icon-font-display));
}
.ag-icon-group::after {
  background-image: var(--ag-icon-image-group, var(--ag-icon-image));
  display: var(--ag-icon-image-display-group, var(--ag-icon-image-display));
  opacity: var(--ag-icon-image-opacity-group, var(--ag-icon-image-opacity, 0.9));
}
.ag-icon-last {
  font-family: var(--ag-icon-font-family-last, var(--ag-icon-font-family));
  font-weight: var(--ag-icon-font-weight-last, var(--ag-icon-font-weight));
  color: var(--ag-icon-font-color-last, var(--ag-icon-font-color));
}
.ag-icon-last::before {
  content: var(--ag-icon-font-code-last, "\f119");
  display: var(--ag-icon-font-display-last, var(--ag-icon-font-display));
}
.ag-icon-last::after {
  background-image: var(--ag-icon-image-last, var(--ag-icon-image));
  display: var(--ag-icon-image-display-last, var(--ag-icon-image-display));
  opacity: var(--ag-icon-image-opacity-last, var(--ag-icon-image-opacity, 0.9));
}
.ag-icon-left {
  font-family: var(--ag-icon-font-family-left, var(--ag-icon-font-family));
  font-weight: var(--ag-icon-font-weight-left, var(--ag-icon-font-weight));
  color: var(--ag-icon-font-color-left, var(--ag-icon-font-color));
}
.ag-icon-left::before {
  content: var(--ag-icon-font-code-left, "\f11a");
  display: var(--ag-icon-font-display-left, var(--ag-icon-font-display));
}
.ag-icon-left::after {
  background-image: var(--ag-icon-image-left, var(--ag-icon-image));
  display: var(--ag-icon-image-display-left, var(--ag-icon-image-display));
  opacity: var(--ag-icon-image-opacity-left, var(--ag-icon-image-opacity, 0.9));
}
.ag-icon-linked {
  font-family: var(--ag-icon-font-family-linked, var(--ag-icon-font-family));
  font-weight: var(--ag-icon-font-weight-linked, var(--ag-icon-font-weight));
  color: var(--ag-icon-font-color-linked, var(--ag-icon-font-color));
}
.ag-icon-linked::before {
  content: var(--ag-icon-font-code-linked, "\f11b");
  display: var(--ag-icon-font-display-linked, var(--ag-icon-font-display));
}
.ag-icon-linked::after {
  background-image: var(--ag-icon-image-linked, var(--ag-icon-image));
  display: var(--ag-icon-image-display-linked, var(--ag-icon-image-display));
  opacity: var(--ag-icon-image-opacity-linked, var(--ag-icon-image-opacity, 0.9));
}
.ag-icon-loading {
  font-family: var(--ag-icon-font-family-loading, var(--ag-icon-font-family));
  font-weight: var(--ag-icon-font-weight-loading, var(--ag-icon-font-weight));
  color: var(--ag-icon-font-color-loading, var(--ag-icon-font-color));
}
.ag-icon-loading::before {
  content: var(--ag-icon-font-code-loading, "\f11c");
  display: var(--ag-icon-font-display-loading, var(--ag-icon-font-display));
}
.ag-icon-loading::after {
  background-image: var(--ag-icon-image-loading, var(--ag-icon-image));
  display: var(--ag-icon-image-display-loading, var(--ag-icon-image-display));
  opacity: var(--ag-icon-image-opacity-loading, var(--ag-icon-image-opacity, 0.9));
}
.ag-icon-maximize {
  font-family: var(--ag-icon-font-family-maximize, var(--ag-icon-font-family));
  font-weight: var(--ag-icon-font-weight-maximize, var(--ag-icon-font-weight));
  color: var(--ag-icon-font-color-maximize, var(--ag-icon-font-color));
}
.ag-icon-maximize::before {
  content: var(--ag-icon-font-code-maximize, "\f11d");
  display: var(--ag-icon-font-display-maximize, var(--ag-icon-font-display));
}
.ag-icon-maximize::after {
  background-image: var(--ag-icon-image-maximize, var(--ag-icon-image));
  display: var(--ag-icon-image-display-maximize, var(--ag-icon-image-display));
  opacity: var(--ag-icon-image-opacity-maximize, var(--ag-icon-image-opacity, 0.9));
}
.ag-icon-menu {
  font-family: var(--ag-icon-font-family-menu, var(--ag-icon-font-family));
  font-weight: var(--ag-icon-font-weight-menu, var(--ag-icon-font-weight));
  color: var(--ag-icon-font-color-menu, var(--ag-icon-font-color));
}
.ag-icon-menu::before {
  content: var(--ag-icon-font-code-menu, "\f11e");
  display: var(--ag-icon-font-display-menu, var(--ag-icon-font-display));
}
.ag-icon-menu::after {
  background-image: var(--ag-icon-image-menu, var(--ag-icon-image));
  display: var(--ag-icon-image-display-menu, var(--ag-icon-image-display));
  opacity: var(--ag-icon-image-opacity-menu, var(--ag-icon-image-opacity, 0.9));
}
.ag-icon-minimize {
  font-family: var(--ag-icon-font-family-minimize, var(--ag-icon-font-family));
  font-weight: var(--ag-icon-font-weight-minimize, var(--ag-icon-font-weight));
  color: var(--ag-icon-font-color-minimize, var(--ag-icon-font-color));
}
.ag-icon-minimize::before {
  content: var(--ag-icon-font-code-minimize, "\f11f");
  display: var(--ag-icon-font-display-minimize, var(--ag-icon-font-display));
}
.ag-icon-minimize::after {
  background-image: var(--ag-icon-image-minimize, var(--ag-icon-image));
  display: var(--ag-icon-image-display-minimize, var(--ag-icon-image-display));
  opacity: var(--ag-icon-image-opacity-minimize, var(--ag-icon-image-opacity, 0.9));
}
.ag-icon-next {
  font-family: var(--ag-icon-font-family-next, var(--ag-icon-font-family));
  font-weight: var(--ag-icon-font-weight-next, var(--ag-icon-font-weight));
  color: var(--ag-icon-font-color-next, var(--ag-icon-font-color));
}
.ag-icon-next::before {
  content: var(--ag-icon-font-code-next, "\f120");
  display: var(--ag-icon-font-display-next, var(--ag-icon-font-display));
}
.ag-icon-next::after {
  background-image: var(--ag-icon-image-next, var(--ag-icon-image));
  display: var(--ag-icon-image-display-next, var(--ag-icon-image-display));
  opacity: var(--ag-icon-image-opacity-next, var(--ag-icon-image-opacity, 0.9));
}
.ag-icon-none {
  font-family: var(--ag-icon-font-family-none, var(--ag-icon-font-family));
  font-weight: var(--ag-icon-font-weight-none, var(--ag-icon-font-weight));
  color: var(--ag-icon-font-color-none, var(--ag-icon-font-color));
}
.ag-icon-none::before {
  content: var(--ag-icon-font-code-none, "\f121");
  display: var(--ag-icon-font-display-none, var(--ag-icon-font-display));
}
.ag-icon-none::after {
  background-image: var(--ag-icon-image-none, var(--ag-icon-image));
  display: var(--ag-icon-image-display-none, var(--ag-icon-image-display));
  opacity: var(--ag-icon-image-opacity-none, var(--ag-icon-image-opacity, 0.9));
}
.ag-icon-not-allowed {
  font-family: var(--ag-icon-font-family-not-allowed, var(--ag-icon-font-family));
  font-weight: var(--ag-icon-font-weight-not-allowed, var(--ag-icon-font-weight));
  color: var(--ag-icon-font-color-not-allowed, var(--ag-icon-font-color));
}
.ag-icon-not-allowed::before {
  content: var(--ag-icon-font-code-not-allowed, "\f122");
  display: var(--ag-icon-font-display-not-allowed, var(--ag-icon-font-display));
}
.ag-icon-not-allowed::after {
  background-image: var(--ag-icon-image-not-allowed, var(--ag-icon-image));
  display: var(--ag-icon-image-display-not-allowed, var(--ag-icon-image-display));
  opacity: var(--ag-icon-image-opacity-not-allowed, var(--ag-icon-image-opacity, 0.9));
}
.ag-icon-paste {
  font-family: var(--ag-icon-font-family-paste, var(--ag-icon-font-family));
  font-weight: var(--ag-icon-font-weight-paste, var(--ag-icon-font-weight));
  color: var(--ag-icon-font-color-paste, var(--ag-icon-font-color));
}
.ag-icon-paste::before {
  content: var(--ag-icon-font-code-paste, "\f123");
  display: var(--ag-icon-font-display-paste, var(--ag-icon-font-display));
}
.ag-icon-paste::after {
  background-image: var(--ag-icon-image-paste, var(--ag-icon-image));
  display: var(--ag-icon-image-display-paste, var(--ag-icon-image-display));
  opacity: var(--ag-icon-image-opacity-paste, var(--ag-icon-image-opacity, 0.9));
}
.ag-icon-pin {
  font-family: var(--ag-icon-font-family-pin, var(--ag-icon-font-family));
  font-weight: var(--ag-icon-font-weight-pin, var(--ag-icon-font-weight));
  color: var(--ag-icon-font-color-pin, var(--ag-icon-font-color));
}
.ag-icon-pin::before {
  content: var(--ag-icon-font-code-pin, "\f124");
  display: var(--ag-icon-font-display-pin, var(--ag-icon-font-display));
}
.ag-icon-pin::after {
  background-image: var(--ag-icon-image-pin, var(--ag-icon-image));
  display: var(--ag-icon-image-display-pin, var(--ag-icon-image-display));
  opacity: var(--ag-icon-image-opacity-pin, var(--ag-icon-image-opacity, 0.9));
}
.ag-icon-pivot {
  font-family: var(--ag-icon-font-family-pivot, var(--ag-icon-font-family));
  font-weight: var(--ag-icon-font-weight-pivot, var(--ag-icon-font-weight));
  color: var(--ag-icon-font-color-pivot, var(--ag-icon-font-color));
}
.ag-icon-pivot::before {
  content: var(--ag-icon-font-code-pivot, "\f125");
  display: var(--ag-icon-font-display-pivot, var(--ag-icon-font-display));
}
.ag-icon-pivot::after {
  background-image: var(--ag-icon-image-pivot, var(--ag-icon-image));
  display: var(--ag-icon-image-display-pivot, var(--ag-icon-image-display));
  opacity: var(--ag-icon-image-opacity-pivot, var(--ag-icon-image-opacity, 0.9));
}
.ag-icon-previous {
  font-family: var(--ag-icon-font-family-previous, var(--ag-icon-font-family));
  font-weight: var(--ag-icon-font-weight-previous, var(--ag-icon-font-weight));
  color: var(--ag-icon-font-color-previous, var(--ag-icon-font-color));
}
.ag-icon-previous::before {
  content: var(--ag-icon-font-code-previous, "\f126");
  display: var(--ag-icon-font-display-previous, var(--ag-icon-font-display));
}
.ag-icon-previous::after {
  background-image: var(--ag-icon-image-previous, var(--ag-icon-image));
  display: var(--ag-icon-image-display-previous, var(--ag-icon-image-display));
  opacity: var(--ag-icon-image-opacity-previous, var(--ag-icon-image-opacity, 0.9));
}
.ag-icon-radio-button-off {
  font-family: var(--ag-icon-font-family-radio-button-off, var(--ag-icon-font-family));
  font-weight: var(--ag-icon-font-weight-radio-button-off, var(--ag-icon-font-weight));
  color: var(--ag-icon-font-color-radio-button-off, var(--ag-icon-font-color));
}
.ag-icon-radio-button-off::before {
  content: var(--ag-icon-font-code-radio-button-off, "\f127");
  display: var(--ag-icon-font-display-radio-button-off, var(--ag-icon-font-display));
}
.ag-icon-radio-button-off::after {
  background-image: var(--ag-icon-image-radio-button-off, var(--ag-icon-image));
  display: var(--ag-icon-image-display-radio-button-off, var(--ag-icon-image-display));
  opacity: var(--ag-icon-image-opacity-radio-button-off, var(--ag-icon-image-opacity, 0.9));
}
.ag-icon-radio-button-on {
  font-family: var(--ag-icon-font-family-radio-button-on, var(--ag-icon-font-family));
  font-weight: var(--ag-icon-font-weight-radio-button-on, var(--ag-icon-font-weight));
  color: var(--ag-icon-font-color-radio-button-on, var(--ag-icon-font-color));
}
.ag-icon-radio-button-on::before {
  content: var(--ag-icon-font-code-radio-button-on, "\f128");
  display: var(--ag-icon-font-display-radio-button-on, var(--ag-icon-font-display));
}
.ag-icon-radio-button-on::after {
  background-image: var(--ag-icon-image-radio-button-on, var(--ag-icon-image));
  display: var(--ag-icon-image-display-radio-button-on, var(--ag-icon-image-display));
  opacity: var(--ag-icon-image-opacity-radio-button-on, var(--ag-icon-image-opacity, 0.9));
}
.ag-icon-right {
  font-family: var(--ag-icon-font-family-right, var(--ag-icon-font-family));
  font-weight: var(--ag-icon-font-weight-right, var(--ag-icon-font-weight));
  color: var(--ag-icon-font-color-right, var(--ag-icon-font-color));
}
.ag-icon-right::before {
  content: var(--ag-icon-font-code-right, "\f129");
  display: var(--ag-icon-font-display-right, var(--ag-icon-font-display));
}
.ag-icon-right::after {
  background-image: var(--ag-icon-image-right, var(--ag-icon-image));
  display: var(--ag-icon-image-display-right, var(--ag-icon-image-display));
  opacity: var(--ag-icon-image-opacity-right, var(--ag-icon-image-opacity, 0.9));
}
.ag-icon-save {
  font-family: var(--ag-icon-font-family-save, var(--ag-icon-font-family));
  font-weight: var(--ag-icon-font-weight-save, var(--ag-icon-font-weight));
  color: var(--ag-icon-font-color-save, var(--ag-icon-font-color));
}
.ag-icon-save::before {
  content: var(--ag-icon-font-code-save, "\f12a");
  display: var(--ag-icon-font-display-save, var(--ag-icon-font-display));
}
.ag-icon-save::after {
  background-image: var(--ag-icon-image-save, var(--ag-icon-image));
  display: var(--ag-icon-image-display-save, var(--ag-icon-image-display));
  opacity: var(--ag-icon-image-opacity-save, var(--ag-icon-image-opacity, 0.9));
}
.ag-icon-small-down {
  font-family: var(--ag-icon-font-family-small-down, var(--ag-icon-font-family));
  font-weight: var(--ag-icon-font-weight-small-down, var(--ag-icon-font-weight));
  color: var(--ag-icon-font-color-small-down, var(--ag-icon-font-color));
}
.ag-icon-small-down::before {
  content: var(--ag-icon-font-code-small-down, "\f12b");
  display: var(--ag-icon-font-display-small-down, var(--ag-icon-font-display));
}
.ag-icon-small-down::after {
  background-image: var(--ag-icon-image-small-down, var(--ag-icon-image));
  display: var(--ag-icon-image-display-small-down, var(--ag-icon-image-display));
  opacity: var(--ag-icon-image-opacity-small-down, var(--ag-icon-image-opacity, 0.9));
}
.ag-icon-small-left {
  font-family: var(--ag-icon-font-family-small-left, var(--ag-icon-font-family));
  font-weight: var(--ag-icon-font-weight-small-left, var(--ag-icon-font-weight));
  color: var(--ag-icon-font-color-small-left, var(--ag-icon-font-color));
}
.ag-icon-small-left::before {
  content: var(--ag-icon-font-code-small-left, "\f12c");
  display: var(--ag-icon-font-display-small-left, var(--ag-icon-font-display));
}
.ag-icon-small-left::after {
  background-image: var(--ag-icon-image-small-left, var(--ag-icon-image));
  display: var(--ag-icon-image-display-small-left, var(--ag-icon-image-display));
  opacity: var(--ag-icon-image-opacity-small-left, var(--ag-icon-image-opacity, 0.9));
}
.ag-icon-small-right {
  font-family: var(--ag-icon-font-family-small-right, var(--ag-icon-font-family));
  font-weight: var(--ag-icon-font-weight-small-right, var(--ag-icon-font-weight));
  color: var(--ag-icon-font-color-small-right, var(--ag-icon-font-color));
}
.ag-icon-small-right::before {
  content: var(--ag-icon-font-code-small-right, "\f12d");
  display: var(--ag-icon-font-display-small-right, var(--ag-icon-font-display));
}
.ag-icon-small-right::after {
  background-image: var(--ag-icon-image-small-right, var(--ag-icon-image));
  display: var(--ag-icon-image-display-small-right, var(--ag-icon-image-display));
  opacity: var(--ag-icon-image-opacity-small-right, var(--ag-icon-image-opacity, 0.9));
}
.ag-icon-small-up {
  font-family: var(--ag-icon-font-family-small-up, var(--ag-icon-font-family));
  font-weight: var(--ag-icon-font-weight-small-up, var(--ag-icon-font-weight));
  color: var(--ag-icon-font-color-small-up, var(--ag-icon-font-color));
}
.ag-icon-small-up::before {
  content: var(--ag-icon-font-code-small-up, "\f12e");
  display: var(--ag-icon-font-display-small-up, var(--ag-icon-font-display));
}
.ag-icon-small-up::after {
  background-image: var(--ag-icon-image-small-up, var(--ag-icon-image));
  display: var(--ag-icon-image-display-small-up, var(--ag-icon-image-display));
  opacity: var(--ag-icon-image-opacity-small-up, var(--ag-icon-image-opacity, 0.9));
}
.ag-icon-tick {
  font-family: var(--ag-icon-font-family-tick, var(--ag-icon-font-family));
  font-weight: var(--ag-icon-font-weight-tick, var(--ag-icon-font-weight));
  color: var(--ag-icon-font-color-tick, var(--ag-icon-font-color));
}
.ag-icon-tick::before {
  content: var(--ag-icon-font-code-tick, "\f12f");
  display: var(--ag-icon-font-display-tick, var(--ag-icon-font-display));
}
.ag-icon-tick::after {
  background-image: var(--ag-icon-image-tick, var(--ag-icon-image));
  display: var(--ag-icon-image-display-tick, var(--ag-icon-image-display));
  opacity: var(--ag-icon-image-opacity-tick, var(--ag-icon-image-opacity, 0.9));
}
.ag-icon-tree-closed {
  font-family: var(--ag-icon-font-family-tree-closed, var(--ag-icon-font-family));
  font-weight: var(--ag-icon-font-weight-tree-closed, var(--ag-icon-font-weight));
  color: var(--ag-icon-font-color-tree-closed, var(--ag-icon-font-color));
}
.ag-icon-tree-closed::before {
  content: var(--ag-icon-font-code-tree-closed, "\f130");
  display: var(--ag-icon-font-display-tree-closed, var(--ag-icon-font-display));
}
.ag-icon-tree-closed::after {
  background-image: var(--ag-icon-image-tree-closed, var(--ag-icon-image));
  display: var(--ag-icon-image-display-tree-closed, var(--ag-icon-image-display));
  opacity: var(--ag-icon-image-opacity-tree-closed, var(--ag-icon-image-opacity, 0.9));
}
.ag-icon-tree-indeterminate {
  font-family: var(--ag-icon-font-family-tree-indeterminate, var(--ag-icon-font-family));
  font-weight: var(--ag-icon-font-weight-tree-indeterminate, var(--ag-icon-font-weight));
  color: var(--ag-icon-font-color-tree-indeterminate, var(--ag-icon-font-color));
}
.ag-icon-tree-indeterminate::before {
  content: var(--ag-icon-font-code-tree-indeterminate, "\f131");
  display: var(--ag-icon-font-display-tree-indeterminate, var(--ag-icon-font-display));
}
.ag-icon-tree-indeterminate::after {
  background-image: var(--ag-icon-image-tree-indeterminate, var(--ag-icon-image));
  display: var(--ag-icon-image-display-tree-indeterminate, var(--ag-icon-image-display));
  opacity: var(--ag-icon-image-opacity-tree-indeterminate, var(--ag-icon-image-opacity, 0.9));
}
.ag-icon-tree-open {
  font-family: var(--ag-icon-font-family-tree-open, var(--ag-icon-font-family));
  font-weight: var(--ag-icon-font-weight-tree-open, var(--ag-icon-font-weight));
  color: var(--ag-icon-font-color-tree-open, var(--ag-icon-font-color));
}
.ag-icon-tree-open::before {
  content: var(--ag-icon-font-code-tree-open, "\f132");
  display: var(--ag-icon-font-display-tree-open, var(--ag-icon-font-display));
}
.ag-icon-tree-open::after {
  background-image: var(--ag-icon-image-tree-open, var(--ag-icon-image));
  display: var(--ag-icon-image-display-tree-open, var(--ag-icon-image-display));
  opacity: var(--ag-icon-image-opacity-tree-open, var(--ag-icon-image-opacity, 0.9));
}
.ag-icon-unlinked {
  font-family: var(--ag-icon-font-family-unlinked, var(--ag-icon-font-family));
  font-weight: var(--ag-icon-font-weight-unlinked, var(--ag-icon-font-weight));
  color: var(--ag-icon-font-color-unlinked, var(--ag-icon-font-color));
}
.ag-icon-unlinked::before {
  content: var(--ag-icon-font-code-unlinked, "\f133");
  display: var(--ag-icon-font-display-unlinked, var(--ag-icon-font-display));
}
.ag-icon-unlinked::after {
  background-image: var(--ag-icon-image-unlinked, var(--ag-icon-image));
  display: var(--ag-icon-image-display-unlinked, var(--ag-icon-image-display));
  opacity: var(--ag-icon-image-opacity-unlinked, var(--ag-icon-image-opacity, 0.9));
}
.ag-icon-up {
  font-family: var(--ag-icon-font-family-up, var(--ag-icon-font-family));
  font-weight: var(--ag-icon-font-weight-up, var(--ag-icon-font-weight));
  color: var(--ag-icon-font-color-up, var(--ag-icon-font-color));
}
.ag-icon-up::before {
  content: var(--ag-icon-font-code-up, "\f134");
  display: var(--ag-icon-font-display-up, var(--ag-icon-font-display));
}
.ag-icon-up::after {
  background-image: var(--ag-icon-image-up, var(--ag-icon-image));
  display: var(--ag-icon-image-display-up, var(--ag-icon-image-display));
  opacity: var(--ag-icon-image-opacity-up, var(--ag-icon-image-opacity, 0.9));
}
.ag-icon-down {
  font-family: var(--ag-icon-font-family-down, var(--ag-icon-font-family));
  font-weight: var(--ag-icon-font-weight-down, var(--ag-icon-font-weight));
  color: var(--ag-icon-font-color-down, var(--ag-icon-font-color));
}
.ag-icon-down::before {
  content: var(--ag-icon-font-code-down, "\f135");
  display: var(--ag-icon-font-display-down, var(--ag-icon-font-display));
}
.ag-icon-down::after {
  background-image: var(--ag-icon-image-down, var(--ag-icon-image));
  display: var(--ag-icon-image-display-down, var(--ag-icon-image-display));
  opacity: var(--ag-icon-image-opacity-down, var(--ag-icon-image-opacity, 0.9));
}
.ag-icon-plus {
  font-family: var(--ag-icon-font-family-plus, var(--ag-icon-font-family));
  font-weight: var(--ag-icon-font-weight-plus, var(--ag-icon-font-weight));
  color: var(--ag-icon-font-color-plus, var(--ag-icon-font-color));
}
.ag-icon-plus::before {
  content: var(--ag-icon-font-code-plus, "\f136");
  display: var(--ag-icon-font-display-plus, var(--ag-icon-font-display));
}
.ag-icon-plus::after {
  background-image: var(--ag-icon-image-plus, var(--ag-icon-image));
  display: var(--ag-icon-image-display-plus, var(--ag-icon-image-display));
  opacity: var(--ag-icon-image-opacity-plus, var(--ag-icon-image-opacity, 0.9));
}
.ag-icon-minus {
  font-family: var(--ag-icon-font-family-minus, var(--ag-icon-font-family));
  font-weight: var(--ag-icon-font-weight-minus, var(--ag-icon-font-weight));
  color: var(--ag-icon-font-color-minus, var(--ag-icon-font-color));
}
.ag-icon-minus::before {
  content: var(--ag-icon-font-code-minus, "\f137");
  display: var(--ag-icon-font-display-minus, var(--ag-icon-font-display));
}
.ag-icon-minus::after {
  background-image: var(--ag-icon-image-minus, var(--ag-icon-image));
  display: var(--ag-icon-image-display-minus, var(--ag-icon-image-display));
  opacity: var(--ag-icon-image-opacity-minus, var(--ag-icon-image-opacity, 0.9));
}
.ag-icon-menu-alt {
  font-family: var(--ag-icon-font-family-menu-alt, var(--ag-icon-font-family));
  font-weight: var(--ag-icon-font-weight-menu-alt, var(--ag-icon-font-weight));
  color: var(--ag-icon-font-color-menu-alt, var(--ag-icon-font-color));
}
.ag-icon-menu-alt::before {
  content: var(--ag-icon-font-code-menu-alt, "\f138");
  display: var(--ag-icon-font-display-menu-alt, var(--ag-icon-font-display));
}
.ag-icon-menu-alt::after {
  background-image: var(--ag-icon-image-menu-alt, var(--ag-icon-image));
  display: var(--ag-icon-image-display-menu-alt, var(--ag-icon-image-display));
  opacity: var(--ag-icon-image-opacity-menu-alt, var(--ag-icon-image-opacity, 0.9));
}
.ag-icon-settings {
  font-family: var(--ag-icon-font-family-settings, var(--ag-icon-font-family));
  font-weight: var(--ag-icon-font-weight-settings, var(--ag-icon-font-weight));
  color: var(--ag-icon-font-color-settings, var(--ag-icon-font-color));
}
.ag-icon-settings::before {
  content: var(--ag-icon-font-code-settings, "\f139");
  display: var(--ag-icon-font-display-settings, var(--ag-icon-font-display));
}
.ag-icon-settings::after {
  background-image: var(--ag-icon-image-settings, var(--ag-icon-image));
  display: var(--ag-icon-image-display-settings, var(--ag-icon-image-display));
  opacity: var(--ag-icon-image-opacity-settings, var(--ag-icon-image-opacity, 0.9));
}
.ag-icon-column-arrow {
  font-family: var(--ag-icon-font-family-column-arrow, var(--ag-icon-font-family));
  font-weight: var(--ag-icon-font-weight-column-arrow, var(--ag-icon-font-weight));
  color: var(--ag-icon-font-color-column-arrow, var(--ag-icon-font-color));
}
.ag-icon-column-arrow::before {
  content: var(--ag-icon-font-code-column-arrow, "\f13a");
  display: var(--ag-icon-font-display-column-arrow, var(--ag-icon-font-display));
}
.ag-icon-column-arrow::after {
  background-image: var(--ag-icon-image-column-arrow, var(--ag-icon-image));
  display: var(--ag-icon-image-display-column-arrow, var(--ag-icon-image-display));
  opacity: var(--ag-icon-image-opacity-column-arrow, var(--ag-icon-image-opacity, 0.9));
}
.ag-icon-un-pin {
  font-family: var(--ag-icon-font-family-un-pin, var(--ag-icon-font-family));
  font-weight: var(--ag-icon-font-weight-un-pin, var(--ag-icon-font-weight));
  color: var(--ag-icon-font-color-un-pin, var(--ag-icon-font-color));
}
.ag-icon-un-pin::before {
  content: var(--ag-icon-font-code-un-pin, "\f13b");
  display: var(--ag-icon-font-display-un-pin, var(--ag-icon-font-display));
}
.ag-icon-un-pin::after {
  background-image: var(--ag-icon-image-un-pin, var(--ag-icon-image));
  display: var(--ag-icon-image-display-un-pin, var(--ag-icon-image-display));
  opacity: var(--ag-icon-image-opacity-un-pin, var(--ag-icon-image-opacity, 0.9));
}
.ag-icon-pinned-bottom {
  font-family: var(--ag-icon-font-family-pinned-bottom, var(--ag-icon-font-family));
  font-weight: var(--ag-icon-font-weight-pinned-bottom, var(--ag-icon-font-weight));
  color: var(--ag-icon-font-color-pinned-bottom, var(--ag-icon-font-color));
}
.ag-icon-pinned-bottom::before {
  content: var(--ag-icon-font-code-pinned-bottom, "\f13e");
  display: var(--ag-icon-font-display-pinned-bottom, var(--ag-icon-font-display));
}
.ag-icon-pinned-bottom::after {
  background-image: var(--ag-icon-image-pinned-bottom, var(--ag-icon-image));
  display: var(--ag-icon-image-display-pinned-bottom, var(--ag-icon-image-display));
  opacity: var(--ag-icon-image-opacity-pinned-bottom, var(--ag-icon-image-opacity, 0.9));
}
.ag-icon-pinned-top {
  font-family: var(--ag-icon-font-family-pinned-top, var(--ag-icon-font-family));
  font-weight: var(--ag-icon-font-weight-pinned-top, var(--ag-icon-font-weight));
  color: var(--ag-icon-font-color-pinned-top, var(--ag-icon-font-color));
}
.ag-icon-pinned-top::before {
  content: var(--ag-icon-font-code-pinned-top, "\f13f");
  display: var(--ag-icon-font-display-pinned-top, var(--ag-icon-font-display));
}
.ag-icon-pinned-top::after {
  background-image: var(--ag-icon-image-pinned-top, var(--ag-icon-image));
  display: var(--ag-icon-image-display-pinned-top, var(--ag-icon-image-display));
  opacity: var(--ag-icon-image-opacity-pinned-top, var(--ag-icon-image-opacity, 0.9));
}
.ag-icon-chevron-up {
  font-family: var(--ag-icon-font-family-chevron-up, var(--ag-icon-font-family));
  font-weight: var(--ag-icon-font-weight-chevron-up, var(--ag-icon-font-weight));
  color: var(--ag-icon-font-color-chevron-up, var(--ag-icon-font-color));
}
.ag-icon-chevron-up::before {
  content: var(--ag-icon-font-code-chevron-up, "\f140");
  display: var(--ag-icon-font-display-chevron-up, var(--ag-icon-font-display));
}
.ag-icon-chevron-up::after {
  background-image: var(--ag-icon-image-chevron-up, var(--ag-icon-image));
  display: var(--ag-icon-image-display-chevron-up, var(--ag-icon-image-display));
  opacity: var(--ag-icon-image-opacity-chevron-up, var(--ag-icon-image-opacity, 0.9));
}
.ag-icon-chevron-down {
  font-family: var(--ag-icon-font-family-chevron-down, var(--ag-icon-font-family));
  font-weight: var(--ag-icon-font-weight-chevron-down, var(--ag-icon-font-weight));
  color: var(--ag-icon-font-color-chevron-down, var(--ag-icon-font-color));
}
.ag-icon-chevron-down::before {
  content: var(--ag-icon-font-code-chevron-down, "\f141");
  display: var(--ag-icon-font-display-chevron-down, var(--ag-icon-font-display));
}
.ag-icon-chevron-down::after {
  background-image: var(--ag-icon-image-chevron-down, var(--ag-icon-image));
  display: var(--ag-icon-image-display-chevron-down, var(--ag-icon-image-display));
  opacity: var(--ag-icon-image-opacity-chevron-down, var(--ag-icon-image-opacity, 0.9));
}
.ag-icon-chevron-left {
  font-family: var(--ag-icon-font-family-chevron-left, var(--ag-icon-font-family));
  font-weight: var(--ag-icon-font-weight-chevron-left, var(--ag-icon-font-weight));
  color: var(--ag-icon-font-color-chevron-left, var(--ag-icon-font-color));
}
.ag-icon-chevron-left::before {
  content: var(--ag-icon-font-code-chevron-left, "\f142");
  display: var(--ag-icon-font-display-chevron-left, var(--ag-icon-font-display));
}
.ag-icon-chevron-left::after {
  background-image: var(--ag-icon-image-chevron-left, var(--ag-icon-image));
  display: var(--ag-icon-image-display-chevron-left, var(--ag-icon-image-display));
  opacity: var(--ag-icon-image-opacity-chevron-left, var(--ag-icon-image-opacity, 0.9));
}
.ag-icon-chevron-right {
  font-family: var(--ag-icon-font-family-chevron-right, var(--ag-icon-font-family));
  font-weight: var(--ag-icon-font-weight-chevron-right, var(--ag-icon-font-weight));
  color: var(--ag-icon-font-color-chevron-right, var(--ag-icon-font-color));
}
.ag-icon-chevron-right::before {
  content: var(--ag-icon-font-code-chevron-right, "\f143");
  display: var(--ag-icon-font-display-chevron-right, var(--ag-icon-font-display));
}
.ag-icon-chevron-right::after {
  background-image: var(--ag-icon-image-chevron-right, var(--ag-icon-image));
  display: var(--ag-icon-image-display-chevron-right, var(--ag-icon-image-display));
  opacity: var(--ag-icon-image-opacity-chevron-right, var(--ag-icon-image-opacity, 0.9));
}
.ag-icon-filter-add {
  font-family: var(--ag-icon-font-family-filter-add, var(--ag-icon-font-family));
  font-weight: var(--ag-icon-font-weight-filter-add, var(--ag-icon-font-weight));
  color: var(--ag-icon-font-color-filter-add, var(--ag-icon-font-color));
}
.ag-icon-filter-add::before {
  content: var(--ag-icon-font-code-filter-add, "\f144");
  display: var(--ag-icon-font-display-filter-add, var(--ag-icon-font-display));
}
.ag-icon-filter-add::after {
  background-image: var(--ag-icon-image-filter-add, var(--ag-icon-image));
  display: var(--ag-icon-image-display-filter-add, var(--ag-icon-image-display));
  opacity: var(--ag-icon-image-opacity-filter-add, var(--ag-icon-image-opacity, 0.9));
}
.ag-icon-edit {
  font-family: var(--ag-icon-font-family-edit, var(--ag-icon-font-family));
  font-weight: var(--ag-icon-font-weight-edit, var(--ag-icon-font-weight));
  color: var(--ag-icon-font-color-edit, var(--ag-icon-font-color));
}
.ag-icon-edit::before {
  content: var(--ag-icon-font-code-edit, "\f145");
  display: var(--ag-icon-font-display-edit, var(--ag-icon-font-display));
}
.ag-icon-edit::after {
  background-image: var(--ag-icon-image-edit, var(--ag-icon-image));
  display: var(--ag-icon-image-display-edit, var(--ag-icon-image-display));
  opacity: var(--ag-icon-image-opacity-edit, var(--ag-icon-image-opacity, 0.9));
}
.ag-icon-row-drag::before {
  content: var(--ag-icon-font-code-grip);
}
.ag-left-arrow::before {
  content: var(--ag-icon-font-code-left);
}
.ag-right-arrow::before {
  content: var(--ag-icon-font-code-right);
}
[class*=ag-theme-] {
  --ag-foreground-color: #000;
  --ag-data-color: var(--ag-foreground-color);
  --ag-secondary-foreground-color: var(--ag-foreground-color);
  --ag-header-foreground-color: var(--ag-secondary-foreground-color);
  --ag-disabled-foreground-color: rgba(0, 0, 0, 0.5);
  --ag-background-color: #fff;
  --ag-header-background-color: transparent;
  --ag-tooltip-background-color: transparent;
  --ag-tooltip-error-background-color: color-mix(
      in srgb,
      var(--ag-background-color),
      var(--ag-invalid-color) 10%
  );
  --ag-tooltip-error-text-color: var(--ag-invalid-color);
  --ag-tooltip-error-border-color: color-mix(in srgb, var(--ag-background-color), var(--ag-invalid-color) 25%);
  --ag-subheader-background-color: transparent;
  --ag-subheader-toolbar-background-color: transparent;
  --ag-control-panel-background-color: transparent;
  --ag-side-button-selected-background-color: var(--ag-control-panel-background-color);
  --ag-selected-row-background-color: #bbb;
  --ag-data-background-color: var(--ag-background-color);
  --ag-odd-row-background-color: var(--ag-data-background-color);
  --ag-modal-overlay-background-color: rgba(255, 255, 255, 0.66);
  --ag-menu-background-color: var(--ag-background-color);
  --ag-menu-border-color: var(--ag-border-color);
  --ag-panel-background-color: var(--ag-background-color);
  --ag-panel-border-color: var(--ag-border-color);
  --ag-row-hover-color: transparent;
  --ag-column-hover-color: transparent;
  --ag-range-selection-border-color: var(--ag-foreground-color);
  --ag-row-drag-indicator-color: var(--ag-range-selection-border-color);
  --ag-row-drag-indicator-width: 2px;
  --ag-column-drag-indicator-color: var(--ag-range-selection-border-color);
  --ag-column-drag-indicator-width: 2px;
  --ag-range-selection-border-style: solid;
  --ag-range-selection-background-color: rgba(0, 0, 0, 0.2);
  --ag-range-selection-background-color-2: var(--ag-range-selection-background-color);
  --ag-range-selection-background-color-3: var(--ag-range-selection-background-color);
  --ag-range-selection-background-color-4: var(--ag-range-selection-background-color);
  --ag-range-selection-highlight-color: var(--ag-range-selection-border-color);
  --ag-range-header-highlight-color: color-mix(
      in srgb,
      var(--ag-header-background-color),
      var(--ag-foreground-color) 8%
  );
  --ag-selected-tab-underline-color: var(--ag-range-selection-border-color);
  --ag-selected-tab-underline-width: 0;
  --ag-selected-tab-underline-transition-speed: 0s;
  --ag-range-selection-chart-category-background-color: rgba(0, 255, 132, 0.1);
  --ag-range-selection-chart-background-color: rgba(0, 88, 255, 0.1);
  --ag-header-cell-hover-background-color: transparent;
  --ag-header-cell-moving-background-color: var(--ag-background-color);
  --ag-value-change-value-highlight-background-color: rgba(22, 160, 133, 0.5);
  --ag-value-change-delta-up-color: #43a047;
  --ag-value-change-delta-down-color: #e53935;
  --ag-row-loading-skeleton-effect-color: rgba(66, 66, 66, 0.2);
  --ag-chip-background-color: transparent;
  --ag-chip-border-color: var(--ag-chip-background-color);
  --ag-borders: solid 1px;
  --ag-border-color: rgba(0, 0, 0, 0.25);
  --ag-borders-critical: var(--ag-borders);
  --ag-borders-secondary: var(--ag-borders);
  --ag-secondary-border-color: var(--ag-border-color);
  --ag-row-border-style: solid;
  --ag-row-border-width: 1px;
  --ag-cell-horizontal-border: solid transparent;
  --ag-borders-input: var(--ag-borders-secondary);
  --ag-input-border-color: var(--ag-secondary-border-color);
  --ag-borders-input-invalid: solid 2px;
  --ag-input-border-color-invalid: var(--ag-invalid-color);
  --ag-full-row-invalid-background-color: color-mix(
      in srgb,
      var(--ag-background-color),
      var(--ag-invalid-color) 25%
  );
  --ag-borders-side-button: var(--ag-borders);
  --ag-border-radius: 0px;
  --ag-wrapper-border-radius: var(--ag-border-radius);
  --ag-row-border-color: var(--ag-secondary-border-color);
  --ag-header-column-separator-display: none;
  --ag-header-column-separator-height: 100%;
  --ag-header-column-separator-width: 1px;
  --ag-header-column-separator-color: var(--ag-secondary-border-color);
  --ag-header-column-resize-handle-display: none;
  --ag-header-column-resize-handle-height: 50%;
  --ag-header-column-resize-handle-width: 1px;
  --ag-header-column-resize-handle-color: var(--ag-secondary-border-color);
  --ag-invalid-color: red;
  --ag-input-disabled-border-color: var(--ag-input-border-color);
  --ag-input-disabled-background-color: transparent;
  --ag-checkbox-background-color: transparent;
  --ag-checkbox-border-radius: var(--ag-border-radius);
  --ag-checkbox-checked-color: var(--ag-foreground-color);
  --ag-checkbox-unchecked-color: var(--ag-foreground-color);
  --ag-checkbox-indeterminate-color: var(--ag-checkbox-unchecked-color);
  --ag-toggle-button-off-border-color: var(--ag-checkbox-unchecked-color);
  --ag-toggle-button-off-background-color: var(--ag-checkbox-unchecked-color);
  --ag-toggle-button-on-border-color: var(--ag-checkbox-checked-color);
  --ag-toggle-button-on-background-color: var(--ag-checkbox-checked-color);
  --ag-toggle-button-switch-background-color: var(--ag-background-color);
  --ag-toggle-button-switch-border-color: var(--ag-toggle-button-off-border-color);
  --ag-toggle-button-border-width: 1px;
  --ag-toggle-button-height: var(--ag-icon-size);
  --ag-toggle-button-width: calc(var(--ag-toggle-button-height) * 2);
  --ag-input-focus-box-shadow: none;
  --ag-input-error-focus-box-shadow: none;
  --ag-input-focus-border-color: none;
  --ag-minichart-selected-chart-color: var(--ag-checkbox-checked-color);
  --ag-minichart-selected-page-color: var(--ag-checkbox-checked-color);
  --ag-grid-size: 4px;
  --ag-icon-size: 12px;
  --ag-icon-font-weight: normal;
  --ag-icon-font-color: var(--ag-foreground-color);
  --ag-icon-image-display: block;
  --ag-widget-container-horizontal-padding: calc(var(--ag-grid-size) * 1.5);
  --ag-widget-container-vertical-padding: calc(var(--ag-grid-size) * 1.5);
  --ag-widget-horizontal-spacing: calc(var(--ag-grid-size) * 2);
  --ag-widget-vertical-spacing: var(--ag-grid-size);
  --ag-cell-horizontal-padding: calc(var(--ag-grid-size) * 3);
  --ag-cell-widget-spacing: var(--ag-cell-horizontal-padding);
  --ag-row-height: calc(var(--ag-grid-size) * 6 + 1px);
  --ag-header-height: var(--ag-row-height);
  --ag-pagination-panel-height: var(--ag-header-height);
  --ag-list-item-height: calc(var(--ag-grid-size) * 5);
  --ag-column-select-indent-size: calc(var(--ag-grid-size) + var(--ag-icon-size));
  --ag-set-filter-indent-size: calc(var(--ag-grid-size) + var(--ag-icon-size));
  --ag-advanced-filter-builder-indent-size: calc(var(--ag-grid-size) * 2 + var(--ag-icon-size));
  --ag-row-group-indent-size: calc(var(--ag-cell-widget-spacing) + var(--ag-icon-size));
  --ag-row-numbers-selected-color: #bbb;
  --ag-filter-tool-panel-group-indent: 16px;
  --ag-tab-min-width: 220px;
  --ag-chart-menu-panel-width: var(--ag-tab-min-width);
  --ag-menu-min-width: 181px;
  --ag-side-bar-panel-width: 200px;
  --ag-side-bar-panel-animation-duration: 0s;
  --ag-font-family: "Helvetica Neue", sans-serif;
  --ag-font-size: 14px;
  --ag-card-radius: var(--ag-border-radius);
  --ag-card-shadow: none;
  --ag-popup-shadow: 5px 5px 10px rgba(0, 0, 0, 0.3);
  --ag-advanced-filter-join-pill-color: #f08e8d;
  --ag-advanced-filter-column-pill-color: #a6e194;
  --ag-advanced-filter-option-pill-color: #f3c08b;
  --ag-advanced-filter-value-pill-color: #85c0e4;
  --ag-find-match-color: var(--ag-foreground-color);
  --ag-find-active-match-color: var(--ag-foreground-color);
  --ag-find-match-background-color: #ffff00;
  --ag-find-active-match-background-color: #ffa500;
  --ag-cell-batch-edit-background-color: rgb(220 181 139 / 16%);
  --ag-cell-batch-edit-text-color: #422f00;
  --ag-row-batch-edit-background-color: var(--ag-cell-batch-edit-background-color);
  --ag-row-batch-edit-text-color: var(--ag-cell-batch-edit-text-color);
  --ag-filter-panel-apply-button-color: var(--ag-foreground-color);
  --ag-filter-panel-apply-button-background-color: var(--ag-background-color);
  --ag-column-panel-apply-button-color: var(--ag-foreground-color);
  --ag-column-panel-apply-button-background-color: var(--ag-background-color);
  --ag-filter-panel-card-subtle-color: var(--ag-foreground-color);
  --ag-filter-panel-card-subtle-hover-color: var(--ag-foreground-color);
  --ag-formula-token-1-color: #3269c6;
  --ag-formula-token-1-background-color: rgb(50 105 198 / 16%);
  --ag-formula-token-1-border-color: var(--ag-formula-token-1-color);
  --ag-formula-token-2-color: #c0343f;
  --ag-formula-token-2-background-color: rgb(192 52 63 / 16%);
  --ag-formula-token-2-border-color: var(--ag-formula-token-2-color);
  --ag-formula-token-3-color: #8156b8;
  --ag-formula-token-3-background-color: rgb(129 86 184 / 16%);
  --ag-formula-token-3-border-color: var(--ag-formula-token-3-color);
  --ag-formula-token-4-color: #007c1f;
  --ag-formula-token-4-background-color: rgb(0 124 31 / 16%);
  --ag-formula-token-4-border-color: var(--ag-formula-token-4-color);
  --ag-formula-token-5-color: #b03e85;
  --ag-formula-token-5-background-color: rgb(176 62 133 / 16%);
  --ag-formula-token-5-border-color: var(--ag-formula-token-5-color);
  --ag-formula-token-6-color: #b74900;
  --ag-formula-token-6-background-color: rgb(183 73 0 / 16%);
  --ag-formula-token-6-border-color: var(--ag-formula-token-6-color);
  --ag-formula-token-7-color: #247492;
  --ag-formula-token-7-background-color: rgb(36 116 146 / 16%);
  --ag-formula-token-7-border-color: var(--ag-formula-token-7-color);
}
.ag-root-wrapper, .ag-dnd-ghost {
  background-color: var(--ag-background-color);
}
.ag-sticky-top, .ag-sticky-bottom {
  background-color: var(--ag-data-background-color);
}
.ag-sticky-bottom .ag-pinned-left-sticky-bottom, .ag-sticky-bottom .ag-sticky-bottom-container, .ag-sticky-bottom .ag-pinned-right-sticky-bottom {
  border-top: var(--ag-row-border-style) var(--ag-row-border-color) var(--ag-row-border-width);
}
.ag-root-wrapper, .ag-popup {
  --ag-indentation-level: 0;
}
[class*=ag-theme-] {
  -webkit-font-smoothing: antialiased;
  font-family: var(--ag-font-family);
  font-size: var(--ag-font-size);
  line-height: normal;
  color: var(--ag-foreground-color);
}
ag-grid, ag-grid-angular, ag-grid-ng2, ag-grid-polymer, ag-grid-aurelia {
  display: block;
}
.ag-aria-description-container {
  z-index: 9999;
  border: 0px;
  clip: rect(1px, 1px, 1px, 1px);
  height: 1px;
  width: 1px;
  position: absolute;
  overflow: hidden;
  padding: 0px;
  white-space: nowrap;
}
.ag-hidden {
  display: none !important;
}
.ag-invisible {
  visibility: hidden !important;
}
.ag-drag-handle {
  cursor: grab;
}
.ag-column-drop-wrapper {
  display: flex;
}
.ag-column-drop-horizontal-half-width {
  display: inline-block;
  width: 50% !important;
}
.ag-unselectable {
  -moz-user-select: none;
  -webkit-user-select: none;
  -ms-user-select: none;
  user-select: none;
}
.ag-selectable {
  -moz-user-select: text;
  -webkit-user-select: text;
  -ms-user-select: text;
  user-select: text;
}
.ag-tab {
  position: relative;
}
.ag-tab-guard {
  position: absolute;
  width: 0;
  height: 0;
  display: block;
}
.ag-virtual-list-viewport .ag-tab-guard {
  position: sticky;
}
.ag-tab-guard-top {
  top: 1px;
}
.ag-tab-guard-bottom {
  bottom: 1px;
}
.ag-select-agg-func-popup {
  position: absolute;
}
.ag-input-wrapper, .ag-picker-field-wrapper {
  display: flex;
  flex: 1 1 auto;
  align-items: center;
  line-height: normal;
  position: relative;
}
.ag-shake-left-to-right {
  animation-direction: alternate;
  animation-duration: 0.2s;
  animation-iteration-count: infinite;
  animation-name: ag-shake-left-to-right;
}
@keyframes ag-shake-left-to-right {
  from {
    padding-left: 6px;
    padding-right: 2px;
  }
  to {
    padding-left: 2px;
    padding-right: 6px;
  }
}
.ag-root-wrapper {
  cursor: default;
  position: relative;
  display: flex;
  flex-direction: column;
  overflow: hidden;
  white-space: normal;
}
.ag-root-wrapper.ag-layout-normal {
  height: 100%;
}
.ag-watermark {
  position: absolute;
  bottom: 20px;
  right: 25px;
  opacity: 0.7;
  transition: opacity 1s ease-out 3s;
  color: #9b9b9b;
}
.ag-watermark::before {
  content: "";
  background-image: url(data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iMjA5IiBoZWlnaHQ9IjM2IiB2aWV3Qm94PSIwIDAgMjA5IDM2IiBmaWxsPSJub25lIiB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciPgo8cGF0aCBkPSJNMTkyLjk5MyAyMy42NTgyVjE1LjcxMTdIMTc5LjQ1MkwxNzEuNTA1IDIzLjY1ODJIMTkyLjk5M1oiIGZpbGw9IiM5QjlCOUIiLz4KPHBhdGggZD0iTTIwOC4yNSAzLjk1MDgxSDE5MS4yNzZMMTgzLjI2NiAxMS44OTczSDIwOC4yNVYzLjk1MDgxWiIgZmlsbD0iIzlCOUI5QiIvPgo8cGF0aCBkPSJNMTYzLjYyMiAzMS42MDQ4TDE2Ny42OTEgMjcuNTM2MUgxODEuNDIzVjM1LjQ4MjdIMTYzLjYyMlYzMS42MDQ4WiIgZmlsbD0iIzlCOUI5QiIvPgo8cGF0aCBkPSJNMTY2LjYxIDE5Ljc4MDNIMTc1LjM4M0wxODMuMzkzIDExLjgzMzdIMTY2LjYxVjE5Ljc4MDNaIiBmaWxsPSIjOUI5QjlCIi8+CjxwYXRoIGQ9Ik0xNTcuMDExIDMxLjYwNDdIMTYzLjYyMkwxNzEuNTA1IDIzLjY1ODJIMTU3LjAxMVYzMS42MDQ3WiIgZmlsbD0iIzlCOUI5QiIvPgo8cGF0aCBkPSJNMTkxLjI3NiAzLjk1MDgxTDE4Ny4yMDggOC4wMTk0MUgxNjEuMjdWMC4wNzI4NzZIMTkxLjI3NlYzLjk1MDgxWiIgZmlsbD0iIzlCOUI5QiIvPgo8cGF0aCBkPSJNMjAuODM5MSAzMC4yMDYxSDguMzc4OTJMNi4yMTc0NSAzNS41NDYySDAuNzUwMjQ0TDEyLjI1NjggOC41OTE1NUgxNy4wMjQ3TDI4LjUzMTMgMzUuNTQ2MkgyMy4wMDA1TDIwLjgzOTEgMzAuMjA2MVpNMTkuMTIyNyAyNS45NDY4TDE0LjYwOSAxNC45NDg4TDEwLjA5NTQgMjUuOTQ2OEgxOS4xMjI3WiIgZmlsbD0iIzlCOUI5QiIvPgo8cGF0aCBkPSJNMTA0LjQzNyAxOC41MDg5QzEwNi4wMjYgMTYuMTU2NyAxMTAuMDMxIDE1LjkwMjQgMTExLjY4NCAxNS45MDI0VjIwLjQ3OTZDMTA5LjY1IDIwLjQ3OTYgMTA3LjYxNSAyMC41NDMyIDEwNi40MDcgMjEuNDMzMkMxMDUuMiAyMi4zMjMyIDEwNC41NjQgMjMuNTMxMSAxMDQuNTY0IDI0Ljk5MzJWMzUuNTQ2Mkg5OS42MDUxVjE1LjkwMjRIMTA0LjM3M0wxMDQuNDM3IDE4LjUwODlaIiBmaWxsPSIjOUI5QjlCIi8+CjxwYXRoIGQ9Ik0xMTkuMzc2IDE1LjkwMjRIMTE0LjQxOFYzNS41NDYySDExOS4zNzZWMTUuOTAyNFoiIGZpbGw9IiM5QjlCOUIiLz4KPHBhdGggZD0iTTExOS4zNzYgNy4xMjkzOUgxMTQuNDE4VjEyLjk3OEgxMTkuMzc2VjcuMTI5MzlaIiBmaWxsPSIjOUI5QjlCIi8+CjxwYXRoIGQ9Ik0xNDMuOTc5IDcuMTI5MzlWMzUuNTQ2MkgxMzkuMjExTDEzOS4wODQgMzIuNTU4M0MxMzguMzg0IDMzLjU3NTUgMTM3LjQ5NCAzNC40MDE5IDEzNi40MTQgMzUuMDM3NkMxMzUuMzMzIDM1LjYwOTggMTMzLjk5OCAzNS45Mjc2IDEzMi40NzIgMzUuOTI3NkMxMzEuMTM3IDM1LjkyNzYgMTI5Ljg2NiAzNS42NzMzIDEyOC43ODUgMzUuMjI4M0MxMjcuNjQxIDM0LjcxOTcgMTI2LjYyMyAzNC4wODQgMTI1Ljc5NyAzMy4xOTRDMTI0Ljk3MSAzMi4zMDQgMTI0LjI3MSAzMS4yMjMzIDEyMy44MjYgMzAuMDE1NEMxMjMuMzE4IDI4LjgwNzUgMTIzLjEyNyAyNy40MDkgMTIzLjEyNyAyNS44ODMyQzEyMy4xMjcgMjQuMzU3NSAxMjMuMzgxIDIyLjk1ODkgMTIzLjgyNiAyMS42ODc0QzEyNC4zMzUgMjAuNDE2IDEyNC45NzEgMTkuMzM1MyAxMjUuNzk3IDE4LjQ0NTNDMTI2LjYyMyAxNy41NTUyIDEyNy42NDEgMTYuODU2IDEyOC43ODUgMTYuMzQ3NEMxMjkuOTI5IDE1LjgzODggMTMxLjEzNyAxNS41ODQ1IDEzMi40NzIgMTUuNTg0NUMxMzMuOTk4IDE1LjU4NDUgMTM1LjI2OSAxNS44Mzg4IDEzNi4zNSAxNi40MTA5QzEzNy40MzEgMTYuOTgzMSAxMzguMzIxIDE3Ljc0NTkgMTM5LjAyIDE4LjgyNjdWNy4xOTI5NUgxNDMuOTc5VjcuMTI5MzlaTTEzMy41NTMgMzEuNjY4M0MxMzUuMjA2IDMxLjY2ODMgMTM2LjQ3NyAzMS4wOTYyIDEzNy40OTQgMzAuMDE1NEMxMzguNTExIDI4LjkzNDcgMTM5LjAyIDI3LjQ3MjUgMTM5LjAyIDI1LjY5MjVDMTM5LjAyIDIzLjkxMjUgMTM4LjUxMSAyMi41MTM5IDEzNy40OTQgMjEuMzY5NkMxMzYuNDc3IDIwLjI4ODggMTM1LjIwNiAxOS43MTY3IDEzMy41NTMgMTkuNzE2N0MxMzEuOTYzIDE5LjcxNjcgMTMwLjYyOCAyMC4yODg4IDEyOS42NzUgMjEuMzY5NkMxMjguNjU4IDIyLjQ1MDMgMTI4LjE0OSAyMy45MTI1IDEyOC4xNDkgMjUuNjkyNUMxMjguMTQ5IDI3LjQ3MjUgMTI4LjY1OCAyOC44NzExIDEyOS42NzUgMjkuOTUxOEMxMzAuNjkyIDMxLjA5NjEgMTMxLjk2MyAzMS42NjgzIDEzMy41NTMgMzEuNjY4M1oiIGZpbGw9IiM5QjlCOUIiLz4KPHBhdGggZD0iTTU3LjIwMjQgMjAuMzUyNUg0NC45MzNWMjQuNjExOEg1MS45MjU5QzUxLjczNTIgMjYuNzczMyA1MC45MDg4IDI4LjQyNjEgNDkuNTEwMiAyOS43NjExQzQ4LjExMTYgMzEuMDMyNiA0Ni4zMzE1IDMxLjY2ODMgNDQuMDQyOSAzMS42NjgzQzQyLjc3MTUgMzEuNjY4MyA0MS41NjM2IDMxLjQxNCA0MC41NDY1IDMwLjk2OUMzOS40NjU3IDMwLjUyNCAzOC41NzU3IDI5Ljg4ODMgMzcuODEyOSAyOC45OTgzQzM3LjA1IDI4LjE3MTggMzYuNDc3OCAyNy4xNTQ3IDM2LjAzMjggMjUuOTQ2OEMzNS41ODc4IDI0LjczODkgMzUuMzk3MSAyMy40Njc1IDM1LjM5NzEgMjIuMDA1M0MzNS4zOTcxIDIwLjU0MzIgMzUuNTg3OCAxOS4yNzE3IDM2LjAzMjggMTguMDYzOEMzNi40MTQzIDE2Ljg1NiAzNy4wNSAxNS45MDI0IDM3LjgxMjkgMTUuMDEyNEMzOC41NzU3IDE0LjE4NTkgMzkuNDY1NyAxMy41NTAyIDQwLjU0NjUgMTMuMDQxNkM0MS42MjcyIDEyLjU5NjYgNDIuNzcxNSAxMi4zNDIzIDQ0LjEwNjUgMTIuMzQyM0M0Ni43NzY2IDEyLjM0MjMgNDguODEwOSAxMi45NzggNTAuMjA5NSAxNC4yNDk1TDUzLjUxNTIgMTAuOTQzOEM1MS4wMzU5IDkuMDM2NTkgNDcuODU3MyA4LjAxOTQxIDQ0LjEwNjUgOC4wMTk0MUM0Mi4wMDg2IDguMDE5NDEgNDAuMTAxNSA4LjMzNzI5IDM4LjM4NSA5LjAzNjU5QzM2LjY2ODYgOS43MzU4OCAzNS4yMDY0IDEwLjYyNTkgMzMuOTk4NSAxMS44MzM3QzMyLjc5MDYgMTMuMDQxNiAzMS44MzcxIDE0LjUwMzggMzEuMjAxNCAxNi4yMjAzQzMwLjU2NTYgMTcuOTM2NyAzMC4yNDc4IDE5Ljg0MzggMzAuMjQ3OCAyMS44NzgyQzMwLjI0NzggMjMuOTEyNSAzMC41NjU2IDI1LjgxOTcgMzEuMjY0OSAyNy41MzYxQzMxLjk2NDIgMjkuMjUyNiAzMi44NTQyIDMwLjcxNDcgMzQuMDYyMSAzMS45MjI2QzM1LjI3IDMzLjEzMDUgMzYuNzMyMSAzNC4wODQxIDM4LjQ0ODYgMzQuNzE5OEM0MC4xNjUgMzUuNDE5MSA0Mi4wNzIyIDM1LjczNyA0NC4xMDY1IDM1LjczN0M0Ni4xNDA4IDM1LjczNyA0Ny45ODQ0IDM1LjQxOTEgNDkuNjM3MyAzNC43MTk4QzUxLjI5MDIgMzQuMDIwNSA1Mi42ODg4IDMzLjEzMDUgNTMuODMzMSAzMS45MjI2QzU0Ljk3NzQgMzAuNzE0NyA1NS44Njc0IDI5LjI1MjYgNTYuNTAzMSAyNy41MzYxQzU3LjEzODggMjUuODE5NyA1Ny40NTY3IDIzLjkxMjUgNTcuNDU2NyAyMS44NzgyVjIxLjA1MTdDNTcuMjY2IDIwLjkyNDYgNTcuMjAyNCAyMC42MDY3IDU3LjIwMjQgMjAuMzUyNVoiIGZpbGw9IiM5QjlCOUIiLz4KPHBhdGggZD0iTTk1Ljk4MTUgMjAuMzUyNUg4My43MTIxVjI0LjYxMThIOTAuNzA1QzkwLjUxNDMgMjYuNzczMyA4OS42ODc5IDI4LjQyNjEgODguMjg5MyAyOS43NjExQzg2Ljg5MDcgMzEuMDMyNiA4NS4xMTA2IDMxLjY2ODMgODIuODIyIDMxLjY2ODNDODEuNTUwNiAzMS42NjgzIDgwLjM0MjcgMzEuNDE0IDc5LjMyNTYgMzAuOTY5Qzc4LjI0NDggMzAuNTI0IDc3LjM1NDggMjkuODg4MyA3Ni41OTIgMjguOTk4M0M3NS44MjkxIDI4LjE3MTggNzUuMjU3IDI3LjE1NDcgNzQuODExOSAyNS45NDY4Qzc0LjM2NjkgMjQuNzM4OSA3NC4xNzYyIDIzLjQ2NzUgNzQuMTc2MiAyMi4wMDUzQzc0LjE3NjIgMjAuNTQzMiA3NC4zNjY5IDE5LjI3MTcgNzQuODExOSAxOC4wNjM4Qzc1LjE5MzQgMTYuODU2IDc1LjgyOTEgMTUuOTAyNCA3Ni41OTIgMTUuMDEyNEM3Ny4zNTQ4IDE0LjE4NTkgNzguMjQ0OCAxMy41NTAyIDc5LjMyNTYgMTMuMDQxNkM4MC40MDYzIDEyLjU5NjYgODEuNTUwNiAxMi4zNDIzIDgyLjg4NTYgMTIuMzQyM0M4NS41NTU3IDEyLjM0MjMgODcuNTkgMTIuOTc4IDg4Ljk4ODYgMTQuMjQ5NUw5Mi4yOTQzIDEwLjk0MzhDODkuODE1IDkuMDM2NTkgODYuNjM2NCA4LjAxOTQxIDgyLjg4NTYgOC4wMTk0MUM4MC43ODc4IDguMDE5NDEgNzguODgwNiA4LjMzNzI5IDc3LjE2NDEgOS4wMzY1OUM3NS40NDc3IDkuNzM1ODggNzMuOTg1NSAxMC42MjU5IDcyLjc3NzYgMTEuODMzN0M3MS41Njk4IDEzLjA0MTYgNzAuNjE2MiAxNC41MDM4IDY5Ljk4MDUgMTYuMjIwM0M2OS4zNDQ3IDE3LjkzNjcgNjkuMDI2OSAxOS44NDM4IDY5LjAyNjkgMjEuODc4MkM2OS4wMjY5IDIzLjkxMjUgNjkuMzQ0NyAyNS44MTk3IDcwLjA0NCAyNy41MzYxQzcwLjc0MzMgMjkuMjUyNiA3MS42MzM0IDMwLjcxNDcgNzIuODQxMiAzMS45MjI2Qzc0LjA0OTEgMzMuMTMwNSA3NS41MTEyIDM0LjA4NDEgNzcuMjI3NyAzNC43MTk4Qzc4Ljk0NDEgMzUuNDE5MSA4MC44NTEzIDM1LjczNyA4Mi44ODU2IDM1LjczN0M4NC45MiAzNS43MzcgODYuNzYzNiAzNS40MTkxIDg4LjQxNjQgMzQuNzE5OEM5MC4wNjkzIDM0LjAyMDUgOTEuNDY3OSAzMy4xMzA1IDkyLjYxMjIgMzEuOTIyNkM5My43NTY1IDMwLjcxNDcgOTQuNjQ2NSAyOS4yNTI2IDk1LjI4MjIgMjcuNTM2MUM5NS45MTggMjUuODE5NyA5Ni4yMzU4IDIzLjkxMjUgOTYuMjM1OCAyMS44NzgyVjIxLjA1MTdDOTYuMDQ1MSAyMC45MjQ2IDk1Ljk4MTUgMjAuNjA2NyA5NS45ODE1IDIwLjM1MjVaIiBmaWxsPSIjOUI5QjlCIi8+Cjwvc3ZnPgo=);
  background-repeat: no-repeat;
  background-size: 170px 40px;
  display: block;
  height: 40px;
  width: 170px;
}
.ag-watermark-text {
  opacity: 0.5;
  font-weight: bold;
  font-family: Impact, sans-serif;
  font-size: 19px;
  padding-left: 0.7rem;
}
.ag-root-wrapper-body {
  display: flex;
  flex-direction: row;
}
.ag-root-wrapper-body.ag-layout-normal {
  flex: 1 1 auto;
  height: 0;
  min-height: 0;
}
.ag-root {
  position: relative;
  display: flex;
  flex-direction: column;
}
.ag-root.ag-layout-normal, .ag-root.ag-layout-auto-height {
  overflow: hidden;
  flex: 1 1 auto;
  width: 0;
}
.ag-root.ag-layout-normal {
  height: 100%;
}
.ag-header-viewport, .ag-floating-top-viewport, .ag-body-viewport, .ag-center-cols-viewport, .ag-floating-bottom-viewport, .ag-body-horizontal-scroll-viewport, .ag-body-vertical-scroll-viewport, .ag-virtual-list-viewport, .ag-sticky-top-viewport, .ag-sticky-bottom-viewport {
  position: relative;
  height: 100%;
  min-width: 0px;
  overflow: hidden;
  flex: 1 1 auto;
}
.ag-body-viewport, .ag-center-cols-viewport, .ag-header-viewport, .ag-floating-top-viewport, .ag-floating-bottom-viewport, .ag-sticky-top-viewport, .ag-sticky-bottom-viewport {
  overflow-x: auto;
  -ms-overflow-style: none !important;
  scrollbar-width: none !important;
}
.ag-body-viewport::-webkit-scrollbar, .ag-center-cols-viewport::-webkit-scrollbar, .ag-header-viewport::-webkit-scrollbar, .ag-floating-top-viewport::-webkit-scrollbar, .ag-floating-bottom-viewport::-webkit-scrollbar, .ag-sticky-top-viewport::-webkit-scrollbar, .ag-sticky-bottom-viewport::-webkit-scrollbar {
  display: none !important;
}
.ag-body-viewport {
  display: flex;
  overflow-x: hidden;
}
.ag-body-viewport.ag-layout-normal {
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
}
.ag-viewport {
  position: relative;
}
.ag-spanning-container {
  position: absolute;
  top: 0;
  z-index: 1;
}
.ag-sticky-top-container, .ag-sticky-bottom-container, .ag-floating-top-container, .ag-floating-bottom-container {
  min-height: 1px;
}
.ag-sticky-top, .ag-sticky-bottom {
  z-index: 1;
}
.ag-center-cols-viewport {
  min-height: 100%;
  width: 100%;
}
.ag-body-horizontal-scroll-viewport {
  overflow-x: scroll;
}
.ag-body-vertical-scroll-viewport {
  overflow-y: scroll;
}
.ag-virtual-list-viewport {
  overflow: auto;
  width: 100%;
}
.ag-header-container, .ag-floating-top-container, .ag-body-container, .ag-pinned-right-cols-container, .ag-center-cols-container, .ag-pinned-left-cols-container, .ag-floating-bottom-container, .ag-body-horizontal-scroll-container, .ag-body-vertical-scroll-container, .ag-full-width-container, .ag-floating-bottom-full-width-container, .ag-virtual-list-container, .ag-sticky-top-container, .ag-sticky-bottom-container, .ag-pinned-left-sticky-bottom, .ag-pinned-right-sticky-bottom {
  position: relative;
}
.ag-header-container, .ag-floating-top-container, .ag-pinned-left-floating-top, .ag-pinned-right-floating-top, .ag-floating-bottom-container, .ag-pinned-left-floating-bottom, .ag-pinned-right-floating-bottom, .ag-sticky-top-container, .ag-sticky-bottom-container {
  height: 100%;
  white-space: nowrap;
}
.ag-center-cols-container {
  display: block;
}
.ag-pinned-right-cols-container {
  display: block;
}
.ag-body-horizontal-scroll-container {
  height: 100%;
}
.ag-body-vertical-scroll-container {
  width: 100%;
}
.ag-full-width-container, .ag-floating-top-full-width-container, .ag-floating-bottom-full-width-container, .ag-sticky-top-full-width-container, .ag-sticky-bottom-full-width-container {
  position: absolute;
  top: 0px;
  pointer-events: none;
}
.ag-ltr .ag-full-width-container, .ag-ltr .ag-floating-top-full-width-container, .ag-ltr .ag-floating-bottom-full-width-container, .ag-ltr .ag-sticky-top-full-width-container, .ag-ltr .ag-sticky-bottom-full-width-container {
  left: 0;
}
.ag-rtl .ag-full-width-container, .ag-rtl .ag-floating-top-full-width-container, .ag-rtl .ag-floating-bottom-full-width-container, .ag-rtl .ag-sticky-top-full-width-container, .ag-rtl .ag-sticky-bottom-full-width-container {
  right: 0;
}
.ag-full-width-container {
  width: 100%;
}
.ag-floating-bottom-full-width-container, .ag-floating-top-full-width-container {
  display: inline-block;
  overflow: hidden;
  height: 100%;
  width: 100%;
}
.ag-virtual-list-container {
  overflow: hidden;
}
.ag-body {
  position: relative;
  display: flex;
  flex: 1 1 auto;
  flex-direction: row !important;
  min-height: 0;
}
.ag-body-horizontal-scroll, .ag-body-vertical-scroll {
  min-height: 0;
  min-width: 0;
  display: flex;
  position: relative;
}
.ag-body-horizontal-scroll.ag-scrollbar-invisible, .ag-body-vertical-scroll.ag-scrollbar-invisible {
  position: absolute;
  bottom: 0;
}
.ag-body-horizontal-scroll.ag-scrollbar-invisible.ag-apple-scrollbar, .ag-body-vertical-scroll.ag-scrollbar-invisible.ag-apple-scrollbar {
  opacity: 0;
  transition: opacity 400ms;
  visibility: hidden;
}
.ag-body-horizontal-scroll.ag-scrollbar-invisible.ag-apple-scrollbar.ag-scrollbar-scrolling, .ag-body-horizontal-scroll.ag-scrollbar-invisible.ag-apple-scrollbar.ag-scrollbar-active, .ag-body-vertical-scroll.ag-scrollbar-invisible.ag-apple-scrollbar.ag-scrollbar-scrolling, .ag-body-vertical-scroll.ag-scrollbar-invisible.ag-apple-scrollbar.ag-scrollbar-active {
  visibility: visible;
  opacity: 1;
}
.ag-body-horizontal-scroll {
  width: 100%;
}
.ag-body-horizontal-scroll.ag-scrollbar-invisible {
  left: 0;
  right: 0;
}
.ag-body-vertical-scroll {
  height: 100%;
}
.ag-body-vertical-scroll.ag-scrollbar-invisible {
  top: 0;
  z-index: 10;
}
.ag-ltr .ag-body-vertical-scroll.ag-scrollbar-invisible {
  right: 0;
}
.ag-rtl .ag-body-vertical-scroll.ag-scrollbar-invisible {
  left: 0;
}
.ag-force-vertical-scroll {
  overflow-y: scroll !important;
}
.ag-horizontal-left-spacer, .ag-horizontal-right-spacer {
  height: 100%;
  min-width: 0;
  overflow-x: scroll;
}
.ag-horizontal-left-spacer.ag-scroller-corner, .ag-horizontal-right-spacer.ag-scroller-corner {
  overflow-x: hidden;
}
.ag-header, .ag-pinned-left-header, .ag-pinned-right-header {
  display: inline-block;
  overflow: hidden;
  position: relative;
}
.ag-header-cell-sortable .ag-header-cell-label, .ag-header-group-cell-selectable .ag-header-cell-comp-wrapper {
  cursor: pointer;
}
.ag-header {
  display: flex;
  width: 100%;
  white-space: nowrap;
}
.ag-pinned-left-header {
  height: 100%;
}
.ag-pinned-right-header {
  height: 100%;
}
.ag-header-row {
  position: absolute;
}
.ag-header-row:not(.ag-header-row-column-group) {
  overflow: hidden;
}
.ag-header.ag-header-allow-overflow .ag-header-row {
  overflow: visible;
}
.ag-header-cell {
  display: inline-flex;
  align-items: center;
  position: absolute;
  height: 100%;
  overflow: hidden;
}
.ag-header-cell.ag-header-active .ag-header-cell-menu-button, .ag-header-cell-filter-button {
  opacity: 1;
}
.ag-header-cell-menu-button:not(.ag-header-menu-always-show) {
  transition: opacity 0.2s;
  opacity: 0;
}
.ag-header-group-cell-label, .ag-header-cell-label {
  display: flex;
  flex: 1 1 auto;
  align-self: stretch;
  align-items: center;
  overflow: hidden;
}
.ag-header-cell-label {
  text-overflow: ellipsis;
}
.ag-header-group-cell-label.ag-sticky-label {
  position: sticky;
  flex: none;
  max-width: 100%;
  overflow: visible;
}
.ag-header-group-text {
  overflow: hidden;
  text-overflow: ellipsis;
}
.ag-header-cell-text {
  overflow: hidden;
  text-overflow: ellipsis;
  word-break: break-word;
}
.ag-header-group-cell .ag-header-cell-comp-wrapper {
  display: flex;
}
.ag-header-cell:not(.ag-header-cell-auto-height) .ag-header-cell-comp-wrapper {
  height: 100%;
  display: flex;
  align-items: center;
}
.ag-header-cell-comp-wrapper {
  width: 100%;
}
.ag-header-cell-wrap-text .ag-header-cell-comp-wrapper {
  white-space: normal;
}
.ag-header-cell-comp-wrapper-limited-height > div {
  overflow: hidden;
}
.ag-right-aligned-header .ag-header-cell-label {
  flex-direction: row-reverse;
}
.ag-header-cell-resize {
  position: absolute;
  z-index: 2;
  height: 100%;
  width: 8px;
  top: 0;
  cursor: ew-resize;
}
.ag-ltr .ag-header-cell-resize {
  right: -3px;
}
.ag-rtl .ag-header-cell-resize {
  left: -3px;
}
.ag-pinned-left-header .ag-header-cell-resize {
  right: -3px;
}
.ag-pinned-right-header .ag-header-cell-resize {
  left: -3px;
}
.ag-header-select-all {
  display: flex;
}
.ag-header-cell-menu-button, .ag-header-cell-filter-button, .ag-side-button-button, .ag-panel-title-bar-button, .ag-floating-filter-button-button {
  cursor: pointer;
}
.ag-column-moving .ag-cell {
  transition: left 0.2s;
}
.ag-column-moving .ag-header-cell {
  transition: left 0.2s;
}
.ag-column-moving .ag-spanned-cell-wrapper {
  transition: left 0.2s;
}
.ag-column-moving .ag-header-group-cell {
  transition: left 0.2s, width 0.2s;
}
.ag-delay-render .ag-cell {
  visibility: hidden;
}
.ag-delay-render .ag-row {
  visibility: hidden;
}
.ag-delay-render .ag-spanned-cell-wrapper {
  visibility: hidden;
}
.ag-delay-render .ag-header-cell {
  visibility: hidden;
}
.ag-delay-render .ag-header-group-cell {
  visibility: hidden;
}
.ag-column-panel {
  display: flex;
  flex-direction: column;
  overflow: hidden;
  flex: 1 1 auto;
}
.ag-column-select {
  position: relative;
  display: flex;
  flex-direction: column;
  overflow: hidden;
  flex: 3 1 0px;
}
.ag-column-select-header {
  position: relative;
  display: flex;
  flex: none;
}
.ag-column-select-header-icon {
  position: relative;
}
.ag-column-select-header-filter-wrapper {
  flex: 1 1 auto;
}
.ag-column-select-header-filter {
  width: 100%;
}
.ag-column-select-list {
  flex: 1 1 0px;
  overflow: hidden;
}
.ag-column-drop {
  position: relative;
  display: inline-flex;
  align-items: center;
  overflow: auto;
  width: 100%;
}
.ag-column-drop-list {
  display: flex;
  align-items: center;
}
.ag-column-drop-cell {
  position: relative;
  display: flex;
  align-items: center;
}
.ag-column-drop-cell-text {
  overflow: hidden;
  flex: 1 1 auto;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.ag-column-drop-vertical {
  display: flex;
  flex-direction: column;
  overflow: hidden;
  align-items: stretch;
  flex: 1 1 0px;
}
.ag-column-drop-vertical-title-bar {
  display: flex;
  align-items: center;
  flex: none;
}
.ag-column-drop-vertical-list {
  position: relative;
  align-items: stretch;
  flex-grow: 1;
  flex-direction: column;
  overflow-x: auto;
}
.ag-column-drop-vertical-list > * {
  flex: none;
}
.ag-column-drop-empty .ag-column-drop-vertical-list {
  overflow: hidden;
}
.ag-column-drop-vertical-empty-message {
  display: block;
}
.ag-column-drop.ag-column-drop-horizontal {
  white-space: nowrap;
  overflow: hidden;
}
.ag-column-drop-cell-button {
  cursor: pointer;
}
.ag-filter-toolpanel {
  flex: 1 1 0px;
  min-width: 0;
}
.ag-filter-toolpanel-header {
  position: relative;
}
.ag-filter-toolpanel-header, .ag-filter-toolpanel-search {
  display: flex;
  align-items: center;
}
.ag-filter-toolpanel-header > *, .ag-filter-toolpanel-search > * {
  display: flex;
  align-items: center;
}
.ag-filter-apply-panel {
  display: flex;
  justify-content: flex-end;
  overflow: hidden;
}
.ag-row-animation .ag-row {
  transition: transform 0.4s, top 0.4s, opacity 0.2s;
}
.ag-row-animation .ag-row.ag-after-created {
  transition: transform 0.4s, top 0.4s, height 0.4s, opacity 0.2s;
}
.ag-row-animation.ag-prevent-animation .ag-row, .ag-row-animation.ag-prevent-animation .ag-row.ag-after-created {
  transition: none !important;
}
.ag-row-no-animation .ag-row {
  transition: none;
}
.ag-row {
  white-space: nowrap;
  width: 100%;
}
.ag-row-loading {
  display: flex;
  align-items: center;
}
.ag-row-position-absolute {
  position: absolute;
}
.ag-row-position-relative {
  position: relative;
}
.ag-full-width-row {
  overflow: hidden;
  pointer-events: all;
}
.ag-row-inline-editing {
  z-index: 1;
}
.ag-row-dragging {
  z-index: 2;
}
.ag-stub-cell {
  display: flex;
  align-items: center;
}
.ag-cell {
  display: inline-block;
  position: absolute;
  white-space: nowrap;
  height: 100%;
}
.ag-cell-value {
  flex: 1 1 auto;
}
.ag-cell-value:not(.ag-allow-overflow), .ag-group-value {
  overflow: hidden;
  text-overflow: ellipsis;
}
.ag-cell-wrapper {
  display: flex;
  align-items: center;
}
.ag-cell-wrapper.ag-row-group {
  align-items: flex-start;
}
.ag-cell-wrap-text {
  white-space: normal;
  word-break: break-word;
}
.ag-cell-wrap-text:not(.ag-cell-auto-height) .ag-cell-wrapper {
  align-items: normal;
  height: 100%;
}
.ag-cell-wrap-text:not(.ag-cell-auto-height) .ag-cell-wrapper .ag-cell-value {
  height: 100%;
}
.ag-sparkline-wrapper {
  position: absolute;
  height: 100%;
  width: 100%;
  top: 0;
  line-height: initial;
}
.ag-full-width-row .ag-cell-wrapper.ag-row-group {
  height: 100%;
  align-items: center;
}
.ag-cell-inline-editing {
  z-index: 1;
}
.ag-cell-inline-editing .ag-cell-wrapper, .ag-cell-inline-editing .ag-cell-edit-wrapper, .ag-cell-inline-editing .ag-cell-editor, .ag-cell-inline-editing .ag-cell-editor .ag-wrapper, .ag-cell-inline-editing .ag-cell-editor.ag-cell-editor.ag-cell-editor input {
  height: 100%;
  min-height: 100%;
  width: 100%;
  line-height: normal;
}
.ag-row.ag-row-editing-invalid .ag-cell-inline-editing {
  opacity: 0.8;
}
.ag-cell .ag-icon {
  display: inline-block;
  vertical-align: middle;
}
.ag-set-filter-item {
  display: flex;
  align-items: center;
  height: 100%;
}
.ag-set-filter-item-checkbox {
  display: flex;
  width: 100%;
  height: 100%;
}
.ag-set-filter-group-icons {
  display: block;
}
.ag-set-filter-group-icons > * {
  cursor: pointer;
}
.ag-filter-body-wrapper {
  display: flex;
  flex-direction: column;
}
.ag-filter-filter {
  flex: 1 1 0px;
}
.ag-filter-condition {
  display: flex;
  justify-content: center;
}
.ag-floating-filter-body {
  position: relative;
  display: flex;
  flex: 1 1 auto;
  height: 100%;
}
.ag-floating-filter-full-body {
  display: flex;
  flex: 1 1 auto;
  height: 100%;
  width: 100%;
  align-items: center;
  overflow: hidden;
}
.ag-floating-filter-full-body > div {
  flex: 1 1 auto;
}
.ag-floating-filter-input {
  align-items: center;
  display: flex;
  width: 100%;
}
.ag-floating-filter-input > * {
  flex: 1 1 auto;
}
.ag-floating-filter-button {
  display: flex;
  flex: none;
}
.ag-date-floating-filter-wrapper {
  display: flex;
}
.ag-set-floating-filter-input input[disabled] {
  pointer-events: none;
}
.ag-dnd-ghost {
  display: inline-flex;
  align-items: center;
  cursor: move;
  white-space: nowrap;
}
.ag-overlay {
  height: 100%;
  left: 0;
  pointer-events: none;
  position: absolute;
  top: 0;
  width: 100%;
  z-index: 2;
}
.ag-overlay-panel {
  display: flex;
  height: 100%;
  width: 100%;
}
.ag-overlay-wrapper {
  display: flex;
  flex: none;
  width: 100%;
  height: 100%;
  align-items: center;
  justify-content: center;
  text-align: center;
}
.ag-overlay-loading-wrapper, .ag-overlay-exporting-wrapper, .ag-overlay-modal-wrapper {
  pointer-events: all;
}
.ag-popup-child {
  z-index: 5;
  top: 0;
}
.ag-popup-editor {
  position: absolute;
  -moz-user-select: none;
  -webkit-user-select: none;
  -ms-user-select: none;
  user-select: none;
}
.ag-large-text-input {
  display: block;
}
.ag-virtual-list-item {
  position: absolute;
  width: 100%;
}
.ag-floating-top, .ag-floating-bottom {
  overflow: hidden;
  white-space: nowrap;
  width: 100%;
  position: relative;
  display: flex;
}
.ag-pinned-left-floating-top, .ag-pinned-right-floating-top, .ag-pinned-left-floating-bottom, .ag-pinned-right-floating-bottom {
  overflow: hidden;
  position: relative;
  min-width: 0px;
}
.ag-sticky-top, .ag-sticky-bottom {
  position: absolute;
  display: flex;
  width: 100%;
  overflow: hidden;
  height: 0px;
}
.ag-sticky-bottom {
  box-sizing: content-box !important;
}
.ag-sticky-bottom .ag-pinned-left-sticky-bottom, .ag-sticky-bottom .ag-sticky-bottom-container, .ag-sticky-bottom .ag-pinned-right-sticky-bottom {
  box-sizing: border-box;
}
.ag-pinned-left-sticky-top, .ag-pinned-right-sticky-top {
  position: relative;
  height: 100%;
  overflow: hidden;
}
.ag-sticky-top-full-width-container, .ag-sticky-bottom-full-width-container {
  overflow: hidden;
  width: 100%;
  height: 100%;
}
.ag-dialog, .ag-panel {
  display: flex;
  flex-direction: column;
  position: relative;
  overflow: hidden;
}
.ag-panel-title-bar {
  display: flex;
  flex: none;
  align-items: center;
  cursor: default;
}
.ag-panel-title-bar-title {
  flex: 1 1 auto;
}
.ag-panel-title-bar-buttons {
  display: flex;
}
.ag-panel-title-bar-button {
  cursor: pointer;
}
.ag-panel-content-wrapper {
  display: flex;
  flex: 1 1 auto;
  position: relative;
  overflow: hidden;
}
.ag-dialog {
  position: absolute;
}
.ag-resizer {
  position: absolute;
  pointer-events: none;
  z-index: 1;
  -moz-user-select: none;
  -webkit-user-select: none;
  -ms-user-select: none;
  user-select: none;
}
.ag-resizer.ag-resizer-topLeft {
  top: 0;
  left: 0;
  height: 5px;
  width: 5px;
  cursor: nwse-resize;
}
.ag-resizer.ag-resizer-top {
  top: 0;
  left: 5px;
  right: 5px;
  height: 5px;
  cursor: ns-resize;
}
.ag-resizer.ag-resizer-topRight {
  top: 0;
  right: 0;
  height: 5px;
  width: 5px;
  cursor: nesw-resize;
}
.ag-resizer.ag-resizer-right {
  top: 5px;
  right: 0;
  bottom: 5px;
  width: 5px;
  cursor: ew-resize;
}
.ag-resizer.ag-resizer-bottomRight {
  bottom: 0;
  right: 0;
  height: 5px;
  width: 5px;
  cursor: nwse-resize;
}
.ag-resizer.ag-resizer-bottom {
  bottom: 0;
  left: 5px;
  right: 5px;
  height: 5px;
  cursor: ns-resize;
}
.ag-resizer.ag-resizer-bottomLeft {
  bottom: 0;
  left: 0;
  height: 5px;
  width: 5px;
  cursor: nesw-resize;
}
.ag-resizer.ag-resizer-left {
  left: 0;
  top: 5px;
  bottom: 5px;
  width: 5px;
  cursor: ew-resize;
}
.ag-tooltip {
  position: absolute;
  z-index: 99999;
}
.ag-tooltip-custom {
  position: absolute;
  z-index: 99999;
}
.ag-tooltip:not(.ag-tooltip-interactive), .ag-tooltip-custom:not(.ag-tooltip-interactive) {
  pointer-events: none;
}
.ag-value-slide-out {
  margin-right: 5px;
  opacity: 1;
  transition: opacity 3s, margin-right 3s;
  transition-timing-function: linear;
}
.ag-value-slide-out-end {
  margin-right: 10px;
  opacity: 0;
}
.ag-opacity-zero {
  opacity: 0 !important;
}
.ag-menu {
  max-height: 100%;
  overflow-y: auto;
  position: absolute;
  -moz-user-select: none;
  -webkit-user-select: none;
  -ms-user-select: none;
  user-select: none;
}
.ag-menu-column-select-wrapper {
  height: 265px;
  overflow: auto;
}
.ag-menu-column-select-wrapper .ag-column-select {
  height: 100%;
}
.ag-dialog .ag-panel-content-wrapper .ag-column-select {
  user-select: none;
}
.ag-menu-list {
  display: table;
  width: 100%;
}
.ag-menu-option, .ag-menu-separator {
  display: table-row;
}
.ag-menu-option-part, .ag-menu-separator-part {
  display: table-cell;
  vertical-align: middle;
}
.ag-menu-option-text {
  white-space: nowrap;
}
.ag-menu-option-custom {
  display: contents;
}
.ag-compact-menu-option {
  width: 100%;
  display: flex;
  flex-wrap: nowrap;
}
.ag-compact-menu-option-text {
  white-space: nowrap;
  flex: 1 1 auto;
}
.ag-context-menu-loading-icon {
  position: absolute;
  pointer-events: none;
}
.ag-pill-container {
  display: flex;
  gap: 0.25rem;
  flex-wrap: nowrap;
}
.ag-pill {
  display: flex;
  white-space: nowrap;
  padding: 0 0.25rem;
  align-items: center;
}
.ag-pill .ag-pill-button {
  border: none;
  padding: 0;
}
.ag-rich-select {
  cursor: default;
  outline: none;
  height: 100%;
}
.ag-rich-select-value {
  display: flex;
  align-items: center;
  height: 100%;
}
.ag-rich-select-value .ag-picker-field-display {
  overflow: hidden;
  text-overflow: ellipsis;
}
.ag-rich-select-value .ag-picker-field-display.ag-display-as-placeholder {
  opacity: 0.5;
}
.ag-rich-select-list {
  position: relative;
}
.ag-rich-select-list .ag-rich-select-loading {
  display: flex;
  min-height: 2rem;
}
.ag-rich-select-list .ag-rich-select-loading .ag-loading-text {
  overflow: hidden;
  text-overflow: ellipsis;
}
.ag-rich-select-row {
  display: flex;
  flex: 1 1 auto;
  align-items: center;
  white-space: nowrap;
  overflow: hidden;
  height: 100%;
}
.ag-rich-select-field-input {
  flex: 1 1 auto;
}
.ag-rich-select-field-input .ag-input-field-input {
  padding: 0 !important;
  border: none !important;
  box-shadow: none !important;
  text-overflow: ellipsis;
}
.ag-rich-select-field-input .ag-input-field-input::placeholder {
  opacity: 0.8;
}
.ag-rich-select-typing-multi .ag-picker-field-display {
  flex: 0 1 auto;
  min-width: 0;
  max-width: 100%;
}
.ag-rich-select-typing-multi .ag-rich-select-pill-display {
  display: flex;
  flex: 0 1 auto;
  min-width: 0;
  max-width: 100%;
  align-items: center;
  overflow: hidden;
}
.ag-rich-select-typing-multi .ag-rich-select-pill-display .ag-pill-container {
  flex: 0 1 auto;
  min-width: 0;
  max-width: 100%;
  overflow: hidden;
}
.ag-rich-select-typing-multi .ag-rich-select-field-input {
  flex: 0 0 auto;
  min-width: 0;
  max-width: 100%;
}
.ag-rich-select-typing-multi .ag-rich-select-field-input .ag-input-wrapper {
  flex: 0 0 auto;
  max-width: 100%;
}
.ag-rich-select-typing-multi .ag-rich-select-field-input .ag-input-field-input {
  width: auto;
  min-width: 1ch;
  max-width: 100%;
}
.ag-autocomplete {
  align-items: center;
  display: flex;
}
.ag-autocomplete > * {
  flex: 1 1 auto;
}
.ag-autocomplete-list-popup {
  position: absolute;
  -moz-user-select: none;
  -webkit-user-select: none;
  -ms-user-select: none;
  user-select: none;
}
.ag-autocomplete-list {
  position: relative;
}
.ag-autocomplete-virtual-list-item {
  display: flex;
}
.ag-autocomplete-row {
  display: flex;
  flex: 1 1 auto;
  align-items: center;
  overflow: hidden;
}
.ag-autocomplete-row-label {
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.ag-paging-panel {
  align-items: center;
  display: flex;
  justify-content: flex-end;
}
.ag-paging-page-summary-panel {
  display: flex;
  align-items: center;
}
.ag-paging-button {
  position: relative;
}
.ag-disabled .ag-paging-page-summary-panel {
  pointer-events: none;
}
.ag-tool-panel-wrapper {
  overflow: hidden;
  cursor: default;
  -moz-user-select: none;
  -webkit-user-select: none;
  -ms-user-select: none;
  user-select: none;
}
.ag-column-select-column, .ag-column-select-column-group, .ag-select-agg-func-item {
  position: relative;
  align-items: center;
  display: flex;
  flex-direction: row;
  flex-wrap: nowrap;
  height: 100%;
}
.ag-column-select-column > *, .ag-column-select-column-group > *, .ag-select-agg-func-item > * {
  flex: none;
}
.ag-select-agg-func-item, .ag-column-select-column-label {
  flex: 1 1 auto;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.ag-column-select-checkbox {
  display: flex;
}
.ag-tool-panel-horizontal-resize {
  cursor: ew-resize;
  height: 100%;
  position: absolute;
  top: 0;
  width: 5px;
  z-index: 1;
}
.ag-ltr .ag-side-bar-left .ag-tool-panel-horizontal-resize {
  right: -3px;
}
.ag-rtl .ag-side-bar-left .ag-tool-panel-horizontal-resize {
  left: -3px;
}
.ag-ltr .ag-side-bar-right .ag-tool-panel-horizontal-resize {
  left: -3px;
}
.ag-rtl .ag-side-bar-right .ag-tool-panel-horizontal-resize {
  right: -3px;
}
.ag-details-row {
  width: 100%;
}
.ag-details-row-fixed-height {
  height: 100%;
}
.ag-details-grid {
  width: 100%;
}
.ag-details-grid-fixed-height {
  height: 100%;
}
.ag-header-group-cell {
  display: flex;
  align-items: center;
  height: 100%;
  position: absolute;
  contain: paint;
}
.ag-header-group-cell-no-group.ag-header-span-height {
  display: none;
}
.ag-cell-label-container {
  display: flex;
  justify-content: space-between;
  flex-direction: row-reverse;
  align-items: center;
  height: 100%;
  width: 100%;
}
.ag-header-group-cell-label, .ag-cell-label-container {
  padding: 5px 0px;
}
.ag-right-aligned-header .ag-cell-label-container {
  flex-direction: row;
}
.ag-right-aligned-header .ag-header-cell-text {
  text-align: end;
}
.ag-side-bar {
  display: flex;
  flex-direction: row-reverse;
}
.ag-side-bar-left {
  order: -1;
  flex-direction: row;
}
.ag-side-button-button {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  flex-wrap: nowrap;
  white-space: nowrap;
  outline: none;
  cursor: pointer;
}
.ag-side-button-label {
  writing-mode: vertical-lr;
}
.ag-status-bar {
  display: flex;
  justify-content: space-between;
  overflow: hidden;
}
.ag-status-panel, .ag-status-panel.ag-status-panel-aggregations .ag-status-name-value {
  display: inline-flex;
}
.ag-status-name-value {
  white-space: nowrap;
}
.ag-status-bar-left {
  display: inline-flex;
}
.ag-status-bar-center {
  display: inline-flex;
}
.ag-status-bar-right {
  display: inline-flex;
}
.ag-row-number-cell {
  width: 100%;
  white-space: nowrap;
  overflow: hidden;
  user-select: none;
}
.ag-ltr .ag-row-number-cell {
  text-align: right;
}
.ag-rtl .ag-row-number-cell {
  text-align: left;
}
.ag-row-numbers-resizer {
  position: absolute;
  bottom: -2px;
  left: 0;
  height: 4px;
  width: 100%;
  cursor: ns-resize;
}
.ag-floating-bottom .ag-row-numbers-resizer {
  bottom: unset;
  top: -2px;
}
.ag-icon {
  display: block;
  speak: none;
}
.ag-group {
  position: relative;
  width: 100%;
}
.ag-group-title-bar {
  display: flex;
  align-items: center;
}
.ag-group-title {
  display: inline;
  min-width: 0;
  overflow: hidden;
  white-space: nowrap;
  text-overflow: ellipsis;
}
.ag-group-title-bar .ag-group-title {
  cursor: default;
}
.ag-group-toolbar {
  display: flex;
  align-items: center;
}
.ag-group-container {
  display: flex;
}
.ag-disabled .ag-group-container {
  pointer-events: none;
}
.ag-group-container-horizontal {
  flex-direction: row;
  flex-wrap: wrap;
}
.ag-group-container-vertical {
  flex-direction: column;
}
.ag-column-group-icons {
  display: block;
}
.ag-column-group-icons > * {
  cursor: pointer;
}
.ag-group-item-alignment-stretch .ag-group-item {
  align-items: stretch;
}
.ag-group-item-alignment-start .ag-group-item {
  align-items: flex-start;
}
.ag-group-item-alignment-end .ag-group-item {
  align-items: flex-end;
}
.ag-toggle-button-icon {
  transition: right 0.3s;
  position: absolute;
  top: -1px;
}
.ag-input-field, .ag-select {
  display: flex;
  flex-direction: row;
  align-items: center;
}
.ag-input-field-input {
  flex: 1 1 auto;
}
.ag-floating-filter-input .ag-input-field-input[type=date], .ag-floating-filter-input .ag-input-field-input[type=datetime-local] {
  width: 1px;
}
.ag-range-field {
  display: flex;
  align-items: center;
}
.ag-angle-select {
  display: flex;
  align-items: center;
}
.ag-angle-select-wrapper {
  display: flex;
}
.ag-angle-select-parent-circle {
  display: block;
  position: relative;
}
.ag-angle-select-child-circle {
  position: absolute;
}
.ag-slider-wrapper {
  display: flex;
}
.ag-slider-wrapper .ag-input-field {
  flex: 1 1 auto;
}
.ag-picker-field-display {
  flex: 1 1 auto;
}
.ag-picker-field {
  display: flex;
  align-items: center;
}
.ag-picker-field-icon {
  display: flex;
  border: 0;
  padding: 0;
  margin: 0;
  cursor: pointer;
}
.ag-picker-field-wrapper {
  overflow: hidden;
}
.ag-label-align-right .ag-label {
  order: 1;
}
.ag-label-align-right > * {
  flex: none;
}
.ag-label-align-top {
  flex-direction: column;
  align-items: flex-start;
}
.ag-label-align-top > * {
  align-self: stretch;
}
.ag-label-ellipsis {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  flex: 1;
}
.ag-color-panel {
  width: 100%;
  display: flex;
  flex-direction: column;
  text-align: center;
}
.ag-spectrum-color {
  flex: 1 1 auto;
  position: relative;
  overflow: visible;
  cursor: default;
}
.ag-spectrum-fill {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
}
.ag-spectrum-val {
  cursor: pointer;
}
.ag-spectrum-dragger {
  position: absolute;
  pointer-events: none;
  cursor: pointer;
}
.ag-spectrum-hue, .ag-spectrum-alpha {
  cursor: default;
}
.ag-spectrum-hue-background {
  background: linear-gradient(to left, #ff0000 3%, #ffff00 17%, #00ff00 33%, #00ffff 50%, #0000ff 67%, #ff00ff 83%, #ff0000 100%);
  width: 100%;
  height: 100%;
}
.ag-spectrum-alpha {
  --ag-spectrum-alpha-background-checked: url("data:image/svg+xml;utf8,<svg xmlns=%22http://www.w3.org/2000/svg%22 width=%224%22 height=%224%22><rect x=%220%22 y=%220%22 width=%224%22 height=%224%22 fill=%22%23fff%22/><path d=%22M0 0H2V4H4V2H0Z%22 fill=%22%23b2b2b2%22/></svg>");
}
.ag-spectrum-alpha-background {
  background: linear-gradient(to right, var(--ag-internal-spectrum-alpha-color-from), var(--ag-internal-spectrum-alpha-color-to)), var(--ag-spectrum-alpha-background-checked) top left/4px 4px;
  width: 100%;
  height: 100%;
}
.ag-spectrum-tool {
  cursor: pointer;
  position: relative;
}
.ag-spectrum-slider {
  position: absolute;
  pointer-events: none;
}
.ag-spectrum-alpha .ag-spectrum-slider {
  background: linear-gradient(to bottom, var(--ag-internal-spectrum-alpha-color), var(--ag-internal-spectrum-alpha-color)) white;
}
.ag-recent-colors {
  display: flex;
}
.ag-recent-color {
  cursor: pointer;
}
.ag-pill-select {
  display: flex;
  flex-direction: column;
}
.ag-pill-select .ag-column-drop {
  flex: unset;
}
.ag-content-editable-field {
  display: flex;
  align-items: center;
}
.ag-content-editable-field-input {
  cursor: text;
  display: block;
  flex: 1 1 auto;
  outline: none;
  white-space: nowrap;
  line-height: normal;
  overflow: auto;
  overflow-y: hidden;
  -ms-overflow-style: none !important;
  scrollbar-width: none !important;
}
.ag-content-editable-field-input::-webkit-scrollbar {
  display: none !important;
}
.ag-ltr {
  direction: ltr;
}
.ag-ltr .ag-body, .ag-ltr .ag-floating-top, .ag-ltr .ag-floating-bottom, .ag-ltr .ag-header, .ag-ltr .ag-sticky-top, .ag-ltr .ag-sticky-bottom, .ag-ltr .ag-body-viewport, .ag-ltr .ag-body-horizontal-scroll {
  flex-direction: row;
}
.ag-rtl {
  direction: rtl;
}
.ag-rtl .ag-body, .ag-rtl .ag-floating-top, .ag-rtl .ag-floating-bottom, .ag-rtl .ag-header, .ag-rtl .ag-sticky-top, .ag-rtl .ag-sticky-bottom, .ag-rtl .ag-body-viewport, .ag-rtl .ag-body-horizontal-scroll {
  flex-direction: row-reverse;
}
.ag-rtl .ag-icon-contracted, .ag-rtl .ag-icon-expanded, .ag-rtl .ag-icon-tree-closed {
  display: block;
  transform: rotate(180deg);
}
.ag-body .ag-body-viewport {
  -webkit-overflow-scrolling: touch;
}
.ag-measurement-container {
  width: 0;
  overflow: hidden;
  visibility: hidden;
}
.ag-measurement-container div {
  position: absolute;
}
.ag-layout-print.ag-body {
  display: block;
  height: unset;
}
.ag-layout-print.ag-root-wrapper {
  display: inline-block;
}
.ag-layout-print .ag-body-vertical-scroll {
  display: none;
}
.ag-layout-print .ag-body-horizontal-scroll {
  display: none;
}
.ag-layout-print.ag-force-vertical-scroll {
  overflow-y: visible !important;
}
@media print {
  .ag-root-wrapper.ag-layout-print {
    display: table;
    container-type: normal;
  }
  .ag-root-wrapper.ag-layout-print .ag-root-wrapper-body, .ag-root-wrapper.ag-layout-print .ag-root, .ag-root-wrapper.ag-layout-print .ag-body-viewport, .ag-root-wrapper.ag-layout-print .ag-center-cols-container, .ag-root-wrapper.ag-layout-print .ag-center-cols-viewport, .ag-root-wrapper.ag-layout-print .ag-body-horizontal-scroll-viewport, .ag-root-wrapper.ag-layout-print .ag-virtual-list-viewport {
    height: auto !important;
    overflow: hidden !important;
    display: block !important;
  }
  .ag-root-wrapper.ag-layout-print .ag-row, .ag-root-wrapper.ag-layout-print .ag-cell {
    break-inside: avoid;
  }
}
[class^=ag-], [class^=ag-]:focus, [class^=ag-]:after, [class^=ag-]:before {
  box-sizing: border-box;
  outline: none;
}
[class^=ag-]::-ms-clear {
  display: none;
}
.ag-checkbox .ag-input-wrapper, .ag-radio-button .ag-input-wrapper {
  overflow: visible;
}
.ag-range-field .ag-input-wrapper {
  height: 100%;
}
.ag-toggle-button {
  flex: none;
  width: unset;
  min-width: unset;
}
.ag-button {
  border-radius: 0px;
  color: var(--ag-foreground-color);
}
.ag-button:hover {
  background-color: transparent;
}
.ag-ltr .ag-label-align-right .ag-label {
  margin-left: var(--ag-grid-size);
}
.ag-rtl .ag-label-align-right .ag-label {
  margin-right: var(--ag-grid-size);
}
input[class^=ag-] {
  margin: 0;
  background-color: var(--ag-background-color);
}
textarea[class^=ag-], select[class^=ag-] {
  background-color: var(--ag-background-color);
}
input[class^=ag-]:not([type]), input[class^=ag-][type=text], input[class^=ag-][type=number], input[class^=ag-][type=tel], input[class^=ag-][type=date], input[class^=ag-][type=datetime-local], textarea[class^=ag-] {
  font-size: inherit;
  line-height: inherit;
  color: inherit;
  font-family: inherit;
  border: var(--ag-borders-input) var(--ag-input-border-color);
}
input[class^=ag-]:not([type]):disabled, input[class^=ag-][type=text]:disabled, input[class^=ag-][type=number]:disabled, input[class^=ag-][type=tel]:disabled, input[class^=ag-][type=date]:disabled, input[class^=ag-][type=datetime-local]:disabled, textarea[class^=ag-]:disabled {
  color: var(--ag-disabled-foreground-color);
  background-color: var(--ag-input-disabled-background-color);
  border-color: var(--ag-input-disabled-border-color);
}
input[class^=ag-]:not([type]):focus, input[class^=ag-][type=text]:focus, input[class^=ag-][type=number]:focus, input[class^=ag-][type=tel]:focus, input[class^=ag-][type=date]:focus, input[class^=ag-][type=datetime-local]:focus, textarea[class^=ag-]:focus {
  outline: none;
  box-shadow: var(--ag-input-focus-box-shadow);
  border-color: var(--ag-input-focus-border-color);
}
input[class^=ag-]:not([type]):focus.invalid, input[class^=ag-]:not([type]):focus:invalid, input[class^=ag-][type=text]:focus.invalid, input[class^=ag-][type=text]:focus:invalid, input[class^=ag-][type=number]:focus.invalid, input[class^=ag-][type=number]:focus:invalid, input[class^=ag-][type=tel]:focus.invalid, input[class^=ag-][type=tel]:focus:invalid, input[class^=ag-][type=date]:focus.invalid, input[class^=ag-][type=date]:focus:invalid, input[class^=ag-][type=datetime-local]:focus.invalid, input[class^=ag-][type=datetime-local]:focus:invalid, textarea[class^=ag-]:focus.invalid, textarea[class^=ag-]:focus:invalid {
  box-shadow: var(--ag-input-error-focus-box-shadow);
  border-color: var(--ag-invalid-color);
}
input[class^=ag-]:not([type]):invalid, input[class^=ag-][type=text]:invalid, input[class^=ag-][type=number]:invalid, input[class^=ag-][type=tel]:invalid, input[class^=ag-][type=date]:invalid, input[class^=ag-][type=datetime-local]:invalid, textarea[class^=ag-]:invalid {
  border: var(--ag-borders-input-invalid) var(--ag-input-border-color-invalid);
}
input[class^=ag-][type=number]:not(.ag-number-field-input-stepper) {
  -moz-appearance: textfield;
}
input[class^=ag-][type=number]:not(.ag-number-field-input-stepper)::-webkit-outer-spin-button, input[class^=ag-][type=number]:not(.ag-number-field-input-stepper)::-webkit-inner-spin-button {
  -webkit-appearance: none;
  margin: 0;
}
input[class^=ag-][type=range] {
  padding: 0;
}
input[class^=ag-][type=button]:focus, button[class^=ag-]:focus {
  box-shadow: var(--ag-input-focus-box-shadow);
}
input[class^=ag-][type=button]:focus:invalid, input[class^=ag-][type=button]:focus.invalid, button[class^=ag-]:focus:invalid, button[class^=ag-]:focus.invalid {
  box-shadow: var(--ag-input-error-focus-box-shadow);
}
.ag-drag-handle {
  color: var(--ag-secondary-foreground-color);
}
.ag-list-item, .ag-virtual-list-item {
  height: var(--ag-list-item-height);
}
.ag-virtual-list-item:focus-visible {
  outline: none;
}
.ag-virtual-list-item:focus-visible::after {
  content: "";
  position: absolute;
  background-color: transparent;
  pointer-events: none;
  top: 4px;
  left: 4px;
  display: block;
  width: calc(100% - 8px);
  height: calc(100% - 8px);
  border: 1px solid;
  border-color: var(--ag-input-focus-border-color);
}
.ag-select-list {
  background-color: var(--ag-background-color);
  overflow-y: auto;
  overflow-x: hidden;
  border-radius: var(--ag-border-radius);
  border: var(--ag-borders) var(--ag-border-color);
}
.ag-list-item {
  display: flex;
  align-items: center;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.ag-list-item.ag-active-item {
  background-color: var(--ag-row-hover-color);
}
.ag-select-list-item {
  -moz-user-select: none;
  -webkit-user-select: none;
  -ms-user-select: none;
  user-select: none;
  cursor: default;
}
.ag-ltr .ag-select-list-item {
  padding-left: calc(var(--ag-cell-horizontal-padding) / 2);
}
.ag-rtl .ag-select-list-item {
  padding-right: calc(var(--ag-cell-horizontal-padding) / 2);
}
.ag-select-list-item span {
  white-space: nowrap;
  text-overflow: ellipsis;
  overflow: hidden;
}
.ag-row-drag, .ag-selection-checkbox, .ag-group-expanded, .ag-group-contracted {
  color: var(--ag-secondary-foreground-color);
}
.ag-ltr .ag-row-drag, .ag-ltr .ag-selection-checkbox, .ag-ltr .ag-group-expanded, .ag-ltr .ag-group-contracted {
  margin-right: var(--ag-cell-widget-spacing);
}
.ag-rtl .ag-row-drag, .ag-rtl .ag-selection-checkbox, .ag-rtl .ag-group-expanded, .ag-rtl .ag-group-contracted {
  margin-left: var(--ag-cell-widget-spacing);
}
.ag-drag-handle-disabled {
  opacity: 0.35;
  pointer-events: none;
}
.ag-cell-wrapper > *:not(.ag-cell-value):not(.ag-group-value) {
  --ag-internal-calculated-line-height: var(
      --ag-line-height,
      calc(var(--ag-row-height) - var(--ag-row-border-width))
  );
  --ag-internal-padded-row-height: calc(var(--ag-row-height) - var(--ag-row-border-width) - 2px);
  height: min(var(--ag-internal-calculated-line-height), var(--ag-internal-padded-row-height));
  display: flex;
  align-items: center;
  flex: none;
}
.ag-group-expanded, .ag-group-contracted {
  cursor: pointer;
}
.ag-group-title-bar-icon {
  cursor: pointer;
  flex: none;
  color: var(--ag-secondary-foreground-color);
}
.ag-ltr .ag-group-child-count {
  margin-left: 2px;
}
.ag-rtl .ag-group-child-count {
  margin-right: 2px;
}
.ag-group-title-bar {
  background-color: var(--ag-subheader-background-color);
  padding: var(--ag-grid-size);
}
.ag-group-toolbar {
  padding: var(--ag-grid-size);
  background-color: var(--ag-subheader-toolbar-background-color);
}
.ag-disabled-group-title-bar, .ag-disabled-group-container {
  opacity: 0.5;
}
.group-item {
  margin: calc(var(--ag-grid-size) * 0.5) 0;
}
.ag-label {
  white-space: nowrap;
}
.ag-ltr .ag-label {
  margin-right: var(--ag-grid-size);
}
.ag-rtl .ag-label {
  margin-left: var(--ag-grid-size);
}
.ag-label-align-top .ag-label {
  margin-bottom: calc(var(--ag-grid-size) * 0.5);
}
.ag-angle-select[disabled] {
  color: var(--ag-disabled-foreground-color);
  pointer-events: none;
}
.ag-angle-select[disabled] .ag-angle-select-field {
  opacity: 0.4;
}
.ag-ltr .ag-slider-field, .ag-ltr .ag-angle-select-field {
  margin-right: calc(var(--ag-grid-size) * 2);
}
.ag-rtl .ag-slider-field, .ag-rtl .ag-angle-select-field {
  margin-left: calc(var(--ag-grid-size) * 2);
}
.ag-angle-select-parent-circle {
  width: 24px;
  height: 24px;
  border-radius: 12px;
  border: solid 1px;
  border-color: var(--ag-border-color);
  background-color: var(--ag-background-color);
}
.ag-angle-select-child-circle {
  top: 4px;
  left: 12px;
  width: 6px;
  height: 6px;
  margin-left: -3px;
  margin-top: -4px;
  border-radius: 3px;
  background-color: var(--ag-secondary-foreground-color);
}
.ag-picker-field-wrapper {
  border: var(--ag-borders);
  border-color: var(--ag-border-color);
  border-radius: 5px;
  background-color: var(--ag-background-color);
}
.ag-picker-field-wrapper:disabled {
  color: var(--ag-disabled-foreground-color);
  background-color: var(--ag-input-disabled-background-color);
  border-color: var(--ag-input-disabled-border-color);
}
.ag-picker-field-wrapper.ag-picker-has-focus, .ag-picker-field-wrapper:focus-within {
  outline: none;
  box-shadow: var(--ag-input-focus-box-shadow);
  border-color: var(--ag-input-focus-border-color);
}
.ag-picker-field-wrapper.ag-picker-has-focus.invalid, .ag-picker-field-wrapper:focus-within.invalid {
  box-shadow: var(--ag-input-error-focus-box-shadow);
}
.ag-picker-field-wrapper.invalid {
  border: var(--ag-borders-input-invalid) var(--ag-input-border-color-invalid);
}
.ag-picker-field-button {
  background-color: var(--ag-background-color);
  color: var(--ag-secondary-foreground-color);
}
.ag-dialog.ag-color-dialog {
  border-radius: 5px;
}
.ag-color-picker .ag-picker-field-wrapper {
  padding-left: var(--ag-grid-size);
  padding-right: var(--ag-grid-size);
}
.ag-color-picker .ag-picker-field-display {
  display: flex;
  flex-direction: row;
  align-items: center;
  min-height: var(--ag-list-item-height);
}
.ag-ltr .ag-color-picker-color, .ag-ltr .ag-color-picker-value {
  margin-right: var(--ag-grid-size);
}
.ag-rtl .ag-color-picker-color, .ag-rtl .ag-color-picker-value {
  margin-left: var(--ag-grid-size);
}
.ag-color-panel {
  padding: var(--ag-grid-size);
}
.ag-spectrum-color {
  background-color: rgb(255, 0, 0);
  border-radius: 2px;
}
.ag-spectrum-tools {
  padding: 10px;
}
.ag-spectrum-sat {
  background-image: linear-gradient(to right, white, rgba(204, 154, 129, 0));
}
.ag-spectrum-val {
  background-image: linear-gradient(to top, black, rgba(204, 154, 129, 0));
}
.ag-spectrum-dragger {
  border-radius: 12px;
  height: 12px;
  width: 12px;
  border: 2px solid white;
  background: black;
  box-shadow: 0 0 2px 0px rgba(0, 0, 0, 0.24);
}
.ag-spectrum-hue-background {
  border-radius: 2px;
}
.ag-spectrum-alpha-background {
  border-radius: 2px;
}
.ag-spectrum-tool {
  margin-bottom: 10px;
  height: 11px;
  border-radius: 2px;
}
.ag-spectrum-slider {
  margin-top: -12px;
  width: 13px;
  height: 13px;
  border-radius: 13px;
  border: 2px solid white;
  box-shadow: 0 1px 4px 0 rgba(0, 0, 0, 0.37);
}
.ag-recent-colors {
  margin-top: 10px;
}
.ag-recent-color {
  margin: 0 3px;
}
.ag-recent-color:first-child {
  margin-left: 0;
}
.ag-recent-color:last-child {
  margin-right: 0;
}
.ag-spectrum-color:focus-visible:not(:disabled):not([readonly]), .ag-spectrum-slider:focus-visible:not(:disabled):not([readonly]), .ag-recent-color:focus-visible:not(:disabled):not([readonly]) {
  box-shadow: var(--ag-input-focus-box-shadow);
}
.ag-ltr .ag-color-input input[class^=ag-][type=text].ag-input-field-input {
  padding-left: calc(var(--ag-icon-size) + var(--ag-grid-size) * 2);
}
.ag-rtl .ag-color-input input[class^=ag-][type=text].ag-input-field-input {
  padding-right: calc(var(--ag-icon-size) + var(--ag-grid-size) * 2);
}
.ag-color-input .ag-color-input-color {
  position: absolute;
}
.ag-ltr .ag-color-input .ag-color-input-color {
  margin-left: var(--ag-grid-size);
}
.ag-rtl .ag-color-input .ag-color-input-color {
  margin-right: var(--ag-grid-size);
}
.ag-color-picker-color, .ag-color-input-color {
  width: var(--ag-icon-size);
  height: var(--ag-icon-size);
  border: var(--ag-borders-secondary) var(--ag-secondary-border-color);
  border-radius: 2px;
}
.ag-dnd-ghost {
  border: var(--ag-borders) var(--ag-border-color);
  background: var(--ag-background-color);
  border-radius: var(--ag-card-radius);
  box-shadow: var(--ag-card-shadow);
  padding: var(--ag-grid-size);
  overflow: hidden;
  text-overflow: ellipsis;
  border: var(--ag-borders-secondary) var(--ag-secondary-border-color);
  color: var(--ag-secondary-foreground-color);
  height: var(--ag-header-height);
  line-height: var(--ag-header-height);
  margin: 0;
  padding: 0 calc(var(--ag-grid-size) * 2);
  transform: translateY(calc(var(--ag-grid-size) * 2));
}
.ag-dnd-ghost-not-allowed {
  border-color: var(--ag-background-color);
  @supports (color: color-mix(in lab, red, red)) {
    border-color: color-mix(in srgb, var(--ag-background-color), var(--ag-invalid-color) 50%);
  }
}
.ag-dnd-ghost-icon {
  margin-right: var(--ag-grid-size);
  color: var(--ag-foreground-color);
}
.ag-popup-child:not(.ag-tooltip-custom) {
  box-shadow: var(--ag-popup-shadow);
}
.ag-select .ag-picker-field-wrapper {
  min-height: var(--ag-list-item-height);
  cursor: default;
}
.ag-ltr .ag-select .ag-picker-field-wrapper {
  padding-left: calc(var(--ag-cell-horizontal-padding) / 2);
}
.ag-rtl .ag-select .ag-picker-field-wrapper {
  padding-right: calc(var(--ag-cell-horizontal-padding) / 2);
}
.ag-ltr .ag-select .ag-picker-field-wrapper {
  padding-right: var(--ag-grid-size);
}
.ag-rtl .ag-select .ag-picker-field-wrapper {
  padding-left: var(--ag-grid-size);
}
.ag-select.ag-disabled .ag-picker-field-wrapper:focus {
  box-shadow: none;
}
.ag-select:not(.ag-cell-editor, .ag-label-align-top) {
  min-height: var(--ag-list-item-height);
}
.ag-select .ag-picker-field-display {
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.ag-select .ag-picker-field-icon {
  display: flex;
  align-items: center;
}
.ag-select.ag-disabled {
  opacity: 0.5;
}
.ag-rich-select-value, .ag-rich-select-list {
  background-color: var(--ag-background-color);
}
.ag-rich-select-list {
  width: 100%;
  height: auto;
  border-radius: var(--ag-border-radius);
  border: var(--ag-borders) var(--ag-border-color);
}
.ag-rich-select-list .ag-rich-select-loading {
  padding: var(--ag-widget-vertical-spacing) var(--ag-widget-horizontal-spacing);
}
.ag-rich-select-value {
  border-bottom: var(--ag-borders-secondary) var(--ag-secondary-border-color);
  padding-top: 0;
  padding-bottom: 0;
}
.ag-ltr .ag-rich-select-value {
  padding-left: calc(var(--ag-cell-horizontal-padding) / 2);
}
.ag-rtl .ag-rich-select-value {
  padding-right: calc(var(--ag-cell-horizontal-padding) / 2);
}
.ag-ltr .ag-rich-select-value {
  padding-right: var(--ag-grid-size);
}
.ag-rtl .ag-rich-select-value {
  padding-left: var(--ag-grid-size);
}
.ag-ltr .ag-rich-select-field-input {
  left: calc(var(--ag-cell-horizontal-padding));
}
.ag-rtl .ag-rich-select-field-input {
  right: calc(var(--ag-cell-horizontal-padding));
}
.ag-ltr .ag-rich-select-typing-multi .ag-rich-select-field-input {
  margin-left: 0.25rem;
}
.ag-rtl .ag-rich-select-typing-multi .ag-rich-select-field-input {
  margin-right: 0.25rem;
}
.ag-ltr .ag-rich-select-typing-multi .ag-rich-select-deselect-button {
  margin-left: auto;
}
.ag-rtl .ag-rich-select-typing-multi .ag-rich-select-deselect-button {
  margin-right: auto;
}
.ag-ltr .ag-rich-select-typing-multi .ag-rich-select-deselect-button.ag-hidden + .ag-picker-field-icon {
  margin-left: auto;
}
.ag-rtl .ag-rich-select-typing-multi .ag-rich-select-deselect-button.ag-hidden + .ag-picker-field-icon {
  margin-right: auto;
}
.ag-popup-editor .ag-rich-select-value {
  height: var(--ag-row-height);
  min-width: 200px;
}
.ag-rich-select-virtual-list-item {
  cursor: default;
  height: var(--ag-list-item-height);
}
.ag-rich-select-virtual-list-item:focus-visible::after {
  content: none;
}
.ag-ltr .ag-rich-select-row {
  padding-left: calc(var(--ag-cell-horizontal-padding) / 2);
}
.ag-rtl .ag-rich-select-row {
  padding-right: calc(var(--ag-cell-horizontal-padding) / 2);
}
.ag-rich-select-row-selected {
  background-color: var(--ag-selected-row-background-color);
}
.ag-rich-select-row:hover, .ag-rich-select-row-highlighted {
  background-image: linear-gradient(var(--ag-row-hover-color), var(--ag-row-hover-color));
}
.ag-rich-select-row-text-highlight {
  font-weight: bold;
}
.ag-autocomplete {
  width: 100%;
}
.ag-autocomplete-list {
  width: 100%;
  min-width: 200px;
  height: calc(var(--ag-row-height) * 6.5);
}
.ag-autocomplete-virtual-list-item {
  cursor: default;
  height: var(--ag-list-item-height);
}
.ag-autocomplete-virtual-list-item:focus-visible::after {
  content: none;
}
.ag-autocomplete-virtual-list-item:hover {
  background-color: var(--ag-row-hover-color);
}
.ag-autocomplete-row-label {
  margin: 0px var(--ag-widget-container-horizontal-padding);
}
.ag-autocomplete-row-selected {
  background-color: var(--ag-selected-row-background-color);
}
.ag-pill {
  border: 1px solid var(--ag-chip-border-color);
  border-radius: var(--ag-border-radius);
  background-color: var(--ag-chip-background-color);
}
.ag-ltr .ag-pill .ag-pill-button {
  margin-left: var(--ag-grid-size);
}
.ag-rtl .ag-pill .ag-pill-button {
  margin-right: var(--ag-grid-size);
}
.ag-pill:focus-visible {
  border-color: var(--ag-input-focus-border-color);
}
.ag-pill .ag-pill-button:hover {
  cursor: pointer;
}
.ag-content-editable-field-input {
  background-color: var(--ag-background-color);
  border: var(--ag-borders-input) var(--ag-input-border-color);
  border-radius: var(--ag-border-radius);
  color: var(--ag-foreground-color);
}
.ag-ltr .ag-content-editable-field-input {
  padding-left: var(--ag-grid-size);
}
.ag-rtl .ag-content-editable-field-input {
  padding-right: var(--ag-grid-size);
}
.ag-cell-editor .ag-wrapper.ag-content-editable-field-input {
  --ag-internal-calculated-line-height: var(
      --ag-line-height,
      calc(var(--ag-row-height) - var(--ag-row-border-width))
  );
  --ag-internal-padded-row-height: calc(var(--ag-row-height) - var(--ag-row-border-width) - 2px);
  line-height: min(var(--ag-internal-calculated-line-height), var(--ag-internal-padded-row-height));
}
.ag-content-editable-field-input:focus, .ag-content-editable-field-input:focus-within {
  box-shadow: var(--ag-input-focus-box-shadow);
  border-color: var(--ag-input-focus-border-color);
}
:where(.ag-content-editable-field.ag-disabled .ag-content-editable-field-input) {
  background-color: var(--ag-input-disabled-background-color);
  border-color: var(--ag-input-disabled-border-color);
  color: var(--ag-disabled-foreground-color);
}
.ag-content-editable-field-input.invalid {
  border-color: var(--ag-invalid-color);
}
.ag-formula-token {
  line-height: var(--ag-line-height, 1.6);
}
.ag-formula-token-color-1 {
  color: var(--ag-formula-token-1-color);
}
.ag-formula-token-color-2 {
  color: var(--ag-formula-token-2-color);
}
.ag-formula-token-color-3 {
  color: var(--ag-formula-token-3-color);
}
.ag-formula-token-color-4 {
  color: var(--ag-formula-token-4-color);
}
.ag-formula-token-color-5 {
  color: var(--ag-formula-token-5-color);
}
.ag-formula-token-color-6 {
  color: var(--ag-formula-token-6-color);
}
.ag-formula-token-color-7 {
  color: var(--ag-formula-token-7-color);
}
.ag-formula-range-color-1 {
  --ag-range-selection-border-color: var(--ag-formula-token-1-color);
  --ag-range-selection-background-color: var(--ag-formula-token-1-background-color);
}
.ag-formula-range-color-2 {
  --ag-range-selection-border-color: var(--ag-formula-token-2-color);
  --ag-range-selection-background-color: var(--ag-formula-token-2-background-color);
}
.ag-formula-range-color-3 {
  --ag-range-selection-border-color: var(--ag-formula-token-3-color);
  --ag-range-selection-background-color: var(--ag-formula-token-3-background-color);
}
.ag-formula-range-color-4 {
  --ag-range-selection-border-color: var(--ag-formula-token-4-color);
  --ag-range-selection-background-color: var(--ag-formula-token-4-background-color);
}
.ag-formula-range-color-5 {
  --ag-range-selection-border-color: var(--ag-formula-token-5-color);
  --ag-range-selection-background-color: var(--ag-formula-token-5-background-color);
}
.ag-formula-range-color-6 {
  --ag-range-selection-border-color: var(--ag-formula-token-6-color);
  --ag-range-selection-background-color: var(--ag-formula-token-6-background-color);
}
.ag-formula-range-color-7 {
  --ag-range-selection-border-color: var(--ag-formula-token-7-color);
  --ag-range-selection-background-color: var(--ag-formula-token-7-background-color);
}
.ag-range-handle.ag-formula-range-color-1, .ag-fill-handle.ag-formula-range-color-1 {
  background-color: var(--ag-formula-token-1-color);
}
.ag-range-handle.ag-formula-range-color-2, .ag-fill-handle.ag-formula-range-color-2 {
  background-color: var(--ag-formula-token-2-color);
}
.ag-range-handle.ag-formula-range-color-3, .ag-fill-handle.ag-formula-range-color-3 {
  background-color: var(--ag-formula-token-3-color);
}
.ag-range-handle.ag-formula-range-color-4, .ag-fill-handle.ag-formula-range-color-4 {
  background-color: var(--ag-formula-token-4-color);
}
.ag-range-handle.ag-formula-range-color-5, .ag-fill-handle.ag-formula-range-color-5 {
  background-color: var(--ag-formula-token-5-color);
}
.ag-range-handle.ag-formula-range-color-6, .ag-fill-handle.ag-formula-range-color-6 {
  background-color: var(--ag-formula-token-6-color);
}
.ag-dragging-range-handle .ag-dialog, .ag-dragging-fill-handle .ag-dialog {
  opacity: 0.7;
  pointer-events: none;
}
.ag-dialog {
  border-radius: var(--ag-border-radius);
  border: var(--ag-borders) var(--ag-border-color);
  box-shadow: var(--ag-popup-shadow);
}
.ag-panel {
  background-color: var(--ag-panel-background-color);
  border-color: var(--ag-panel-border-color);
}
.ag-panel-title-bar {
  color: var(--ag-header-foreground-color);
  height: var(--ag-header-height);
  padding: var(--ag-grid-size) var(--ag-cell-horizontal-padding);
  border-bottom: var(--ag-borders) var(--ag-border-color);
}
.ag-ltr .ag-panel-title-bar-button {
  margin-left: var(--ag-grid-size);
}
.ag-rtl .ag-panel-title-bar-button {
  margin-right: var(--ag-grid-size);
}
.ag-tooltip {
  background-color: var(--ag-tooltip-background-color);
  color: var(--ag-foreground-color);
  padding: var(--ag-grid-size);
  border: var(--ag-borders) var(--ag-border-color);
  border-radius: var(--ag-card-radius);
  white-space: normal;
}
.ag-tooltip.ag-cell-editor-tooltip, .ag-tooltip.ag-cell-formula-tooltip {
  background-color: var(--ag-tooltip-error-background-color);
  color: var(--ag-tooltip-error-text-color);
  border: var(--ag-borders) var(--ag-tooltip-error-border-color);
  font-weight: 500;
}
.ag-tooltip.ag-tooltip-animate, .ag-tooltip-custom.ag-tooltip-animate {
  transition: opacity 1s;
}
.ag-tooltip.ag-tooltip-animate.ag-tooltip-hiding, .ag-tooltip-custom.ag-tooltip-animate.ag-tooltip-hiding {
  opacity: 0;
}
.ag-ltr .ag-column-select-column, .ag-ltr .ag-column-select-column-group {
  padding-left: calc(var(--ag-indentation-level) * var(--ag-column-select-indent-size));
}
.ag-rtl .ag-column-select-column, .ag-rtl .ag-column-select-column-group {
  padding-right: calc(var(--ag-indentation-level) * var(--ag-column-select-indent-size));
}
.ag-column-select-header-icon {
  cursor: pointer;
}
.ag-column-select-header-icon:focus-visible {
  outline: none;
}
.ag-column-select-header-icon:focus-visible::after {
  content: "";
  position: absolute;
  background-color: transparent;
  pointer-events: none;
  top: 0px;
  left: 0px;
  display: block;
  width: calc(100% - 0px);
  height: calc(100% - 0px);
  border: 1px solid;
  border-color: var(--ag-input-focus-border-color);
}
.ag-ltr .ag-column-group-icons:not(:last-child), .ag-ltr .ag-column-select-header-icon:not(:last-child), .ag-ltr .ag-column-select-header-checkbox:not(:last-child), .ag-ltr .ag-column-select-header-filter-wrapper:not(:last-child), .ag-ltr .ag-column-select-checkbox:not(:last-child), .ag-ltr .ag-column-select-column-drag-handle:not(:last-child), .ag-ltr .ag-column-select-column-group-drag-handle:not(:last-child), .ag-ltr .ag-column-select-column-label:not(:last-child) {
  margin-right: var(--ag-widget-horizontal-spacing);
}
.ag-rtl .ag-column-group-icons:not(:last-child), .ag-rtl .ag-column-select-header-icon:not(:last-child), .ag-rtl .ag-column-select-header-checkbox:not(:last-child), .ag-rtl .ag-column-select-header-filter-wrapper:not(:last-child), .ag-rtl .ag-column-select-checkbox:not(:last-child), .ag-rtl .ag-column-select-column-drag-handle:not(:last-child), .ag-rtl .ag-column-select-column-group-drag-handle:not(:last-child), .ag-rtl .ag-column-select-column-label:not(:last-child) {
  margin-left: var(--ag-widget-horizontal-spacing);
}
.ag-column-select-virtual-list-item:focus-visible {
  outline: none;
}
.ag-column-select-virtual-list-item:focus-visible::after {
  content: "";
  position: absolute;
  background-color: transparent;
  pointer-events: none;
  top: 1px;
  left: 1px;
  display: block;
  width: calc(100% - 2px);
  height: calc(100% - 2px);
  border: 1px solid;
  border-color: var(--ag-input-focus-border-color);
}
.ag-column-select-column-group:not(:last-child), .ag-column-select-column:not(:last-child) {
  margin-bottom: var(--ag-widget-vertical-spacing);
}
.ag-column-select-column-readonly, .ag-column-select-column-group-readonly {
  color: var(--ag-disabled-foreground-color);
  pointer-events: none;
}
.ag-ltr .ag-column-select-add-group-indent {
  margin-left: calc(var(--ag-icon-size) + var(--ag-grid-size) * 2);
}
.ag-rtl .ag-column-select-add-group-indent {
  margin-right: calc(var(--ag-icon-size) + var(--ag-grid-size) * 2);
}
.ag-column-select-virtual-list-viewport {
  padding: calc(var(--ag-widget-container-vertical-padding) * 0.5) 0px;
}
.ag-column-select-virtual-list-item {
  padding: 0 var(--ag-widget-container-horizontal-padding);
}
.ag-checkbox-edit {
  padding-left: var(--ag-cell-horizontal-padding);
  padding-right: var(--ag-cell-horizontal-padding);
}
.ag-pill-select .ag-column-drop {
  border-bottom: 0;
  min-height: unset;
}
.ag-pill-select .ag-column-drop-list {
  padding: 0;
}
.ag-pill-select .ag-select {
  padding-top: var(--ag-grid-size);
}
.ag-pill-select .ag-picker-field-wrapper {
  background-color: transparent;
  border: 0;
}
.ag-pill-select .ag-picker-field-display {
  cursor: pointer;
}
.ag-rtl {
  text-align: right;
}
.ag-root-wrapper {
  border-radius: var(--ag-wrapper-border-radius);
  border: var(--ag-borders) var(--ag-border-color);
}
.ag-row > .ag-cell-wrapper.ag-row-group {
  padding-left: calc(var(--ag-cell-horizontal-padding) + var(--ag-row-group-indent-size) * var(--ag-indentation-level));
}
.ag-cell-wrapper.ag-row-group, .ag-cell-wrapper.ag-row-group-leaf-indent, .ag-cell-wrapper.ag-pivot-leaf-group {
  padding-left: calc(var(--ag-indentation-level) * var(--ag-row-group-indent-size));
}
.ag-cell-wrapper > .ag-group-checkbox-spacing {
  width: var(--ag-icon-size);
  margin-right: var(--ag-cell-widget-spacing);
}
.ag-ltr .ag-row-group-leaf-indent {
  margin-left: var(--ag-row-group-indent-size);
}
.ag-rtl .ag-row-group-leaf-indent {
  margin-right: var(--ag-row-group-indent-size);
}
.ag-row:not(.ag-row-level-0) .ag-pivot-leaf-group {
  margin-left: var(--ag-row-group-indent-size);
}
.ag-value-change-delta {
  padding-right: 2px;
}
.ag-value-change-delta-up {
  color: var(--ag-value-change-delta-up-color);
}
.ag-value-change-delta-down {
  color: var(--ag-value-change-delta-down-color);
}
.ag-value-change-value {
  background-color: transparent;
  border-radius: 1px;
  padding-left: 1px;
  padding-right: 1px;
  transition: background-color 1s;
}
.ag-value-change-value-highlight {
  background-color: var(--ag-value-change-value-highlight-background-color);
  transition: background-color 0.1s;
}
.ag-cell-data-changed {
  background-color: var(--ag-value-change-value-highlight-background-color) !important;
}
.ag-cell-data-changed-animation {
  background-color: transparent;
}
.ag-cell-highlight {
  background-color: var(--ag-range-selection-highlight-color) !important;
}
.ag-row, .ag-spanned-row {
  color: var(--ag-data-color);
}
.ag-row {
  height: var(--ag-row-height);
  background-color: var(--ag-data-background-color);
  border-bottom: var(--ag-row-border-style) var(--ag-row-border-color) var(--ag-row-border-width);
}
.ag-row.ag-row-editing-invalid {
  background-color: var(--ag-full-row-invalid-background-color);
}
.ag-spanned-cell-wrapper {
  background-color: var(--ag-data-background-color);
  position: absolute;
}
.ag-spanned-cell-wrapper > .ag-spanned-cell {
  display: block;
  position: relative;
}
.ag-row-highlight-above::after, .ag-row-highlight-inside::after, .ag-row-highlight-below::after {
  content: "";
  position: absolute;
  width: calc(100% - 1px);
  height: var(--ag-row-drag-indicator-width);
  background-color: var(--ag-row-drag-indicator-color);
  border-radius: calc(var(--ag-row-drag-indicator-width) / 2);
  left: 1px;
  pointer-events: none;
}
.ag-row-highlight-above::after {
  top: 0;
}
.ag-row-highlight-below::after {
  bottom: 0;
}
.ag-row-highlight-indent::after {
  display: block;
  width: auto;
  left: calc(2 * (var(--ag-cell-widget-spacing) + var(--ag-icon-size)) + var(--ag-cell-horizontal-padding) + var(--ag-row-highlight-level) * var(--ag-row-group-indent-size));
  right: 1px;
}
.ag-row-highlight-inside::after {
  display: block;
  width: auto;
  height: auto;
  inset: 0;
  background-color: var(--ag-selected-row-background-color);
  border: 1px solid var(--ag-range-selection-border-color);
}
.ag-body, .ag-floating-top, .ag-floating-bottom {
  background-color: var(--ag-data-background-color);
}
.ag-row-odd {
  background-color: var(--ag-odd-row-background-color);
}
.ag-body-horizontal-scroll:not(.ag-scrollbar-invisible) .ag-horizontal-left-spacer:not(.ag-scroller-corner) {
  border-right: var(--ag-borders-critical) var(--ag-border-color);
}
.ag-body-horizontal-scroll:not(.ag-scrollbar-invisible) .ag-horizontal-right-spacer:not(.ag-scroller-corner) {
  border-left: var(--ag-borders-critical) var(--ag-border-color);
}
.ag-row-selected::before {
  content: "";
  background-color: var(--ag-selected-row-background-color);
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
}
.ag-row-hover:not(.ag-full-width-row)::before, .ag-row-hover.ag-full-width-row.ag-row-group::before {
  content: "";
  background-color: var(--ag-row-hover-color);
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  pointer-events: none;
}
.ag-row.ag-full-width-row.ag-row-group > * {
  position: relative;
}
.ag-row-hover.ag-row-selected::before {
  background-color: var(--ag-row-hover-color);
  background-image: linear-gradient(var(--ag-selected-row-background-color), var(--ag-selected-row-background-color));
}
.ag-column-hover {
  background-color: var(--ag-column-hover-color);
}
.ag-header-range-highlight {
  background-color: var(--ag-range-header-highlight-color);
}
.ag-ltr .ag-right-aligned-cell {
  text-align: right;
}
.ag-rtl .ag-right-aligned-cell {
  text-align: left;
}
.ag-ltr .ag-right-aligned-cell .ag-cell-value, .ag-ltr .ag-right-aligned-cell .ag-group-value {
  margin-left: auto;
}
.ag-rtl .ag-right-aligned-cell .ag-cell-value, .ag-rtl .ag-right-aligned-cell .ag-group-value {
  margin-right: auto;
}
.ag-ltr .ag-right-aligned-cell .ag-skeleton-effect {
  margin-left: auto;
}
.ag-rtl .ag-right-aligned-cell .ag-skeleton-effect {
  margin-right: auto;
}
.ag-cell, .ag-full-width-row .ag-cell-wrapper.ag-row-group {
  --ag-internal-calculated-line-height: var(
      --ag-line-height,
      calc(var(--ag-row-height) - var(--ag-row-border-width))
  );
  --ag-internal-padded-row-height: calc(var(--ag-row-height) - var(--ag-row-border-width) - 2px);
  border: 1px solid transparent;
  line-height: min(var(--ag-internal-calculated-line-height), var(--ag-internal-padded-row-height));
  padding-left: calc(var(--ag-cell-horizontal-padding) - 1px + var(--ag-row-group-indent-size) * var(--ag-indentation-level));
  padding-right: calc(var(--ag-cell-horizontal-padding) - 1px);
  -webkit-font-smoothing: subpixel-antialiased;
}
.ag-row > .ag-cell-wrapper {
  padding-left: calc(var(--ag-cell-horizontal-padding) - 1px);
  padding-right: calc(var(--ag-cell-horizontal-padding) - 1px);
}
.ag-row-dragging {
  cursor: move;
  opacity: 0.5;
}
.ag-cell-inline-editing {
  border: 1px solid var(--ag-border-color);
  border-radius: var(--ag-card-radius);
  box-shadow: var(--ag-card-shadow);
  padding: 0;
  background-color: var(--ag-control-panel-background-color);
}
.ag-popup-editor .ag-large-text, .ag-autocomplete-list-popup {
  border: var(--ag-borders) var(--ag-border-color);
  background: var(--ag-background-color);
  border-radius: var(--ag-card-radius);
  box-shadow: var(--ag-card-shadow);
  padding: var(--ag-grid-size);
  background-color: var(--ag-control-panel-background-color);
  padding: 0;
}
.ag-large-text-input {
  height: auto;
  padding: var(--ag-cell-horizontal-padding);
}
.ag-rtl .ag-large-text-input textarea {
  resize: none;
}
.ag-details-row {
  padding: calc(var(--ag-grid-size) * 5);
  background-color: var(--ag-data-background-color);
}
.ag-layout-auto-height .ag-center-cols-viewport, .ag-layout-auto-height .ag-center-cols-container, .ag-layout-print .ag-center-cols-viewport, .ag-layout-print .ag-center-cols-container {
  min-height: 50px;
}
.ag-overlay-loading-wrapper, .ag-overlay-exporting-wrapper, .ag-overlay-modal-wrapper {
  background-color: var(--ag-modal-overlay-background-color);
}
.ag-overlay-loading-center, .ag-overlay-exporting-center {
  border: var(--ag-borders) var(--ag-border-color);
  background: var(--ag-background-color);
  border-radius: var(--ag-card-radius);
  box-shadow: var(--ag-card-shadow);
  padding: var(--ag-grid-size);
  display: flex;
}
.ag-skeleton-container {
  width: 100%;
  height: 100%;
  align-content: center;
}
.ag-skeleton-effect {
  background-color: var(--ag-row-loading-skeleton-effect-color);
  width: 100%;
  height: 1em;
  border-radius: 0.25rem;
  animation: ag-skeleton-loading 1.5s ease-in-out 0.5s infinite;
}
@keyframes ag-skeleton-loading {
  0% {
    opacity: 1;
  }
  50% {
    opacity: 0.4;
  }
  100% {
    opacity: 1;
  }
}
.ag-loading {
  display: flex;
  height: 100%;
  align-items: center;
}
.ag-ltr .ag-loading {
  padding-left: var(--ag-cell-horizontal-padding);
}
.ag-rtl .ag-loading {
  padding-right: var(--ag-cell-horizontal-padding);
}
.ag-ltr .ag-loading-icon {
  padding-right: var(--ag-cell-widget-spacing);
}
.ag-rtl .ag-loading-icon {
  padding-left: var(--ag-cell-widget-spacing);
}
.ag-icon-loading {
  animation-name: spin;
  animation-duration: 1000ms;
  animation-iteration-count: infinite;
  animation-timing-function: linear;
}
@keyframes spin {
  from {
    transform: rotate(0deg);
  }
  to {
    transform: rotate(360deg);
  }
}
.ag-floating-top:not(.ag-invisible) {
  border-bottom: var(--ag-borders-critical) var(--ag-border-color);
}
.ag-floating-bottom:not(.ag-invisible) {
  border-top: var(--ag-borders-critical) var(--ag-border-color);
}
.ag-find-cell {
  display: block;
  overflow: hidden;
  text-overflow: ellipsis;
}
.ag-find-match {
  color: var(--ag-find-match-color);
  background-color: var(--ag-find-match-background-color);
}
.ag-find-active-match {
  color: var(--ag-find-active-match-color);
  background-color: var(--ag-find-active-match-background-color);
}
.ag-ltr .ag-cell {
  border-right: var(--ag-cell-horizontal-border);
}
.ag-rtl .ag-cell {
  border-left: var(--ag-cell-horizontal-border);
}
.ag-ltr .ag-cell {
  border-right-width: 1px;
}
.ag-rtl .ag-cell {
  border-left-width: 1px;
}
.ag-cell.ag-cell-first-right-pinned:not(.ag-cell-range-left):not(.ag-cell-range-single-cell) {
  border-left: var(--ag-borders-critical) var(--ag-border-color);
}
.ag-cell.ag-cell-last-left-pinned:not(.ag-cell-range-right):not(.ag-cell-range-single-cell) {
  border-right: var(--ag-borders-critical) var(--ag-border-color);
}
.ag-cell-range-selected:not(.ag-cell-focus), .ag-cell-range-selected.ag-cell-range-chart, .ag-body-viewport:not(.ag-has-focus) .ag-cell-range-single-cell:not(.ag-cell-inline-editing) {
  background-color: var(--ag-range-selection-background-color);
}
.ag-cell-range-selected:not(.ag-cell-focus).ag-cell-range-chart, .ag-cell-range-selected.ag-cell-range-chart.ag-cell-range-chart, .ag-body-viewport:not(.ag-has-focus) .ag-cell-range-single-cell:not(.ag-cell-inline-editing).ag-cell-range-chart {
  background-color: var(--ag-range-selection-chart-background-color) !important;
}
.ag-cell-range-selected:not(.ag-cell-focus).ag-cell-range-chart.ag-cell-range-chart-category, .ag-cell-range-selected.ag-cell-range-chart.ag-cell-range-chart.ag-cell-range-chart-category, .ag-body-viewport:not(.ag-has-focus) .ag-cell-range-single-cell:not(.ag-cell-inline-editing).ag-cell-range-chart.ag-cell-range-chart-category {
  background-color: var(--ag-range-selection-chart-category-background-color) !important;
}
.ag-cell-range-selected-1:not(.ag-cell-focus), .ag-cell-range-selected-1.ag-cell-range-chart, .ag-cell-range-selected-1.ag-formula-range, .ag-root:not(.ag-context-menu-open) .ag-body-viewport:not(.ag-has-focus) .ag-cell-range-selected-1:not(.ag-cell-inline-editing) {
  background-color: var(--ag-range-selection-background-color);
}
.ag-cell-range-selected-2:not(.ag-cell-focus), .ag-cell-range-selected-2.ag-cell-range-chart, .ag-cell-range-selected-2.ag-formula-range, .ag-body-viewport:not(.ag-has-focus) .ag-cell-range-selected-2 {
  background-color: var(--ag-range-selection-background-color-2);
}
.ag-cell-range-selected-3:not(.ag-cell-focus), .ag-cell-range-selected-3.ag-cell-range-chart, .ag-cell-range-selected-3.ag-formula-range, .ag-body-viewport:not(.ag-has-focus) .ag-cell-range-selected-3 {
  background-color: var(--ag-range-selection-background-color-3);
}
.ag-cell-range-selected-4:not(.ag-cell-focus), .ag-cell-range-selected-4.ag-cell-range-chart, .ag-cell-range-selected-4.ag-formula-range, .ag-body-viewport:not(.ag-has-focus) .ag-cell-range-selected-4 {
  background-color: var(--ag-range-selection-background-color-4);
}
.ag-cell.ag-cell-range-selected:not(.ag-cell-range-single-cell).ag-cell-range-top {
  border-top-color: var(--ag-range-selection-border-color);
  border-top-style: var(--ag-range-selection-border-style);
}
.ag-cell.ag-cell-range-selected:not(.ag-cell-range-single-cell).ag-cell-range-right {
  border-right-color: var(--ag-range-selection-border-color);
  border-right-style: var(--ag-range-selection-border-style);
}
.ag-cell.ag-cell-range-selected:not(.ag-cell-range-single-cell).ag-cell-range-bottom {
  border-bottom-color: var(--ag-range-selection-border-color);
  border-bottom-style: var(--ag-range-selection-border-style);
}
.ag-cell.ag-cell-range-selected:not(.ag-cell-range-single-cell).ag-cell-range-left {
  border-left-color: var(--ag-range-selection-border-color);
  border-left-style: var(--ag-range-selection-border-style);
}
.ag-ltr .ag-cell-focus:not(.ag-cell-range-selected):focus-within, .ag-ltr .ag-context-menu-open .ag-cell-focus:not(.ag-cell-range-selected), .ag-ltr .ag-full-width-row.ag-row-focus:focus .ag-cell-wrapper.ag-row-group, .ag-ltr .ag-cell-range-single-cell, .ag-ltr .ag-cell-range-single-cell.ag-cell-range-handle, .ag-rtl .ag-cell-focus:not(.ag-cell-range-selected):focus-within, .ag-rtl .ag-context-menu-open .ag-cell-focus:not(.ag-cell-range-selected), .ag-rtl .ag-full-width-row.ag-row-focus:focus .ag-cell-wrapper.ag-row-group, .ag-rtl .ag-cell-range-single-cell, .ag-rtl .ag-cell-range-single-cell.ag-cell-range-handle {
  border: 1px solid;
  border-color: var(--ag-range-selection-border-color);
  border-style: var(--ag-range-selection-border-style);
  outline: initial;
}
.ag-cell.ag-selection-fill-top, .ag-cell.ag-selection-fill-top.ag-cell-range-selected {
  border-top: 1px dashed;
  border-top-color: var(--ag-range-selection-border-color);
}
.ag-ltr .ag-cell.ag-selection-fill-right, .ag-ltr .ag-cell.ag-selection-fill-right.ag-cell-range-selected {
  border-right: 1px dashed var(--ag-range-selection-border-color) !important;
}
.ag-rtl .ag-cell.ag-selection-fill-right, .ag-rtl .ag-cell.ag-selection-fill-right.ag-cell-range-selected {
  border-left: 1px dashed var(--ag-range-selection-border-color) !important;
}
.ag-cell.ag-selection-fill-bottom, .ag-cell.ag-selection-fill-bottom.ag-cell-range-selected {
  border-bottom: 1px dashed;
  border-bottom-color: var(--ag-range-selection-border-color);
}
.ag-ltr .ag-cell.ag-selection-fill-left, .ag-ltr .ag-cell.ag-selection-fill-left.ag-cell-range-selected {
  border-left: 1px dashed var(--ag-range-selection-border-color) !important;
}
.ag-rtl .ag-cell.ag-selection-fill-left, .ag-rtl .ag-cell.ag-selection-fill-left.ag-cell-range-selected {
  border-right: 1px dashed var(--ag-range-selection-border-color) !important;
}
.ag-fill-handle, .ag-range-handle {
  position: absolute;
  width: 6px;
  height: 6px;
  bottom: -1px;
  background-color: var(--ag-range-selection-border-color);
}
.ag-ltr .ag-fill-handle, .ag-ltr .ag-range-handle {
  right: -1px;
}
.ag-rtl .ag-fill-handle, .ag-rtl .ag-range-handle {
  left: -1px;
}
.ag-fill-handle {
  cursor: crosshair;
}
.ag-range-handle {
  cursor: nwse-resize;
}
.ag-cell-inline-editing {
  border-color: var(--ag-input-focus-border-color) !important;
}
.ag-cell-inline-editing.ag-cell-editing-error {
  border-color: var(--ag-invalid-color) !important;
}
.ag-menu {
  border: var(--ag-borders) var(--ag-border-color);
  background: var(--ag-background-color);
  border-radius: var(--ag-card-radius);
  box-shadow: var(--ag-card-shadow);
  padding: var(--ag-grid-size);
  background-color: var(--ag-menu-background-color);
  border-color: var(--ag-menu-border-color);
  padding: 0;
}
.ag-menu.ag-tabs {
  min-width: var(--ag-tab-min-width);
}
.ag-menu-list {
  cursor: default;
  padding: var(--ag-grid-size) 0;
}
.ag-menu-separator {
  height: calc(var(--ag-grid-size) * 2 + 1px);
}
.ag-menu-separator-part::after {
  content: "";
  display: block;
  border-top: var(--ag-borders-critical) var(--ag-border-color);
}
.ag-menu-option {
  position: relative;
}
.ag-menu-option:focus-visible {
  outline: none;
}
.ag-menu-option:focus-visible::after {
  content: "";
  position: absolute;
  background-color: transparent;
  pointer-events: none;
  top: 1px;
  left: 1px;
  display: block;
  width: calc(100% - 2px);
  height: calc(100% - 2px);
  border: 1px solid;
  border-color: var(--ag-input-focus-border-color);
}
.ag-menu-option-active, .ag-compact-menu-option-active {
  background-color: var(--ag-row-hover-color);
}
.ag-menu-option-part, .ag-compact-menu-option-part {
  line-height: var(--ag-icon-size);
  padding: calc(var(--ag-grid-size) + 2px) 0;
}
.ag-menu-option-disabled, .ag-compact-menu-option-disabled {
  opacity: 0.5;
}
.ag-menu-option-icon, .ag-compact-menu-option-icon {
  width: var(--ag-icon-size);
}
.ag-ltr .ag-menu-option-icon, .ag-ltr .ag-compact-menu-option-icon {
  padding-left: calc(var(--ag-grid-size) * 2);
}
.ag-rtl .ag-menu-option-icon, .ag-rtl .ag-compact-menu-option-icon {
  padding-right: calc(var(--ag-grid-size) * 2);
}
.ag-menu-option-text, .ag-compact-menu-option-text {
  padding-left: calc(var(--ag-grid-size) * 2);
  padding-right: calc(var(--ag-grid-size) * 2);
}
.ag-ltr .ag-menu-option-shortcut, .ag-ltr .ag-compact-menu-option-shortcut {
  padding-right: var(--ag-grid-size);
}
.ag-rtl .ag-menu-option-shortcut, .ag-rtl .ag-compact-menu-option-shortcut {
  padding-left: var(--ag-grid-size);
}
.ag-ltr .ag-menu-option-popup-pointer, .ag-ltr .ag-compact-menu-option-popup-pointer {
  padding-right: var(--ag-grid-size);
}
.ag-rtl .ag-menu-option-popup-pointer, .ag-rtl .ag-compact-menu-option-popup-pointer {
  padding-left: var(--ag-grid-size);
}
.ag-tabs-header {
  display: flex;
}
.ag-tabs-header-wrapper {
  display: flex;
}
.ag-tabs-header-wrapper .ag-tabs-header {
  flex: 1;
}
.ag-tabs-close-button-wrapper {
  border: 0;
  border-right: var(--ag-borders) var(--ag-border-color);
  padding: var(--ag-grid-size);
}
.ag-tabs-close-button {
  border: 0;
  background-color: unset;
  cursor: pointer;
  padding: 0;
}
.ag-tab {
  border-bottom: var(--ag-selected-tab-underline-width) solid transparent;
  transition: border-bottom var(--ag-selected-tab-underline-transition-speed);
  display: flex;
  flex: none;
  align-items: center;
  justify-content: center;
  cursor: pointer;
}
.ag-tab:focus-visible {
  outline: none;
}
.ag-tab:focus-visible::after {
  content: "";
  position: absolute;
  background-color: transparent;
  pointer-events: none;
  top: 4px;
  left: 4px;
  display: block;
  width: calc(100% - 8px);
  height: calc(100% - 8px);
  border: 1px solid;
  border-color: var(--ag-input-focus-border-color);
}
.ag-tab-selected {
  border-bottom-color: var(--ag-selected-tab-underline-color);
}
.ag-menu-header {
  color: var(--ag-secondary-foreground-color);
}
.ag-filter-separator {
  border-top: var(--ag-borders-critical) var(--ag-border-color);
}
.ag-filter-select .ag-picker-field-wrapper {
  width: 0;
}
.ag-filter-condition-operator {
  height: 17px;
}
.ag-ltr .ag-filter-condition-operator-or {
  margin-left: calc(var(--ag-grid-size) * 2);
}
.ag-rtl .ag-filter-condition-operator-or {
  margin-right: calc(var(--ag-grid-size) * 2);
}
.ag-set-filter-select-all {
  padding-top: var(--ag-widget-container-vertical-padding);
}
.ag-set-filter-list, .ag-filter-no-matches {
  height: calc(var(--ag-list-item-height) * 6);
}
.ag-set-filter-tree-list {
  height: calc(var(--ag-list-item-height) * 10);
}
.ag-set-filter-filter {
  margin-top: var(--ag-widget-container-vertical-padding);
  margin-left: var(--ag-widget-container-horizontal-padding);
  margin-right: var(--ag-widget-container-horizontal-padding);
}
.ag-filter-to {
  margin-top: var(--ag-widget-vertical-spacing);
}
.ag-mini-filter {
  margin: var(--ag-widget-container-vertical-padding) var(--ag-widget-container-horizontal-padding);
}
.ag-set-filter {
  --ag-indentation-level: 0;
}
.ag-ltr .ag-set-filter-item {
  padding-left: calc(var(--ag-widget-container-horizontal-padding) + var(--ag-indentation-level) * var(--ag-set-filter-indent-size));
}
.ag-rtl .ag-set-filter-item {
  padding-right: calc(var(--ag-widget-container-horizontal-padding) + var(--ag-indentation-level) * var(--ag-set-filter-indent-size));
}
.ag-ltr .ag-set-filter-add-group-indent {
  margin-left: calc(var(--ag-icon-size) + var(--ag-widget-container-horizontal-padding));
}
.ag-rtl .ag-set-filter-add-group-indent {
  margin-right: calc(var(--ag-icon-size) + var(--ag-widget-container-horizontal-padding));
}
.ag-ltr .ag-set-filter-group-icons {
  margin-right: var(--ag-widget-container-horizontal-padding);
}
.ag-rtl .ag-set-filter-group-icons {
  margin-left: var(--ag-widget-container-horizontal-padding);
}
.ag-filter-menu .ag-set-filter-list {
  min-width: 200px;
}
.ag-filter-virtual-list-item:focus-visible {
  outline: none;
}
.ag-filter-virtual-list-item:focus-visible::after {
  content: "";
  position: absolute;
  background-color: transparent;
  pointer-events: none;
  top: 1px;
  left: 1px;
  display: block;
  width: calc(100% - 2px);
  height: calc(100% - 2px);
  border: 1px solid;
  border-color: var(--ag-input-focus-border-color);
}
.ag-filter-apply-panel {
  padding: var(--ag-widget-container-vertical-padding) var(--ag-widget-container-horizontal-padding);
  border-top: var(--ag-borders-secondary) var(--ag-secondary-border-color);
}
.ag-filter-apply-panel-button {
  line-height: 1.5;
}
.ag-ltr .ag-filter-apply-panel-button {
  margin-left: calc(var(--ag-grid-size) * 2);
}
.ag-rtl .ag-filter-apply-panel-button {
  margin-right: calc(var(--ag-grid-size) * 2);
}
.ag-simple-filter-body-wrapper {
  display: flex;
  flex-direction: column;
  gap: var(--ag-widget-vertical-spacing);
  padding: var(--ag-widget-container-vertical-padding) var(--ag-widget-container-horizontal-padding);
  padding-bottom: var(--ag-widget-container-vertical-padding);
  overflow-y: auto;
  min-height: calc(var(--ag-list-item-height) + var(--ag-widget-container-vertical-padding) + var(--ag-widget-vertical-spacing));
}
.ag-simple-filter-body-wrapper .ag-resizer-wrapper {
  margin: 0;
}
.ag-menu:not(.ag-tabs) .ag-filter .ag-filter-body-wrapper, .ag-menu:not(.ag-tabs) .ag-filter > *:not(.ag-filter-wrapper) {
  min-width: calc(var(--ag-menu-min-width) - 2px);
}
.ag-filter-no-matches {
  padding: var(--ag-widget-container-vertical-padding) var(--ag-widget-container-horizontal-padding);
}
.ag-multi-filter-menu-item {
  margin: var(--ag-grid-size) 0;
}
.ag-multi-filter-group-title-bar {
  padding: calc(var(--ag-grid-size) * 2) var(--ag-grid-size);
  background-color: transparent;
}
.ag-group-filter-field-select-wrapper {
  padding: var(--ag-widget-container-vertical-padding) var(--ag-widget-container-horizontal-padding);
  padding-bottom: calc(var(--ag-widget-container-vertical-padding) - var(--ag-widget-vertical-spacing));
}
.ag-group-filter-field-select-wrapper > * {
  margin-bottom: var(--ag-widget-vertical-spacing);
}
.ag-multi-filter-group-title-bar:focus-visible {
  outline: none;
}
.ag-multi-filter-group-title-bar:focus-visible::after {
  content: "";
  position: absolute;
  background-color: transparent;
  pointer-events: none;
  top: 4px;
  left: 4px;
  display: block;
  width: calc(100% - 8px);
  height: calc(100% - 8px);
  border: 1px solid;
  border-color: var(--ag-input-focus-border-color);
}
.ag-side-bar {
  position: relative;
}
.ag-tool-panel-wrapper {
  width: var(--ag-horizontal-size, var(--ag-side-bar-panel-width));
  background-color: var(--ag-control-panel-background-color);
}
.ag-tool-panel-content {
  display: flex;
  height: 100%;
  overflow: hidden auto;
}
.ag-tool-panel-wrapper.ag-tool-panel-animating {
  display: block !important;
  transition: width var(--ag-side-bar-panel-animation-duration) ease-in-out;
}
@media (prefers-reduced-motion: reduce) {
  .ag-tool-panel-wrapper.ag-tool-panel-animating {
    transition: none;
  }
}
.ag-tool-panel-external {
  display: flex;
  flex-direction: row;
}
:where(.ag-tool-panel-external) .ag-tool-panel-wrapper {
  flex-grow: 1;
}
.ag-side-buttons {
  padding-top: calc(var(--ag-grid-size) * 4);
  width: calc(var(--ag-icon-size) + 4px);
  position: relative;
  overflow: hidden;
}
button.ag-side-button-button {
  color: inherit;
  font-family: inherit;
  font-size: inherit;
  font-weight: inherit;
  line-height: inherit;
  background: transparent;
  padding: calc(var(--ag-grid-size) * 2) 0 calc(var(--ag-grid-size) * 2) 0;
  width: 100%;
  margin: 0;
  min-height: calc(var(--ag-grid-size) * 18);
  background-position-y: center;
  background-position-x: center;
  background-repeat: no-repeat;
  border: none;
  border-top: var(--ag-borders-side-button) var(--ag-border-color);
  border-bottom: var(--ag-borders-side-button) var(--ag-border-color);
}
button.ag-side-button-button:focus {
  box-shadow: none;
}
.ag-side-button-button:focus-visible {
  outline: none;
}
.ag-side-button-button:focus-visible::after {
  content: "";
  position: absolute;
  background-color: transparent;
  pointer-events: none;
  top: 4px;
  left: 4px;
  display: block;
  width: calc(100% - 8px);
  height: calc(100% - 8px);
  border: 1px solid;
  border-color: var(--ag-input-focus-border-color);
}
.ag-selected button.ag-side-button-button {
  background-color: var(--ag-side-button-selected-background-color);
}
.ag-side-button-icon-wrapper {
  margin-bottom: 3px;
}
.ag-ltr .ag-side-bar-left, .ag-rtl .ag-side-bar-right {
  border-right: var(--ag-borders) var(--ag-border-color);
}
.ag-ltr .ag-side-bar-left .ag-tool-panel-wrapper, .ag-rtl .ag-side-bar-right .ag-tool-panel-wrapper {
  border-left: var(--ag-borders) var(--ag-border-color);
}
.ag-ltr .ag-side-bar-left .ag-side-button-button, .ag-rtl .ag-side-bar-right .ag-side-button-button {
  border-right: var(--ag-selected-tab-underline-width) solid transparent;
  transition: border-right var(--ag-selected-tab-underline-transition-speed);
}
.ag-ltr .ag-side-bar-left .ag-selected .ag-side-button-button, .ag-rtl .ag-side-bar-right .ag-selected .ag-side-button-button {
  border-right-color: var(--ag-selected-tab-underline-color);
}
.ag-rtl .ag-side-bar-left, .ag-ltr .ag-side-bar-right {
  border-left: var(--ag-borders) var(--ag-border-color);
}
.ag-rtl .ag-side-bar-left .ag-tool-panel-wrapper, .ag-ltr .ag-side-bar-right .ag-tool-panel-wrapper {
  border-right: var(--ag-borders) var(--ag-border-color);
}
.ag-rtl .ag-side-bar-left .ag-side-button-button, .ag-ltr .ag-side-bar-right .ag-side-button-button {
  border-left: var(--ag-selected-tab-underline-width) solid transparent;
  transition: border-left var(--ag-selected-tab-underline-transition-speed);
}
.ag-rtl .ag-side-bar-left .ag-selected .ag-side-button-button, .ag-ltr .ag-side-bar-right .ag-selected .ag-side-button-button {
  border-left-color: var(--ag-selected-tab-underline-color);
}
.ag-filter-toolpanel-header {
  height: calc(var(--ag-grid-size) * 6);
}
.ag-filter-toolpanel-header, .ag-filter-toolpanel-search {
  padding: 0 var(--ag-grid-size);
}
.ag-filter-toolpanel-header:focus-visible {
  outline: none;
}
.ag-filter-toolpanel-header:focus-visible::after {
  content: "";
  position: absolute;
  background-color: transparent;
  pointer-events: none;
  top: 4px;
  left: 4px;
  display: block;
  width: calc(100% - 8px);
  height: calc(100% - 8px);
  border: 1px solid;
  border-color: var(--ag-input-focus-border-color);
}
.ag-filter-toolpanel-group:not(.ag-has-filter) > .ag-group-title-bar .ag-filter-toolpanel-group-instance-header-icon {
  display: none;
}
.ag-filter-toolpanel-group-level-0-header {
  height: calc(var(--ag-grid-size) * 8);
}
.ag-filter-toolpanel-group-item {
  margin-top: calc(var(--ag-grid-size) * 0.5);
  margin-bottom: calc(var(--ag-grid-size) * 0.5);
}
.ag-filter-toolpanel-search {
  height: var(--ag-header-height);
}
.ag-filter-toolpanel-search-input {
  flex-grow: 1;
  height: calc(var(--ag-grid-size) * 4);
}
.ag-ltr .ag-filter-toolpanel-search-input {
  margin-right: var(--ag-grid-size);
}
.ag-rtl .ag-filter-toolpanel-search-input {
  margin-left: var(--ag-grid-size);
}
.ag-filter-toolpanel-group-level-0 {
  border-top: var(--ag-borders-secondary) var(--ag-secondary-border-color);
}
.ag-ltr .ag-filter-toolpanel-expand, .ag-ltr .ag-filter-toolpanel-group-title-bar-icon {
  margin-right: var(--ag-grid-size);
}
.ag-rtl .ag-filter-toolpanel-expand, .ag-rtl .ag-filter-toolpanel-group-title-bar-icon {
  margin-left: var(--ag-grid-size);
}
.ag-filter-toolpanel-group-title-bar {
  background-color: transparent;
}
.ag-ltr .ag-filter-toolpanel-header {
  padding-left: calc(var(--ag-filter-tool-panel-group-indent) * var(--ag-indentation-level, 0) + var(--ag-grid-size));
}
.ag-rtl .ag-filter-toolpanel-header {
  padding-right: calc(var(--ag-filter-tool-panel-group-indent) * var(--ag-indentation-level, 0) + var(--ag-grid-size));
}
.ag-filter-toolpanel-instance-filter {
  border-bottom: var(--ag-borders) var(--ag-border-color);
  border-top: var(--ag-borders) var(--ag-border-color);
  margin-top: var(--ag-grid-size);
}
.ag-ltr .ag-filter-toolpanel-group-instance-header-icon, .ag-ltr .ag-filter-toolpanel-instance-header-icon {
  margin-left: var(--ag-grid-size);
}
.ag-rtl .ag-filter-toolpanel-group-instance-header-icon, .ag-rtl .ag-filter-toolpanel-instance-header-icon {
  margin-right: var(--ag-grid-size);
}
.ag-set-filter-group-icons {
  color: var(--ag-secondary-foreground-color);
}
.ag-filter-panel {
  display: flex;
  flex-direction: column;
  width: 100%;
}
.ag-filter-panel .ag-simple-filter-body-wrapper {
  padding: var(--ag-widget-vertical-spacing) var(--ag-widget-container-horizontal-padding) 0;
}
.ag-filter-panel .ag-mini-filter {
  margin-top: var(--ag-widget-vertical-spacing);
  margin-left: var(--ag-widget-container-horizontal-padding);
  margin-right: var(--ag-widget-container-horizontal-padding);
}
.ag-filter-panel .ag-standard-button {
  transition: background-color 0.25s ease-in-out, color 0.25s ease-in-out;
}
.ag-filter-panel .ag-simple-filter-body-wrapper > *:last-child, .ag-filter-panel .ag-set-filter-body-wrapper {
  margin-bottom: var(--ag-widget-container-vertical-padding);
}
.ag-filter-panel-container {
  flex: 1;
  overflow: auto;
  padding: var(--ag-widget-container-vertical-padding) var(--ag-widget-container-horizontal-padding) 0;
}
.ag-filter-panel-container > *:not(:last-child) {
  margin-bottom: var(--ag-widget-container-vertical-padding);
}
.ag-filter-card {
  border: 1px solid var(--ag-border-color);
  border-radius: var(--ag-border-radius);
  background-color: var(--ag-background-color);
}
.ag-ltr .ag-filter-card .ag-set-filter-item {
  padding-left: calc(var(--ag-widget-container-horizontal-padding) + var(--ag-indentation-level) * var(--ag-set-filter-indent-size));
  padding-right: var(--ag-widget-container-horizontal-padding);
}
.ag-rtl .ag-filter-card .ag-set-filter-item {
  padding-right: calc(var(--ag-widget-container-horizontal-padding) + var(--ag-indentation-level) * var(--ag-set-filter-indent-size));
  padding-left: var(--ag-widget-container-horizontal-padding);
}
.ag-filter-card-header {
  display: flex;
  flex-direction: row;
  align-items: center;
  padding-top: var(--ag-widget-vertical-spacing);
}
.ag-ltr .ag-filter-card-header > *:not(:last-child) {
  padding-right: var(--ag-grid-size);
}
.ag-rtl .ag-filter-card-header > *:not(:last-child) {
  padding-left: var(--ag-grid-size);
}
.ag-filter-card-heading {
  flex: 1;
  overflow: hidden;
  padding-top: calc(var(--ag-widget-container-vertical-padding) - var(--ag-widget-vertical-spacing));
  padding-bottom: calc(var(--ag-widget-container-vertical-padding) - var(--ag-widget-vertical-spacing));
}
.ag-ltr .ag-filter-card-heading {
  padding-left: var(--ag-widget-horizontal-spacing);
}
.ag-rtl .ag-filter-card-heading {
  padding-right: var(--ag-widget-horizontal-spacing);
}
.ag-filter-card-expand {
  display: flex;
  flex-direction: row;
  width: 100%;
  justify-content: space-between;
  align-items: center;
}
.ag-filter-card-title {
  overflow: hidden;
  text-overflow: ellipsis;
}
.ag-filter-card-expand-icon {
  display: flex;
  flex: 1;
  justify-content: end;
}
.ag-filter-card-editing-icon {
  margin: 0 var(--ag-grid-size);
}
.ag-filter-card-summary, .ag-filter-card-expand-icon .ag-icon, .ag-filter-card-delete-icon .ag-icon, .ag-filter-card-editing-icon .ag-icon {
  color: var(--ag-filter-panel-card-subtle-color);
}
.ag-filter-card-expand-icon .ag-icon, .ag-filter-card-delete-icon .ag-icon {
  transition: color 0.25s ease-in-out;
}
.ag-filter-card-expand-icon:hover .ag-icon, .ag-filter-card-delete-icon:hover .ag-icon {
  color: var(--ag-filter-panel-card-subtle-hover-color);
}
.ag-filter-card-heading:hover .ag-filter-card-expand-icon .ag-icon {
  color: var(--ag-filter-panel-card-subtle-hover-color);
}
.ag-filter-card-expand, .ag-filter-card-delete {
  border-radius: var(--ag-button-border-radius);
  background: none;
  border: none;
  cursor: pointer;
  padding: 0;
}
.ag-filter-panel .ag-standard-button {
  cursor: pointer;
}
.ag-filter-card-summary, .ag-filter-type-select {
  margin-left: var(--ag-widget-container-horizontal-padding);
  margin-right: var(--ag-widget-container-horizontal-padding);
}
.ag-ltr .ag-filter-card-delete {
  margin-right: var(--ag-widget-horizontal-spacing);
}
.ag-rtl .ag-filter-card-delete {
  margin-left: var(--ag-widget-horizontal-spacing);
}
.ag-filter-card-summary {
  margin-bottom: var(--ag-widget-container-vertical-padding);
}
.ag-filter-type-select {
  padding-top: var(--ag-widget-vertical-spacing);
}
.ag-filter-card-add {
  padding: 0;
  border: 0;
}
.ag-filter-add-button {
  display: flex;
  flex-direction: row;
  width: 100%;
  align-items: center;
  line-height: 1.5;
}
.ag-ltr .ag-filter-add-button-label {
  margin-left: var(--ag-grid-size);
}
.ag-rtl .ag-filter-add-button-label {
  margin-right: var(--ag-grid-size);
}
.ag-filter-add-select {
  border: 0;
}
.ag-ltr .ag-filter-add-select .ag-text-field-input {
  padding-left: calc(var(--ag-grid-size) * 1.5 + 12px) !important;
}
.ag-rtl .ag-filter-add-select .ag-text-field-input {
  padding-right: calc(var(--ag-grid-size) * 1.5 + 12px) !important;
}
.ag-filter-add-select .ag-rich-select-value {
  padding: calc((1.5 * var(--ag-font-size) + 4 * var(--ag-grid-size) - var(--ag-input-height)) / 2) var(--ag-grid-size);
  border: 0;
}
.ag-pivot-mode-panel {
  min-height: var(--ag-header-height);
  height: var(--ag-header-height);
  display: flex;
}
.ag-pivot-mode-select {
  display: flex;
  align-items: center;
}
.ag-ltr .ag-pivot-mode-select {
  margin-left: var(--ag-widget-container-horizontal-padding);
}
.ag-rtl .ag-pivot-mode-select {
  margin-right: var(--ag-widget-container-horizontal-padding);
}
.ag-column-select-header:focus-visible {
  outline: none;
}
.ag-column-select-header:focus-visible::after {
  content: "";
  position: absolute;
  background-color: transparent;
  pointer-events: none;
  top: 4px;
  left: 4px;
  display: block;
  width: calc(100% - 8px);
  height: calc(100% - 8px);
  border: 1px solid;
  border-color: var(--ag-input-focus-border-color);
}
.ag-column-select-header {
  height: var(--ag-header-height);
  align-items: center;
  padding: 0 var(--ag-widget-container-horizontal-padding);
  border-bottom: var(--ag-borders-secondary) var(--ag-secondary-border-color);
}
.ag-column-panel-column-select {
  border-top: var(--ag-borders-secondary) var(--ag-secondary-border-color);
}
.ag-column-panel-column-select:not(.ag-last-visible-child) {
  border-bottom: var(--ag-borders-secondary) var(--ag-secondary-border-color);
}
.ag-column-panel-buttons {
  display: flex;
  justify-content: flex-end;
  overflow: hidden;
  padding: var(--ag-widget-container-vertical-padding) var(--ag-widget-container-horizontal-padding) 0;
  flex-wrap: wrap;
  gap: var(--ag-widget-vertical-spacing) var(--ag-widget-horizontal-spacing);
}
.ag-column-panel-buttons .ag-standard-button {
  transition: background-color 0.25s ease-in-out, color 0.25s ease-in-out;
}
.ag-column-panel-buttons:last-child {
  padding-bottom: var(--ag-widget-container-vertical-padding);
}
.ag-column-panel-buttons-button {
  line-height: 1.5;
}
.ag-column-panel .ag-standard-button.ag-column-panel-buttons-apply-button:not(:disabled) {
  color: var(--ag-column-panel-apply-button-color);
  background-color: var(--ag-column-panel-apply-button-background-color);
}
.ag-column-group-icons, .ag-column-select-header-icon {
  color: var(--ag-secondary-foreground-color);
}
.ag-column-select-list .ag-list-item-hovered::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  height: 1px;
}
.ag-column-select-list .ag-item-highlight-top::after {
  top: 0;
}
.ag-column-select-list .ag-item-highlight-bottom::after {
  bottom: 0;
}
.ag-header, .ag-advanced-filter-header {
  background-color: var(--ag-header-background-color);
  border-bottom: var(--ag-borders-critical) var(--ag-border-color);
}
.ag-header-row {
  color: var(--ag-header-foreground-color);
  height: var(--ag-header-height);
}
.ag-pinned-right-header {
  border-left: var(--ag-borders-critical) var(--ag-border-color);
}
.ag-pinned-left-header {
  border-right: var(--ag-borders-critical) var(--ag-border-color);
}
.ag-header-cell:not(.ag-right-aligned-header) .ag-header-col-ref {
  margin-right: var(--ag-grid-size);
  color: var(--ag-subtle-text-color);
}
.ag-ltr .ag-header-cell:not(.ag-right-aligned-header) .ag-header-label-icon, .ag-ltr .ag-header-cell:not(.ag-right-aligned-header) .ag-header-menu-icon {
  margin-left: var(--ag-grid-size);
}
.ag-rtl .ag-header-cell:not(.ag-right-aligned-header) .ag-header-label-icon, .ag-rtl .ag-header-cell:not(.ag-right-aligned-header) .ag-header-menu-icon {
  margin-right: var(--ag-grid-size);
}
.ag-header-cell.ag-right-aligned-header .ag-header-col-ref {
  margin-left: var(--ag-grid-size);
  color: var(--ag-subtle-text-color);
}
.ag-ltr .ag-header-cell.ag-right-aligned-header .ag-header-label-icon, .ag-ltr .ag-header-cell.ag-right-aligned-header .ag-header-menu-icon {
  margin-right: var(--ag-grid-size);
}
.ag-rtl .ag-header-cell.ag-right-aligned-header .ag-header-label-icon, .ag-rtl .ag-header-cell.ag-right-aligned-header .ag-header-menu-icon {
  margin-left: var(--ag-grid-size);
}
.ag-header-cell, .ag-header-group-cell {
  padding-left: var(--ag-cell-horizontal-padding);
  padding-right: var(--ag-cell-horizontal-padding);
}
.ag-header-cell.ag-header-cell-moving, .ag-header-group-cell.ag-header-cell-moving {
  background-color: var(--ag-header-cell-moving-background-color);
}
.ag-ltr .ag-header-group-cell-label.ag-sticky-label {
  left: var(--ag-cell-horizontal-padding);
}
.ag-rtl .ag-header-group-cell-label.ag-sticky-label {
  right: var(--ag-cell-horizontal-padding);
}
.ag-header-cell:focus-visible {
  outline: none;
}
.ag-header-cell:focus-visible::after {
  content: "";
  position: absolute;
  background-color: transparent;
  pointer-events: none;
  top: 4px;
  left: 4px;
  display: block;
  width: calc(100% - 8px);
  height: calc(100% - 8px);
  border: 1px solid;
  border-color: var(--ag-input-focus-border-color);
}
.ag-header-group-cell:focus-visible {
  outline: none;
}
.ag-header-group-cell:focus-visible::after {
  content: "";
  position: absolute;
  background-color: transparent;
  pointer-events: none;
  top: 4px;
  left: 4px;
  display: block;
  width: calc(100% - 8px);
  height: calc(100% - 8px);
  border: 1px solid;
  border-color: var(--ag-input-focus-border-color);
}
.ag-advanced-filter-header-cell:focus-visible {
  outline: none;
}
.ag-advanced-filter-header-cell:focus-visible::after {
  content: "";
  position: absolute;
  background-color: transparent;
  pointer-events: none;
  top: 4px;
  left: 4px;
  display: block;
  width: calc(100% - 8px);
  height: calc(100% - 8px);
  border: 1px solid;
  border-color: var(--ag-input-focus-border-color);
}
.ag-header-icon {
  color: var(--ag-secondary-foreground-color);
}
.ag-header-expand-icon {
  cursor: pointer;
}
.ag-ltr .ag-header-expand-icon {
  margin-left: 4px;
}
.ag-rtl .ag-header-expand-icon {
  margin-right: 4px;
}
.ag-header-row:not(:first-child) .ag-header-cell:not(.ag-header-span-height.ag-header-span-total, .ag-header-parent-hidden), .ag-header-row:not(:first-child) .ag-header-group-cell.ag-header-group-cell-with-group {
  border-top: var(--ag-borders-critical) var(--ag-border-color);
}
.ag-header-group-cell:not(.ag-column-resizing) + .ag-header-group-cell:not(.ag-column-hover):not(.ag-header-cell-moving):hover, .ag-header-group-cell:not(.ag-column-resizing) + .ag-header-group-cell:not(.ag-column-hover).ag-column-resizing, .ag-header-cell:not(.ag-column-resizing) + .ag-header-cell:not(.ag-column-hover):not(.ag-header-cell-moving):hover, .ag-header-cell:not(.ag-column-resizing) + .ag-header-cell:not(.ag-column-hover).ag-column-resizing, .ag-header-group-cell:first-of-type:not(.ag-header-cell-moving):hover, .ag-header-group-cell:first-of-type.ag-column-resizing, .ag-header-cell:not(.ag-column-hover):first-of-type:not(.ag-header-cell-moving):hover, .ag-header-cell:not(.ag-column-hover):first-of-type.ag-column-resizing {
  background-color: var(--ag-header-cell-hover-background-color);
}
.ag-header-cell::before, .ag-header-group-cell:not(.ag-header-span-height.ag-header-group-cell-no-group)::before {
  content: "";
  position: absolute;
  z-index: 1;
  display: var(--ag-header-column-separator-display);
  width: var(--ag-header-column-separator-width);
  height: var(--ag-header-column-separator-height);
  top: calc(50% - var(--ag-header-column-separator-height) * 0.5);
  background-color: var(--ag-header-column-separator-color);
}
.ag-ltr .ag-header-cell::before, .ag-ltr .ag-header-group-cell:not(.ag-header-span-height.ag-header-group-cell-no-group)::before {
  right: 0;
}
.ag-rtl .ag-header-cell::before, .ag-rtl .ag-header-group-cell:not(.ag-header-span-height.ag-header-group-cell-no-group)::before {
  left: 0;
}
.ag-header-highlight-before::after, .ag-header-highlight-after::after {
  content: "";
  position: absolute;
  height: 100%;
  width: var(--ag-column-drag-indicator-width);
  border-radius: calc(var(--ag-column-drag-indicator-width) / 2);
  background-color: var(--ag-column-drag-indicator-color);
}
.ag-header-highlight-before::after {
  left: 0px;
}
.ag-header-highlight-after::after {
  right: 0px;
}
.ag-pinned-left-header .ag-header-highlight-after::after {
  right: 1px;
}
.ag-header-cell-resize {
  display: flex;
  align-items: center;
}
.ag-header-cell-resize::after {
  content: "";
  position: absolute;
  z-index: 1;
  display: var(--ag-header-column-resize-handle-display);
  width: var(--ag-header-column-resize-handle-width);
  height: var(--ag-header-column-resize-handle-height);
  top: calc(50% - var(--ag-header-column-resize-handle-height) * 0.5);
  background-color: var(--ag-header-column-resize-handle-color);
}
.ag-header-cell.ag-header-span-height .ag-header-cell-resize::after {
  height: calc(100% - var(--ag-grid-size) * 4);
  top: calc(var(--ag-grid-size) * 2);
}
.ag-ltr .ag-header-viewport .ag-header-cell-resize::after {
  left: calc(50% - var(--ag-header-column-resize-handle-width));
}
.ag-rtl .ag-header-viewport .ag-header-cell-resize::after {
  right: calc(50% - var(--ag-header-column-resize-handle-width));
}
.ag-pinned-left-header .ag-header-cell-resize::after {
  left: calc(50% - var(--ag-header-column-resize-handle-width));
}
.ag-pinned-right-header .ag-header-cell-resize::after {
  left: 50%;
}
.ag-ltr .ag-header-select-all {
  margin-right: var(--ag-cell-horizontal-padding);
}
.ag-rtl .ag-header-select-all {
  margin-left: var(--ag-cell-horizontal-padding);
}
.ag-ltr .ag-floating-filter-button {
  margin-left: var(--ag-cell-widget-spacing);
}
.ag-rtl .ag-floating-filter-button {
  margin-right: var(--ag-cell-widget-spacing);
}
.ag-floating-filter-button-button {
  color: inherit;
  font-family: inherit;
  font-size: inherit;
  font-weight: inherit;
  line-height: inherit;
  appearance: none;
  background: transparent;
  border: none;
  height: var(--ag-icon-size);
  padding: 0;
  width: var(--ag-icon-size);
}
.ag-filter-loading {
  background-color: var(--ag-control-panel-background-color);
  height: 100%;
  padding: var(--ag-widget-container-vertical-padding) var(--ag-widget-container-horizontal-padding);
  position: absolute;
  width: 100%;
  z-index: 1;
  align-items: unset;
}
.ag-paging-panel {
  border-top: 1px solid;
  border-top-color: var(--ag-border-color);
  color: var(--ag-secondary-foreground-color);
  height: var(--ag-pagination-panel-height);
}
.ag-paging-panel > * {
  margin: 0 var(--ag-cell-horizontal-padding);
}
.ag-paging-panel > .ag-paging-page-size .ag-wrapper {
  min-width: calc(var(--ag-grid-size) * 10);
}
.ag-paging-button {
  cursor: pointer;
}
.ag-paging-button.ag-disabled {
  cursor: default;
  color: var(--ag-disabled-foreground-color);
}
.ag-paging-button:focus-visible {
  outline: none;
}
.ag-paging-button:focus-visible::after {
  content: "";
  position: absolute;
  background-color: transparent;
  pointer-events: none;
  top: 0px;
  left: 0px;
  display: block;
  width: calc(100% - 0px);
  height: calc(100% - 0px);
  border: 1px solid;
  border-color: var(--ag-input-focus-border-color);
}
.ag-paging-button, .ag-paging-description {
  margin: 0 var(--ag-grid-size);
  line-height: 0;
}
.ag-status-bar {
  border-top: var(--ag-borders) var(--ag-border-color);
  color: var(--ag-disabled-foreground-color);
  padding-right: calc(var(--ag-grid-size) * 4);
  padding-left: calc(var(--ag-grid-size) * 4);
  line-height: 1.5;
}
.ag-status-name-value-value {
  color: var(--ag-foreground-color);
}
.ag-status-bar-center {
  text-align: center;
}
.ag-status-name-value {
  margin-left: var(--ag-grid-size);
  margin-right: var(--ag-grid-size);
  padding-top: calc(var(--ag-grid-size) * 2);
  padding-bottom: calc(var(--ag-grid-size) * 2);
}
.ag-column-drop-cell {
  background: var(--ag-chip-background-color);
  border-radius: calc(var(--ag-grid-size) * 4);
  height: calc(var(--ag-grid-size) * 4);
  padding: 0 calc(var(--ag-grid-size) * 0.5);
  border: 1px solid var(--ag-chip-border-color);
}
.ag-column-drop-cell:focus-visible {
  outline: none;
}
.ag-column-drop-cell:focus-visible::after {
  content: "";
  position: absolute;
  background-color: transparent;
  pointer-events: none;
  top: 2px;
  left: 2px;
  display: block;
  width: calc(100% - 4px);
  height: calc(100% - 4px);
  border: 1px solid;
  border-color: var(--ag-input-focus-border-color);
}
.ag-column-drop-cell-text {
  margin: 0 var(--ag-grid-size);
}
.ag-column-drop-cell-button {
  min-width: calc(var(--ag-grid-size) * 4);
  margin: 0 calc(var(--ag-grid-size) * 0.5);
  color: var(--ag-secondary-foreground-color);
}
.ag-column-drop-cell-drag-handle {
  margin-left: calc(var(--ag-grid-size) * 2);
}
.ag-column-drop-cell-ghost {
  opacity: 0.5;
}
.ag-column-drop-horizontal {
  background-color: var(--ag-header-background-color);
  color: var(--ag-secondary-foreground-color);
  height: var(--ag-header-height);
  border-bottom: var(--ag-borders) var(--ag-border-color);
}
.ag-ltr .ag-column-drop-horizontal {
  padding-left: var(--ag-cell-horizontal-padding);
}
.ag-rtl .ag-column-drop-horizontal {
  padding-right: var(--ag-cell-horizontal-padding);
}
.ag-ltr .ag-column-drop-horizontal-half-width:not(:last-child) {
  border-right: var(--ag-borders) var(--ag-border-color);
}
.ag-rtl .ag-column-drop-horizontal-half-width:not(:last-child) {
  border-left: var(--ag-borders) var(--ag-border-color);
}
.ag-column-drop-horizontal-cell-separator {
  margin: 0 var(--ag-grid-size);
  color: var(--ag-secondary-foreground-color);
}
.ag-column-drop-horizontal-empty-message {
  color: var(--ag-disabled-foreground-color);
}
.ag-ltr .ag-column-drop-horizontal-icon {
  margin-right: var(--ag-cell-horizontal-padding);
}
.ag-rtl .ag-column-drop-horizontal-icon {
  margin-left: var(--ag-cell-horizontal-padding);
}
.ag-column-drop-vertical-list {
  padding-bottom: var(--ag-grid-size);
  padding-right: var(--ag-grid-size);
  padding-left: var(--ag-grid-size);
}
.ag-column-drop-vertical-cell {
  margin-top: var(--ag-grid-size);
}
.ag-column-drop-vertical {
  min-height: 50px;
  border-bottom: var(--ag-borders-secondary) var(--ag-secondary-border-color);
}
.ag-column-drop-vertical.ag-last-column-drop {
  border-bottom: none;
}
.ag-column-drop-vertical-icon {
  margin-left: var(--ag-grid-size);
  margin-right: var(--ag-grid-size);
}
.ag-column-drop-vertical-empty-message {
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  overflow: hidden;
  color: var(--ag-disabled-foreground-color);
  margin-top: var(--ag-grid-size);
}
.ag-select-agg-func-popup {
  border: var(--ag-borders) var(--ag-border-color);
  border-radius: var(--ag-card-radius);
  box-shadow: var(--ag-card-shadow);
  padding: var(--ag-grid-size);
  background: var(--ag-background-color);
  height: calc(var(--ag-grid-size) * 5 * 3.5);
  padding: 0;
}
.ag-select-agg-func-virtual-list-item {
  cursor: default;
}
.ag-ltr .ag-select-agg-func-virtual-list-item {
  padding-left: calc(var(--ag-grid-size) * 2);
}
.ag-rtl .ag-select-agg-func-virtual-list-item {
  padding-right: calc(var(--ag-grid-size) * 2);
}
.ag-select-agg-func-virtual-list-item:hover {
  background-color: var(--ag-selected-row-background-color);
}
.ag-select-agg-func-virtual-list-item:focus-visible {
  outline: none;
}
.ag-select-agg-func-virtual-list-item:focus-visible::after {
  content: "";
  position: absolute;
  background-color: transparent;
  pointer-events: none;
  top: 1px;
  left: 1px;
  display: block;
  width: calc(100% - 2px);
  height: calc(100% - 2px);
  border: 1px solid;
  border-color: var(--ag-input-focus-border-color);
}
.ag-sort-indicator-container {
  display: flex;
}
.ag-ltr .ag-sort-indicator-icon {
  padding-left: var(--ag-grid-size);
}
.ag-rtl .ag-sort-indicator-icon {
  padding-right: var(--ag-grid-size);
}
.ag-chart {
  position: relative;
  display: flex;
  width: 100%;
  height: 100%;
}
.ag-chart-components-wrapper {
  position: relative;
  display: flex;
  flex: 1 1 auto;
}
.ag-chart-canvas-wrapper {
  position: relative;
  flex: 1 1 auto;
}
.ag-chart-menu {
  position: absolute;
  top: 16px;
  display: flex;
  flex-direction: column;
}
.ag-ltr .ag-chart-menu {
  right: 20px;
}
.ag-rtl .ag-chart-menu {
  left: 20px;
}
.ag-chart-docked-container {
  position: relative;
  min-width: var(--ag-chart-menu-panel-width);
}
.ag-chart-menu-hidden ~ .ag-chart-docked-container {
  display: none;
}
.ag-chart-tabbed-menu {
  width: 100%;
  height: 100%;
  display: flex;
  flex-direction: column;
  overflow: hidden;
}
.ag-chart-tabbed-menu-header {
  flex: none;
  -moz-user-select: none;
  -webkit-user-select: none;
  -ms-user-select: none;
  user-select: none;
  cursor: default;
}
.ag-chart-tabbed-menu-body {
  display: flex;
  flex: 1 1 auto;
  align-items: stretch;
  overflow: hidden;
}
.ag-chart-tab {
  width: 100%;
  overflow: hidden;
  overflow-y: auto;
}
.ag-chart-settings {
  overflow-x: hidden;
}
.ag-chart-settings-wrapper {
  position: relative;
  flex-direction: column;
  width: 100%;
  height: 100%;
  display: flex;
  overflow: hidden;
}
.ag-chart-settings-nav-bar {
  display: flex;
  align-items: center;
  width: 100%;
  height: 30px;
  padding: 0 10px;
  -moz-user-select: none;
  -webkit-user-select: none;
  -ms-user-select: none;
  user-select: none;
}
.ag-chart-settings-card-selector {
  display: flex;
  align-items: center;
  justify-content: space-around;
  flex: 1 1 auto;
  height: 100%;
  padding: 0 10px;
}
.ag-chart-settings-card-item {
  cursor: pointer;
  width: 10px;
  height: 10px;
  background-color: #000;
  position: relative;
}
.ag-chart-settings-card-item.ag-not-selected {
  opacity: 0.2;
}
.ag-chart-settings-card-item::before {
  content: " ";
  display: block;
  position: absolute;
  background-color: transparent;
  left: 50%;
  top: 50%;
  margin-left: -10px;
  margin-top: -10px;
  width: 20px;
  height: 20px;
}
.ag-chart-settings-prev, .ag-chart-settings-next {
  position: relative;
  flex: none;
}
.ag-chart-settings-prev:focus-within, .ag-chart-settings-next:focus-within {
  box-shadow: var(--ag-input-focus-box-shadow);
  border-radius: 1px;
}
.ag-chart-settings-prev-button, .ag-chart-settings-next-button {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  cursor: pointer;
  opacity: 0;
}
.ag-chart-settings-mini-charts-container {
  position: relative;
  flex: 1 1 auto;
  overflow-x: hidden;
  overflow-y: auto;
}
.ag-chart-settings-mini-wrapper {
  position: absolute;
  top: 0;
  left: 0;
  display: flex;
  flex-direction: column;
  width: 100%;
  min-height: 100%;
  overflow: hidden;
}
.ag-chart-settings-mini-wrapper.ag-animating {
  transition: left 0.3s;
  transition-timing-function: ease-in-out;
}
.ag-chart-mini-thumbnail {
  cursor: pointer;
}
.ag-chart-mini-thumbnail-canvas {
  display: block;
}
.ag-chart-data-wrapper, .ag-chart-format-wrapper, .ag-chart-advanced-settings-wrapper {
  display: flex;
  flex-direction: column;
  position: relative;
  -moz-user-select: none;
  -webkit-user-select: none;
  -ms-user-select: none;
  user-select: none;
  padding-bottom: 16px;
}
.ag-chart-data-wrapper, .ag-chart-advanced-settings-wrapper {
  height: 100%;
  overflow-y: auto;
}
.ag-chart-advanced-settings {
  background-color: var(--ag-control-panel-background-color);
}
.ag-chart-advanced-settings-wrapper, .ag-chart-advanced-settings {
  width: 100%;
}
.ag-chart-advanced-settings-wrapper {
  padding-bottom: 0;
}
.ag-chart-data-section, .ag-chart-format-section, .ag-chart-advanced-settings-section {
  display: flex;
  margin: 0;
}
.ag-chart-advanced-settings-section {
  padding-top: var(--ag-grid-size);
  padding-bottom: var(--ag-grid-size);
}
.ag-chart-advanced-settings-section:not(:last-child) {
  border-bottom: 1px solid var(--ag-secondary-border-color);
}
.ag-chart-empty-text {
  display: flex;
  top: 0;
  width: 100%;
  height: 100%;
  align-items: center;
  justify-content: center;
  background-color: var(--ag-background-color);
}
.ag-chart .ag-chart-menu-wrapper .ag-chart-menu {
  display: flex;
  flex-direction: row;
  top: 8px;
  gap: 20px;
  width: auto;
}
.ag-ltr .ag-chart .ag-chart-menu-wrapper .ag-chart-menu {
  right: calc(var(--ag-cell-horizontal-padding) + var(--ag-grid-size) - 4px);
  justify-content: right;
}
.ag-rtl .ag-chart .ag-chart-menu-wrapper .ag-chart-menu {
  left: calc(var(--ag-cell-horizontal-padding) + var(--ag-grid-size) - 4px);
  justify-content: left;
}
.ag-charts-font-size-color {
  display: flex;
  align-self: stretch;
  justify-content: space-between;
}
.ag-charts-data-group-item {
  position: relative;
}
.ag-charts-data-group-item:not(:last-child) {
  margin-bottom: var(--ag-grid-size);
}
.ag-chart-menu {
  border-radius: var(--ag-card-radius);
  background: var(--ag-background-color);
}
.ag-chart-menu-icon {
  opacity: 0.5;
  margin: 2px 0;
  cursor: pointer;
  border-radius: var(--ag-card-radius);
  color: var(--ag-secondary-foreground-color);
}
.ag-chart-menu-icon:hover {
  opacity: 1;
}
.ag-chart-menu-toolbar-button {
  border: 0;
  background-color: unset;
  padding: 0 2px;
  border-radius: 1px;
}
.ag-chart-mini-thumbnail {
  border: 1px solid var(--ag-secondary-border-color);
  border-radius: 5px;
  padding: 1px;
}
.ag-chart-mini-thumbnail.ag-selected {
  border-color: var(--ag-minichart-selected-chart-color);
  border-width: 2px;
  padding: unset;
}
.ag-chart-mini-thumbnail:focus-visible {
  outline: none;
  border-color: var(--ag-minichart-selected-chart-color);
  box-shadow: var(--ag-input-focus-box-shadow);
}
.ag-chart-settings-card-item {
  background: var(--ag-foreground-color);
  width: 8px;
  height: 8px;
  border-radius: 4px;
}
.ag-chart-settings-card-item.ag-selected {
  background-color: var(--ag-minichart-selected-page-color);
}
.ag-chart-data-column-drag-handle {
  margin-left: var(--ag-grid-size);
}
.ag-charts-settings-group-title-bar, .ag-charts-data-group-title-bar, .ag-charts-format-top-level-group-title-bar {
  border-top: var(--ag-borders-secondary) var(--ag-secondary-border-color);
  position: relative;
}
.ag-charts-advanced-settings-top-level-group-title-bar {
  position: relative;
  background-color: unset;
}
.ag-charts-data-group-title-bar:focus-visible {
  outline: none;
}
.ag-charts-data-group-title-bar:focus-visible::after {
  content: "";
  position: absolute;
  background-color: transparent;
  pointer-events: none;
  top: 4px;
  left: 4px;
  display: block;
  width: calc(100% - 8px);
  height: calc(100% - 8px);
  border: 1px solid;
  border-color: var(--ag-input-focus-border-color);
}
.ag-charts-format-top-level-group-title-bar:focus-visible {
  outline: none;
}
.ag-charts-format-top-level-group-title-bar:focus-visible::after {
  content: "";
  position: absolute;
  background-color: transparent;
  pointer-events: none;
  top: 4px;
  left: 4px;
  display: block;
  width: calc(100% - 8px);
  height: calc(100% - 8px);
  border: 1px solid;
  border-color: var(--ag-input-focus-border-color);
}
.ag-charts-data-group-title-bar .ag-charts-data-group-title, .ag-charts-format-top-level-group-title-bar .ag-charts-format-top-level-group-title {
  cursor: pointer;
}
.ag-charts-data-group-container {
  padding: calc(var(--ag-widget-container-vertical-padding) * 0.5) var(--ag-widget-container-horizontal-padding);
}
.ag-charts-data-group-container .ag-charts-data-group-item:not(.ag-charts-format-sub-level-group):not(.ag-pill-select):not(.ag-select) {
  height: var(--ag-list-item-height);
}
.ag-charts-data-group-container .ag-charts-data-group-item.ag-picker-field {
  margin-top: var(--ag-grid-size);
}
.ag-charts-data-group-container .ag-list-item-hovered::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  height: 1px;
}
.ag-charts-data-group-container .ag-item-highlight-top::after {
  top: 0;
}
.ag-charts-data-group-container .ag-item-highlight-bottom::after {
  bottom: 0;
}
.ag-charts-format-top-level-group-container, .ag-charts-advanced-settings-top-level-group-container {
  padding: var(--ag-grid-size);
}
.ag-ltr .ag-charts-format-top-level-group-container, .ag-ltr .ag-charts-advanced-settings-top-level-group-container {
  margin-left: calc(var(--ag-grid-size) * 2);
}
.ag-rtl .ag-charts-format-top-level-group-container, .ag-rtl .ag-charts-advanced-settings-top-level-group-container {
  margin-right: calc(var(--ag-grid-size) * 2);
}
.ag-charts-format-top-level-group-item, .ag-charts-advanced-settings-top-level-group-item {
  margin: var(--ag-grid-size) 0;
}
.ag-charts-format-sub-level-group-container {
  padding: var(--ag-widget-container-vertical-padding) var(--ag-widget-container-horizontal-padding);
  padding-bottom: calc(var(--ag-widget-container-vertical-padding) - var(--ag-widget-vertical-spacing));
}
.ag-charts-format-sub-level-group-container > * {
  margin-bottom: var(--ag-widget-vertical-spacing);
}
.ag-charts-format-sub-level-no-header-group-container > * {
  margin-bottom: var(--ag-widget-vertical-spacing);
}
.ag-charts-format-sub-level-group-container .ag-charts-format-sub-level-group-item.ag-font-panel-no-header {
  margin: 0;
}
.ag-charts-settings-group-container {
  padding: var(--ag-grid-size);
  row-gap: 8px;
  display: grid;
  grid-template-columns: 60px 1fr 60px 1fr 60px;
}
.ag-charts-settings-group-container .ag-chart-mini-thumbnail:nth-child(3n+1) {
  grid-column: 1;
}
.ag-charts-settings-group-container .ag-chart-mini-thumbnail:nth-child(3n+2) {
  grid-column: 3;
}
.ag-charts-settings-group-container .ag-chart-mini-thumbnail:nth-child(3n+3) {
  grid-column: 5;
}
.ag-chart-menu-panel {
  background-color: var(--ag-control-panel-background-color);
}
.ag-ltr .ag-chart-menu-panel {
  border-left: solid 1px var(--ag-border-color);
}
.ag-rtl .ag-chart-menu-panel {
  border-right: solid 1px var(--ag-border-color);
}
.ag-date-time-list-page-title-bar {
  display: flex;
}
.ag-date-time-list-page-title {
  flex-grow: 1;
  text-align: center;
}
.ag-date-time-list-page-column-labels-row, .ag-date-time-list-page-entries-row {
  display: flex;
}
.ag-date-time-list-page-column-label, .ag-date-time-list-page-entry {
  flex-basis: 0;
  flex-grow: 1;
}
.ag-date-time-list-page-entry {
  cursor: pointer;
  text-align: center;
}
.ag-date-time-list-page-column-label {
  text-align: center;
}
.ag-advanced-filter-header {
  position: relative;
  display: flex;
  align-items: center;
  padding-left: var(--ag-cell-horizontal-padding);
  padding-right: var(--ag-cell-horizontal-padding);
}
.ag-advanced-filter {
  display: flex;
  align-items: center;
  width: 100%;
}
.ag-advanced-filter-buttons {
  display: contents;
}
.ag-advanced-filter-builder-button {
  display: flex;
  align-items: center;
  border: 0;
  background-color: unset;
  color: var(--ag-foreground-color);
  font-size: var(--ag-font-size);
  font-weight: 600;
  line-height: normal;
  white-space: nowrap;
}
.ag-ltr .ag-advanced-filter-builder-button {
  margin-left: calc(var(--ag-grid-size) * 2);
}
.ag-rtl .ag-advanced-filter-builder-button {
  margin-right: calc(var(--ag-grid-size) * 2);
}
.ag-advanced-filter-builder-button:hover:not(:disabled) {
  background-color: var(--ag-row-hover-color);
}
.ag-advanced-filter-builder-button:not(:disabled) {
  cursor: pointer;
}
.ag-advanced-filter-builder-button-label {
  margin-left: var(--ag-grid-size);
}
.ag-advanced-filter-builder {
  -moz-user-select: none;
  -webkit-user-select: none;
  -ms-user-select: none;
  user-select: none;
  width: 100%;
  background-color: var(--ag-control-panel-background-color);
  display: flex;
  flex-direction: column;
}
.ag-advanced-filter-builder-list {
  flex: 1;
  overflow: auto;
}
.ag-advanced-filter-builder-list .ag-list-item-hovered::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  height: 1px;
}
.ag-advanced-filter-builder-list .ag-item-highlight-top::after {
  top: 0;
}
.ag-advanced-filter-builder-list .ag-item-highlight-bottom::after {
  bottom: 0;
}
.ag-advanced-filter-builder-button-panel {
  display: flex;
  justify-content: flex-end;
  padding: var(--ag-widget-container-vertical-padding) var(--ag-widget-container-horizontal-padding);
  border-top: var(--ag-borders-secondary) var(--ag-secondary-border-color);
}
.ag-advanced-filter-builder .ag-advanced-filter-builder-button-panel .ag-advanced-filter-builder-apply-button, .ag-advanced-filter-builder .ag-advanced-filter-builder-button-panel .ag-advanced-filter-builder-cancel-button {
  margin-left: calc(var(--ag-grid-size) * 2);
}
.ag-advanced-filter-builder-item-wrapper {
  display: flex;
  flex: 1 1 auto;
  align-items: center;
  justify-content: space-between;
  overflow: hidden;
  padding-left: calc(var(--ag-icon-size) / 2);
  padding-right: var(--ag-icon-size);
}
.ag-virtual-list-viewport .ag-advanced-filter-builder-item-wrapper .ag-tab-guard {
  position: absolute;
}
.ag-advanced-filter-builder-item-tree-lines > * {
  width: var(--ag-advanced-filter-builder-indent-size);
}
.ag-advanced-filter-builder-item-tree-lines .ag-advanced-filter-builder-item-tree-line-root {
  width: var(--ag-icon-size);
}
.ag-advanced-filter-builder-item-tree-lines .ag-advanced-filter-builder-item-tree-line-root::before {
  top: 50%;
  height: 50%;
}
.ag-advanced-filter-builder-item-tree-line-horizontal, .ag-advanced-filter-builder-item-tree-line-vertical, .ag-advanced-filter-builder-item-tree-line-vertical-top, .ag-advanced-filter-builder-item-tree-line-vertical-bottom {
  position: relative;
  height: 100%;
  display: flex;
  align-items: center;
}
.ag-advanced-filter-builder-item-tree-line-horizontal::before, .ag-advanced-filter-builder-item-tree-line-horizontal::after, .ag-advanced-filter-builder-item-tree-line-vertical::before, .ag-advanced-filter-builder-item-tree-line-vertical::after, .ag-advanced-filter-builder-item-tree-line-vertical-top::before, .ag-advanced-filter-builder-item-tree-line-vertical-top::after, .ag-advanced-filter-builder-item-tree-line-vertical-bottom::before, .ag-advanced-filter-builder-item-tree-line-vertical-bottom::after {
  content: "";
  position: absolute;
  height: 100%;
}
.ag-advanced-filter-builder-item-tree-line-horizontal::after {
  height: 50%;
  width: calc(var(--ag-advanced-filter-builder-indent-size) - var(--ag-icon-size));
  top: 0;
  left: calc(var(--ag-icon-size) / 2);
  border-bottom: 1px solid;
  border-color: var(--ag-border-color);
}
.ag-advanced-filter-builder-item-tree-line-vertical::before {
  width: calc(var(--ag-advanced-filter-builder-indent-size) - var(--ag-icon-size) / 2);
  top: 0;
  left: calc(var(--ag-icon-size) / 2);
  border-left: 1px solid;
  border-color: var(--ag-border-color);
}
.ag-advanced-filter-builder-item-tree-line-vertical-top::before {
  height: 50%;
  width: calc(var(--ag-advanced-filter-builder-indent-size) - var(--ag-icon-size) / 2);
  top: 0;
  left: calc(var(--ag-icon-size) / 2);
  border-left: 1px solid;
  border-color: var(--ag-border-color);
}
.ag-advanced-filter-builder-item-tree-line-vertical-bottom::before {
  height: calc((100% - 1.5 * var(--ag-icon-size)) / 2);
  width: calc(var(--ag-icon-size) / 2);
  top: calc((100% + 1.5 * var(--ag-icon-size)) / 2);
  left: calc(var(--ag-icon-size) / 2);
  border-left: 1px solid;
  border-color: var(--ag-border-color);
}
.ag-advanced-filter-builder-item-condition {
  padding-top: var(--ag-grid-size);
  padding-bottom: var(--ag-grid-size);
}
.ag-advanced-filter-builder-item, .ag-advanced-filter-builder-item-condition, .ag-advanced-filter-builder-pill-wrapper, .ag-advanced-filter-builder-pill, .ag-advanced-filter-builder-item-buttons, .ag-advanced-filter-builder-item-tree-lines {
  display: flex;
  align-items: center;
  height: 100%;
}
.ag-advanced-filter-builder-pill-wrapper {
  margin: 0px var(--ag-grid-size);
}
.ag-advanced-filter-builder-pill {
  position: relative;
  border-radius: var(--ag-border-radius);
  padding: var(--ag-grid-size) calc(var(--ag-grid-size) * 2);
  min-height: calc(100% - var(--ag-grid-size) * 3);
  min-width: calc(var(--ag-grid-size) * 2);
}
.ag-advanced-filter-builder-pill .ag-picker-field-display {
  margin-right: var(--ag-grid-size);
}
.ag-advanced-filter-builder-pill .ag-advanced-filter-builder-value-number {
  font-family: monospace;
  font-weight: 700;
}
.ag-advanced-filter-builder-pill .ag-advanced-filter-builder-value-empty {
  color: var(--ag-disabled-foreground-color);
}
.ag-advanced-filter-builder-pill:focus-visible {
  outline: none;
}
.ag-advanced-filter-builder-pill:focus-visible::after {
  content: "";
  position: absolute;
  background-color: transparent;
  pointer-events: none;
  top: -4px;
  left: -4px;
  display: block;
  width: calc(100% - -8px);
  height: calc(100% - -8px);
  border: 1px solid;
  border-color: var(--ag-input-focus-border-color);
}
.ag-advanced-filter-builder-item-button:focus-visible {
  outline: none;
}
.ag-advanced-filter-builder-item-button:focus-visible::after {
  content: "";
  position: absolute;
  background-color: transparent;
  pointer-events: none;
  top: -4px;
  left: -4px;
  display: block;
  width: calc(100% - -8px);
  height: calc(100% - -8px);
  border: 1px solid;
  border-color: var(--ag-input-focus-border-color);
}
.ag-advanced-filter-builder-pill-display {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  font-weight: 500;
}
.ag-advanced-filter-builder-join-pill {
  color: var(--ag-foreground-color);
  background-color: var(--ag-advanced-filter-join-pill-color);
  cursor: pointer;
}
.ag-advanced-filter-builder-column-pill {
  color: var(--ag-foreground-color);
  background-color: var(--ag-advanced-filter-column-pill-color);
  cursor: pointer;
}
.ag-advanced-filter-builder-option-pill {
  color: var(--ag-foreground-color);
  background-color: var(--ag-advanced-filter-option-pill-color);
  cursor: pointer;
}
.ag-advanced-filter-builder-value-pill {
  color: var(--ag-foreground-color);
  background-color: var(--ag-advanced-filter-value-pill-color);
  cursor: text;
  max-width: 140px;
}
.ag-advanced-filter-builder-value-pill .ag-advanced-filter-builder-pill-display {
  display: block;
}
.ag-advanced-filter-builder-item-buttons > * {
  margin: 0 calc(var(--ag-grid-size) * 0.5);
}
.ag-advanced-filter-builder-item-button {
  position: relative;
  cursor: pointer;
  color: var(--ag-secondary-foreground-color);
  opacity: 50%;
}
.ag-advanced-filter-builder-item-button-disabled {
  color: var(--ag-disabled-foreground-color);
  cursor: default;
}
.ag-advanced-filter-builder-virtual-list-container {
  top: var(--ag-grid-size);
}
.ag-advanced-filter-builder-virtual-list-item {
  display: flex;
  cursor: default;
  height: var(--ag-list-item-height);
}
.ag-advanced-filter-builder-virtual-list-item:hover {
  background-color: var(--ag-row-hover-color);
}
.ag-advanced-filter-builder-virtual-list-item:hover .ag-advanced-filter-builder-item-button {
  opacity: 100%;
}
.ag-advanced-filter-builder-virtual-list-item-highlight .ag-advanced-filter-builder-item-button:focus-visible, .ag-advanced-filter-builder-validation .ag-advanced-filter-builder-invalid {
  opacity: 100%;
}
.ag-advanced-filter-builder-invalid {
  margin: 0 var(--ag-grid-size);
  color: var(--ag-invalid-color);
  cursor: default;
}
.ag-row-number-cell {
  background-color: var(--ag-header-background-color);
  color: var(--ag-header-foreground-color);
  font-size: var(--ag-font-size);
  font-family: var(--ag-font-family);
}
.ag-row-number-header.ag-row-number-selection-enabled {
  cursor: cell;
}
.ag-row-number-range-highlight {
  background-color: var(--ag-range-header-highlight-color);
}
.ag-row-number-range-selected {
  background-color: var(--ag-row-numbers-selected-color);
}
.ag-ltr .ag-row-number-header, .ag-ltr .ag-cell.ag-row-number-cell:not(.ag-cell-last-left-pinned) {
  border-right: var(--ag-pinned-column-border);
}
.ag-ltr .ag-cell.ag-row-number-cell.ag-row-number-selection-enabled {
  cursor: url("data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iMTYiIGhlaWdodD0iMTYiIHZlcnNpb249IjEuMSIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIiB4bWxuczp4bGluaz0iaHR0cDovL3d3dy53My5vcmcvMTk5OS94bGluayIgeG1sOnNwYWNlPSJwcmVzZXJ2ZSIgc3R5bGU9ImZpbGwtcnVsZTpldmVub2RkO2NsaXAtcnVsZTpldmVub2RkO3N0cm9rZS1saW5lY2FwOnJvdW5kO3N0cm9rZS1saW5lam9pbjpyb3VuZDtzdHJva2UtbWl0ZXJsaW1pdDoxLjU7Ij4KICAgIDxnIHRyYW5zZm9ybT0ibWF0cml4KDEuNTc4NCwwLDAsMS44NjQyOSwtNC40MTM0OSwtNy4yMTIxMikiPgogICAgICAgIDxwYXRoIGQ9Ik0zLjQ0NSw4LjkxMUwzLjQ0NSw3LjQwOUw5Ljc1LDcuNDA5TDkuNzUsNi4wMTRMMTIuMjg1LDguMTZMOS43NSwxMC4zMDZMOS43NSw4LjkxMUwzLjQ0NSw4LjkxMVoiIHN0eWxlPSJzdHJva2U6d2hpdGU7c3Ryb2tlLXdpZHRoOjAuNDFweDsiLz4KICAgIDwvZz4KPC9zdmc+Cg=="), auto;
}
.ag-rtl .ag-row-number-header, .ag-rtl .ag-cell.ag-row-number-cell:not(.ag-cell-first-right-pinned) {
  border-left: var(--ag-pinned-column-border);
}
.ag-rtl .ag-cell.ag-row-number-cell.ag-row-number-selection-enabled {
  cursor: url("data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iMTYiIGhlaWdodD0iMTYiIHZlcnNpb249IjEuMSIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIiB4bWxuczp4bGluaz0iaHR0cDovL3d3dy53My5vcmcvMTk5OS94bGluayIgeG1sOnNwYWNlPSJwcmVzZXJ2ZSIgc3R5bGU9ImZpbGwtcnVsZTpldmVub2RkO2NsaXAtcnVsZTpldmVub2RkO3N0cm9rZS1saW5lY2FwOnJvdW5kO3N0cm9rZS1saW5lam9pbjpyb3VuZDtzdHJva2UtbWl0ZXJsaW1pdDoxLjU7Ij4KICAgIDxnIHRyYW5zZm9ybT0ibWF0cml4KDEuNTc4NCwwLDAsMS44NjQyOSwtNC40MTM0OSwtNy4yMTIxMikiPgogICAgICAgIDxwYXRoIGQ9Ik01Ljk3OSw4LjkxMUw1Ljk3OSwxMC4zMDZMMy40NDUsOC4xNkw1Ljk3OSw2LjAxNEw1Ljk3OSw3LjQwOUwxMi4yODUsNy40MDlMMTIuMjg1LDguOTExTDUuOTc5LDguOTExWiIgc3R5bGU9InN0cm9rZTp3aGl0ZTtzdHJva2Utd2lkdGg6MC40MXB4OyIvPgogICAgPC9nPgo8L3N2Zz4K"), auto;
}
.ag-cell-batch-edit {
  background-color: var(--ag-cell-batch-edit-background-color);
  color: var(--ag-cell-batch-edit-text-color);
}
.ag-cell.ag-cell-inline-editing {
  background-color: var(--ag-background-color);
  background-image: linear-gradient(0deg, var(--ag-input-background-color), var(--ag-input-background-color));
}
.ag-row-batch-edit {
  background-color: var(--ag-row-batch-edit-background-color);
  color: var(--ag-row-batch-edit-text-color);
}
.ag-input-field-input {
  width: 100%;
  min-width: 0;
}
.ag-checkbox-input-wrapper {
  font-family: var(--ag-icon-font-family);
  font-weight: var(--ag-icon-font-weight);
  color: var(--ag-icon-font-color);
  font-size: var(--ag-icon-size);
  line-height: var(--ag-icon-size);
  font-style: normal;
  font-variant: normal;
  text-transform: none;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  width: var(--ag-icon-size);
  height: var(--ag-icon-size);
  background-color: var(--ag-checkbox-background-color);
  border-radius: var(--ag-checkbox-border-radius);
  display: inline-block;
  vertical-align: middle;
  flex: none;
}
.ag-checkbox-input-wrapper input, .ag-checkbox-input-wrapper input {
  -webkit-appearance: none;
  opacity: 0;
  width: 100%;
  height: 100%;
}
.ag-checkbox-input-wrapper:focus-within, .ag-checkbox-input-wrapper:active {
  outline: none;
  box-shadow: var(--ag-input-focus-box-shadow);
}
.ag-cell-editing-error .ag-checkbox-input-wrapper:focus-within, .ag-cell-editing-error .ag-checkbox-input-wrapper:active {
  box-shadow: var(--ag-input-error-focus-box-shadow);
}
.ag-checkbox-input-wrapper.ag-disabled {
  opacity: 0.5;
}
.ag-checkbox-input-wrapper::after {
  content: var(--ag-icon-font-code-checkbox-unchecked, "\f108");
  font-family: inherit;
  color: var(--ag-checkbox-unchecked-color);
  display: var(--ag-icon-font-display-checkbox-unchecked, var(--ag-icon-font-display));
  position: absolute;
  top: 0;
  left: 0;
  pointer-events: none;
}
.ag-checkbox-input-wrapper.ag-checked::after {
  content: var(--ag-icon-font-code-checkbox-checked, "\f106");
  color: var(--ag-checkbox-checked-color);
  display: var(--ag-icon-font-display-checkbox-checked, var(--ag-icon-font-display));
  position: absolute;
  top: 0;
  left: 0;
  pointer-events: none;
}
.ag-checkbox-input-wrapper.ag-indeterminate::after {
  content: var(--ag-icon-font-code-checkbox-indeterminate, "\f107");
  color: var(--ag-checkbox-indeterminate-color);
  display: var(--ag-icon-font-display-checkbox-indeterminate, var(--ag-icon-font-display));
  position: absolute;
  top: 0;
  left: 0;
  pointer-events: none;
}
.ag-checkbox-input-wrapper::before {
  content: "";
  background: transparent center/contain no-repeat;
  position: absolute;
  inset: 0;
  background-image: var(--ag-icon-image-checkbox-unchecked, var(--ag-icon-image));
  display: var(--ag-icon-image-display-checkbox-unchecked, var(--ag-icon-image-display));
  opacity: var(--ag-icon-image-opacity-checkbox-unchecked, var(--ag-icon-image-opacity, 0.9));
}
.ag-checkbox-input-wrapper.ag-checked::before {
  background-image: var(--ag-icon-image-checkbox-checked, var(--ag-icon-image));
  display: var(--ag-icon-image-display-checkbox-checked, var(--ag-icon-image-display));
  opacity: var(--ag-icon-image-opacity-checkbox-checked, var(--ag-icon-image-opacity, 0.9));
}
.ag-checkbox-input-wrapper.ag-indeterminate::before {
  background-image: var(--ag-icon-image-checkbox-indeterminate, var(--ag-icon-image));
  display: var(--ag-icon-image-display-checkbox-indeterminate, var(--ag-icon-image-display));
  opacity: var(--ag-icon-image-opacity-checkbox-indeterminate, var(--ag-icon-image-opacity, 0.9));
}
.ag-toggle-button-input-wrapper {
  box-sizing: border-box;
  width: var(--ag-toggle-button-width);
  min-width: var(--ag-toggle-button-width);
  max-width: var(--ag-toggle-button-width);
  height: var(--ag-toggle-button-height);
  background-color: var(--ag-toggle-button-off-background-color);
  border-radius: calc(var(--ag-toggle-button-height) * 0.5);
  position: relative;
  flex: none;
  border: var(--ag-toggle-button-border-width) solid;
  border-color: var(--ag-toggle-button-off-border-color);
}
.ag-toggle-button-input-wrapper input {
  opacity: 0;
  height: 100%;
  width: 100%;
}
.ag-toggle-button-input-wrapper:focus-within {
  outline: none;
  box-shadow: var(--ag-input-focus-box-shadow);
}
.ag-toggle-button-input-wrapper.ag-disabled {
  opacity: 0.5;
}
.ag-toggle-button-input-wrapper.ag-checked {
  background-color: var(--ag-toggle-button-on-background-color);
  border-color: var(--ag-toggle-button-on-border-color);
}
.ag-toggle-button-input-wrapper::before {
  content: " ";
  position: absolute;
  top: calc(0px - var(--ag-toggle-button-border-width));
  left: calc(0px - var(--ag-toggle-button-border-width));
  display: block;
  box-sizing: border-box;
  height: var(--ag-toggle-button-height);
  width: var(--ag-toggle-button-height);
  background-color: var(--ag-toggle-button-switch-background-color);
  border-radius: 100%;
  transition: left 100ms;
  border: var(--ag-toggle-button-border-width) solid;
  border-color: var(--ag-toggle-button-switch-border-color);
}
.ag-toggle-button-input-wrapper.ag-checked::before {
  left: calc(100% - var(--ag-toggle-button-height) + var(--ag-toggle-button-border-width));
  border-color: var(--ag-toggle-button-on-border-color);
}
.ag-radio-button-input-wrapper {
  font-family: var(--ag-icon-font-family);
  font-weight: var(--ag-icon-font-weight);
  color: var(--ag-icon-font-color);
  font-size: var(--ag-icon-size);
  line-height: var(--ag-icon-size);
  font-style: normal;
  font-variant: normal;
  text-transform: none;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  width: var(--ag-icon-size);
  height: var(--ag-icon-size);
  background-color: var(--ag-checkbox-background-color);
  border-radius: var(--ag-checkbox-border-radius);
  display: inline-block;
  vertical-align: middle;
  flex: none;
  border-radius: var(--ag-icon-size);
}
.ag-radio-button-input-wrapper input, .ag-radio-button-input-wrapper input {
  -webkit-appearance: none;
  opacity: 0;
  width: 100%;
  height: 100%;
}
.ag-radio-button-input-wrapper:focus-within, .ag-radio-button-input-wrapper:active {
  outline: none;
  box-shadow: var(--ag-input-focus-box-shadow);
}
.ag-cell-editing-error .ag-radio-button-input-wrapper:focus-within, .ag-cell-editing-error .ag-radio-button-input-wrapper:active {
  box-shadow: var(--ag-input-error-focus-box-shadow);
}
.ag-radio-button-input-wrapper.ag-disabled {
  opacity: 0.5;
}
.ag-radio-button-input-wrapper::after {
  content: var(--ag-icon-font-code-radio-button-off, "\f127");
  color: var(--ag-checkbox-unchecked-color);
  display: var(--ag-icon-font-display-radio-button-off, var(--ag-icon-font-display));
  position: absolute;
  top: 0;
  left: 0;
  pointer-events: none;
}
.ag-radio-button-input-wrapper.ag-checked::after {
  content: var(--ag-icon-font-code-radio-button-on, "\f128");
  color: var(--ag-checkbox-checked-color);
  display: var(--ag-icon-font-display-radio-button-on, var(--ag-icon-font-display));
  position: absolute;
  top: 0;
  left: 0;
  pointer-events: none;
}
.ag-radio-button-input-wrapper::before {
  content: "";
  background: transparent center/contain no-repeat;
  position: absolute;
  inset: 0;
  background-image: var(--ag-icon-image-radio-button-off, var(--ag-icon-image));
  display: var(--ag-icon-image-display-radio-button-off, var(--ag-icon-image-display));
  opacity: var(--ag-icon-image-opacity-radio-button-off, var(--ag-icon-image-opacity, 0.9));
}
.ag-radio-button-input-wrapper.ag-checked::before {
  background-image: var(--ag-icon-image-radio-button-on, var(--ag-icon-image));
  display: var(--ag-icon-image-display-radio-button-on, var(--ag-icon-image-display));
  opacity: var(--ag-icon-image-opacity-radio-button-on, var(--ag-icon-image-opacity, 0.9));
}
.ag-range-field-input {
  -webkit-appearance: none;
  width: 100%;
  height: 100%;
  background: none;
  overflow: visible;
}
.ag-range-field-input::-webkit-slider-runnable-track {
  margin: 0;
  padding: 0;
  width: 100%;
  height: 3px;
  background-color: var(--ag-border-color);
  border-radius: var(--ag-border-radius);
  border-radius: var(--ag-checkbox-border-radius);
}
.ag-range-field-input::-moz-range-track {
  margin: 0;
  padding: 0;
  width: 100%;
  height: 3px;
  background-color: var(--ag-border-color);
  border-radius: var(--ag-border-radius);
  border-radius: var(--ag-checkbox-border-radius);
}
.ag-range-field-input::-ms-track {
  margin: 0;
  padding: 0;
  width: 100%;
  height: 3px;
  background-color: var(--ag-border-color);
  border-radius: var(--ag-border-radius);
  border-radius: var(--ag-checkbox-border-radius);
  color: transparent;
  width: calc(100% - 2px);
}
.ag-range-field-input::-webkit-slider-thumb {
  margin: 0;
  padding: 0;
  -webkit-appearance: none;
  width: var(--ag-icon-size);
  height: var(--ag-icon-size);
  background-color: var(--ag-background-color);
  border: 1px solid;
  border-color: var(--ag-checkbox-unchecked-color);
  border-radius: var(--ag-icon-size);
  transform: translateY(calc(var(--ag-icon-size) * -0.5 + 1.5px));
}
.ag-range-field-input::-ms-thumb {
  margin: 0;
  padding: 0;
  -webkit-appearance: none;
  width: var(--ag-icon-size);
  height: var(--ag-icon-size);
  background-color: var(--ag-background-color);
  border: 1px solid;
  border-color: var(--ag-checkbox-unchecked-color);
  border-radius: var(--ag-icon-size);
}
.ag-range-field-input::-moz-ag-range-thumb {
  margin: 0;
  padding: 0;
  -webkit-appearance: none;
  width: var(--ag-icon-size);
  height: var(--ag-icon-size);
  background-color: var(--ag-background-color);
  border: 1px solid;
  border-color: var(--ag-checkbox-unchecked-color);
  border-radius: var(--ag-icon-size);
}
.ag-range-field-input:focus {
  outline: none;
}
.ag-range-field-input:focus::-webkit-slider-thumb {
  box-shadow: var(--ag-input-focus-box-shadow);
  border-color: var(--ag-checkbox-checked-color);
}
.ag-range-field-input:focus::-ms-thumb {
  box-shadow: var(--ag-input-focus-box-shadow);
  border-color: var(--ag-checkbox-checked-color);
}
.ag-range-field-input:focus::-moz-ag-range-thumb {
  box-shadow: var(--ag-input-focus-box-shadow);
  border-color: var(--ag-checkbox-checked-color);
}
.ag-range-field-input:active::-webkit-slider-runnable-track {
  background-color: var(--ag-input-focus-border-color);
}
.ag-range-field-input:active::-moz-ag-range-track {
  background-color: var(--ag-input-focus-border-color);
}
.ag-range-field-input:active::-ms-track {
  background-color: var(--ag-input-focus-border-color);
}
.ag-range-field-input:disabled {
  opacity: 0.5;
}
@font-face {
  font-family: "agGridQuartz";
  src: url(data:font/woff2;charset=utf-8;base64,d09GMgABAAAAAB60AAsAAAAAP9AAAB5kAAEAAAAAAAAAAAAAAAAAAAAAAAAAAAAAHItkBmAAjSYK02DDKgE2AiQDgnALgToABCAFhEYHhlUbGDZVRoWNAxCE6WSJokyNVmT/f0mQlxh6/aA2IaNSNSSMnFiPpCFrpxM4K2otB+uVtaIChHJqIvHDENnTdjLimnVXso4TytrTJzK4pg/me9l/YydzYHHZUEoe/n/tf/vemffdUS3liyhimoYMWTONUCiBEgj1rEV/Ps+9r/et+feYGhwbKIIByglQsVguFajUU8Bc6vSDVEIwvGxhQJFLtCEtQ2/vNjUAhue32YNvIvjF/0kD+mOjuHBJiFhF6aKMlUuMra2hbnfnSte6K4W1lzBXJX9zibf9f1FyUeqFXiEMufb6HcLgvJBHHMR871Sllk9WUWBoOTCmNGMQhNhF1s/dxncbCywH32oQBABKPMP/4ONvm6pmuvZk1rDIKWNuj+d82xpMQjITCuCDoFwi4H9V01W86y5NTmllGNP3ZJsIEKIEfEASRN09UzB9pjuvvGce3eXWdFNK77N4dBHdmVLbMLmOacOSYc2WOcOecUq2UFgnyp8tvnAVMiEtgVbEqzq3Qvxp3Rok89J7f80caG99C/bAiwpChJiEMMkNsv3qO5FAi6w2cmJqYUP+8Y3XT3WgZbdMcFwwPX5w74bks4VuGJfwX0Jtizy/N79/pfqZHub8wldS/ebV1/JWTStGFpTXNhUiGebJXMhhIzw+Kow1Wp3Vx3Cx4BriBBMY7FUEVWCyPj07hjTMCLSjjXjp9iJ4cXOjtAYk5WqtyiAIE0/zHeW3d4ymMZoax5hylBHhW73RzQRXSOOUUNFlTXgHARsVeftSI8aBgBRLlEUf0YLqBlHcg1Mn5ulxGECa1zFIIFe9DPZTzxyJICgoPs6gZ4FQt31fAFGzaFNCBQfqfY4OkMwQmk11bGbRObSxGmIALe+rQ3GqsKa9Gx+mSU4dQKNLsLj5JLEOJLVbUlPrvVXQEWIGvwoagTW8hECk63NwE/pNegiVBO19+fvxO/7xo0Tb08ubS2WpOm1Ou1J72k9gtoXyPf4qXw23W0/TE2qmIGqePZKStASraUzvycGhxdVSLPoyZDNUB1xagP0Acq3XKqNOXrAtnO7AamiZGA69W2viqHLEswsRLpvw7JC0TSR9eiOQxTG1uXgOA5mrkZLA2AriEAUvOhPH5dHZkzpQ9LS+QyWUXwTDWFp6e1Gc2BNRo6JEdlF5bnbEozzK0Q14T9ATnV6siC4K4sirtu+W1Sf14g3UeLrzjqH+9c2n6Jm2qo2FsWRFrPgoThTXRxMfVQQvztMX8OaUAHQDxFxDb4daQrpI0Erq0y7c+bBJaQBKDNoaSGR4ZN0WsR7XQOD9MMK/w+MZ3BAQSRUaEQ8OKahltEb6uGEUFRpJ+9ySelSFsl/QGCqpFT+zBtqogEtzIEQ1iKNA9BsUJKWu+1dyJJrx9AYG8sd8GXwpDnz6J5cyQMYUIHsVK3cnb/uPVIwKH9grtZF+Fdj0AKiBAlycKcr5cvP0dDaofd9FFLHu46F9QxseiZZy68lPTNbrLrlx6yVSyczsRM6DTmFlQAKqsil05HHKU5ETKPYEDWrg5TI1B46FkCgsDk8g+mf2YVSoNLR09AyMTMwsrGzsHJxc3Dy8fBR+AUEhYUYRUTFxCUkpaRlZOXkFRXolZRVVNXU0RkNTS1tH1z4LpAaQPbzhzx9fW1ya2ptYmVFZ3pyb3eYuTG/tzq/v7FtdbUD53nsVuPTRBnCjceBma8CtFoHbLQF3mgLutgfcawK43wrwoBngUavA45aBJ20CT5sDnjULPG8beNkk8KoF4HXTwJu2gLftAu+aB963DnxoB/h49kEQo1gSBiwFA5YGNEAwaIRg0QTBoRmCRwuEgFYIEW0QEtohZHRAKOiEUNEFoUE3hBY9EDr0QujRB2FAP4QRAxAmDEKYMQRhwTCEFSMQNoxC2DEG4cAhCCcOQ7hwBMKNoxAeHIPwoh3Cl+MQOQGRkxA5BZHTEOiDiBgZAzwKDPAYMMDjwABPAAM8CQzwFDDA08AAzwADPAsM8BwwwPPAAC8AA7wIDPASGHrjZWDOeQUY4FVggNeAAV4HBngDGOBNOJcSonUuNYg2Q8Y7wADvAgO8BwzwPjDAB8AAHwIDfAQUTMfB13b+wG+0PwNd37NyHissKde4UwgUUmNwqY/Aon/vkN88uAmfAbkGfo4B8ovk+AjEx2oSoACDojFdV2rGpfWbber8hlTuUk5tptE2hRfFHQyEb0uOjojmRtADtjDYgavYTZIwNJIJ0Z6cHx0sCaaHD4s8jko58QxFsBCpCmwOTmUh/SRkM18oYtAD7Dr2Q0a4Zx9QKILJ8mexdStGY+SMMDRRKBayoiLp0KZwCAlnoFw+P5LFixJjdJ8mBqNKdnOxu0O4jCjS8Oyd0ulbaf7rNCvNsMSlVH3Yo+lAuQG5MjYh//wtgQBOxVvFygozrpmYk/R2l4ilVHppV4d3mgjyspFM+61xYQ+DuudwKuHE7DdFRPViyCsQ45WDMdtNptebRYJiDjuQL6FDJVdgelrTlkZEddl3l/j0crn2TZJr17fSjk4CnIhBw0jyhW9PuO1Ude0efnFjW8jbh03SrSieKnrug9sUtDTUBLbABthnNpgtcItcOwuqPqeASn7cA7uv0sDycqZn1NYFgGauWoxGHgA1VpLPhO3OsKBIOvaQqJ6wiAs5iTuYWvk6/DFePsDDJYausJ7LdYZr4+gqJnZe89JYmaMQUDTiUqVm3JXIrz8Zke3U8iXqkIcdSjVqHyWtDb9w9dmOg5nG56znz+VCGPN61Yg//8ULxczR/v6fpFSo7rwiZe4ObU/Mh8w9whXBE0yaRn4x08UbPGRK+EFXVPNWF0+MvvyGyxsG1F91/Qx+FExPiEcsX7QIw1716ptL2Z2Hvua6Mun6z8LlF7sOfyNeyBusXzTJt+Vknj9odCfI1MNRCwkt5taAOmeM+Z3CQ/MrXgkFHS4WjsRlpsEbFx/gPFwbXMDJo5soMf7QUKok1BoRWUdsW06g+VPMenLrOlVw3gPW4ds38BuuT9YdSivNUI19MjmQWeLTdctblukuo1mElw1o1VGjXoeoKibSkO8cBsKxHYsPn6O/d/PaFuqJBZwhfteZ2KPVy5B9xefRtfjmtRPUSFmhkJbk4kMNa2hkU4vd3KT35YrRZuP6GKFFM5WcsATfBQveE/UN/EWpAens6nY5xtsMU90AubaCRFGqN9wR39SFvimGFBohOwR1XTCFuMfhBNe2FYZslyF+xLKIIcNuLlGUeMgMmzSyDMO2DZNDpEjrYb2oT0yTJG/YEMecyQvFgelQ1SEeVcS6tiqrlkh3WQzhDUihoK89x6YpKGH2bovYGp6GM2QOzUoo781G3UeMUWvEbeeaerLP4sjc/Vz+TNkXzcp4Ll9ORht9nrZhinUImsHyHAbQ4A8RMWq1xr1UgpPGACnCE0yU5nnyQrIa4Qjnt1yqUkgy30tAPYFTwkMmQQcB3RORpsBBsmHHnIQjhyBRtYhGf5az+eL8zNlHghm1PqzeZH2PL2rvv58DuCDhdfjFacloc9qCkT3mj0kkpzNDiM+Xdo0oVqc3ymWeSbHQyzNvLhc0vQQZmkLyBdVvejxDo7Fy+/PF1/MVFuHPGdDBwnkTVXaWzn1yR80zrffRrZLBrfbEWF/4zz9FJcdxuDTzZl69u6O7Z2SqEc2RGTiNZ1WceQafPydeL0Jv2DulV7e3To30BLs+nSdkuMubfv3+rqN9YxOh9pKZj27JWWLO1yKfWZ92oQPWYU8+aWa1QB92oMuY6eQCsBp3w4yZGp1rR8M3O8Aai1CQd1hzWIND1521NWKUB3EhHRMzPcZvRKV78QDgxx0O8tDE2qApzmkruTr16YQdif6meHy/wWwszR3YgVKjVKeDzKZ/zEeC0l9M4AS5cXUADc5OAoC91SSGZFcHfJYpL96Cx6f74cDMRC2+kQRYqRTZqVneWObu6gEtqG687Aj7IwNrmy0cEx0zaIIbnL8h6fdq3pERt8DBSNKEHYtEp0wyHK61yUqXieJ47PInGWYoCKAppOT2wlpK4wY0rbfAOsvP8iLoqRzd/PqcTdyuuwDM7WgetmWDeGlt01RuOmhfiU063Wi1DDrSJGLOkyGLLB1FB8O7WPYSy1UMojV8M5IWC1tq+tRcHy1XJk6ylZiV7AdlnP6wH2EWHIQf1qvIJeMPeUACiSmz54pids7HxmjaiZS3JCmrgQCvsb7s/M1nAOTVGllYtMC6QculGXwvQNOjt1/k3QD3L6/NHD6jor8XF5TJxTfho7xR1Z2Qh3wNO1wbY4qERIq8VbT0aDZhZ1pncM4W5GoI2B1nk1QhOpFaZlx6pRgMZaNQKUmmxtxfsltRGCkddHTk/FnZbqcqruF60jB+LlfjxTtQZ6TVE0oXF3dlO9Py6fVVHOkK9mfaX6QcRZHWPnHunbFGZXtRy0fenIoDryUHDKHESouLclaXPVLHD3sdb/XTSV5e/sln9pqUU9scDak4sJnr7Gxp3D8hqFRGm9tAUz+y079Eo81Wo/m2kvZqccBitX3Mr1rppGvHBCgjjcdmMIshYvP9ELLQypjYFxydHAAaDVwbvAj7D/sW6w6e+azXHEx4cnYQDWmmh51l5lqZMnlEj5NhaSbwoseaqK6JjjPx5m408msdoABjtXUAXwuwHyB9AoKNygLOFgsCVfBex9PdT9qHoV2bX26ryAFPuC5DsiJyI7ZXQFcmihWONbELDzjooSouNj2bhj0hz/C6GeHlIa9Ib9yJeymc0GPeUi6heRoNBEivm9puVQb/PwJ7Kx089i5nllUydzZXA9Glpo28AyNtD3NnrYoaozjdElW2Ti5ON55Qmk7fuHmBX0ZV19NmYB+lrRb8oky7xFCFlBrfyIiVVXPhZDwVTlhfBbVadyh4QyxTjrgGhZvBI4WjhodelA1j875QJh68aOuuNBtYm5Gi/ro1g6phfOhC9xHdfPG9C7bnNSz75IkkT7yAS2g8klsT9ZMLBlw0PENy4INtQiqp1qgiWxYymbwxE+vcpzJbfFZ5iP2PuDi0eapoavPn+5YCZDvJD27f55tdRZMc5CY3/6/cj4bO//fyN3PcMg18ICr5gJST27bh/kflhIcCPDvlsLZtq4hpa21lWqq6LwPw125rOQh7pUG4hSFA8XSbLcyW2vVZiMJ+OX6Zt8GeAuHyRBIjuVzcv19N3L93HXJhDvT6hoZev0g7UHX+EjMEwBwrMAI5+oT12qTh0h+2DZ+McURh31vV/PTAHCr2g+LBOH/YldrwsiBGJPzh7Q3F/OJm/bRKtq9ZvphcGN8OGYtjDP2RLPiWBFLqK2fiDTHH1+YmzBfdY8HfHkc0qbPgjq9g5CP+bJrk3m+uYRfBPr6UOHfi2DESc8pxtxvY+fuppMu94mvEg0cdRT8ukdMX42bC2Shf0Y/Z+6YyLv25ecN9Kke8OkkfkENRHD3BG3ZftUIkSrUNU6IwOyJY4KbEb9Xm0e42nzix/etQ9MPpIHlsEPVFvd6RkVdyh3zQrtfbXY2s3WofyWR9K5rbq7aPeIFQtx5xoEdRB/YlGZMl6BnVXA+qLjxD3JgTmWpoNAVyB749pE3Tl7v4oPQN1eHDudUrc2EoBcq/TlZVwbnKFCWct7IqH969AHzMBNzgc0IoCJ1xkrqhbvMW/aZDu5Y1i4ifVR4nZaaMTmGfKaRc02wc6gISXQrzwNE3ukc7e4I23OAPpcC9iTkT4XG4srW7v3xj7I0vd69tMccbbxUVDAb301iuaS8q6kviJnWXFLueoE9cpt2lxH1FRe1PIgAs+YDAHJhn/XqCsIdpwzQYhlImihOUygoSI3NzP39YGRnNpKfQ4e8hjTRaKnvRRzduOCIdYduFB8UHhZGvreSAnM5f9bEDhoFYPWjMZnIsr5X2hnz4ZcexLz8MgY3RehCkW8Ec5xukp+MkcebY01KD5FJsQv78tdLP0+H64ycWnThcDxth6eThrg3FmcaDXcc3hlYD1nKYlJOTk+AjCo/44yOZj5SD4JsYCe35aIQ4MTcCxZ5W9ihPx0I9j/9NKeLGXEj1005+hapCO5MQUZhkP0/SKeF3fnb28pPxTovBtCf/EJgTI9lsDhvH3BhRnIVNYi4MR4/MUZ0ITH8yWlVhW7c7/SIFq8KSsUps+se/pN4+MBzxVW19G+VZkEId9pKyrucFPPf9U798z7pYfUAuHmhFwjlRf7+1y4+275reEFNUNUybu+Y3bqS1pDaUuVLP2xF64kIojzc5W7lb/WDjTjTk5LW96Y0/0JlGhHGp8f0B1tRdKB718eRbO6rtrFOM1OmKvC/DrkkYweW6T75iv3Un/Nys12NdMW5uLODs8Q/JY9H8ualPOev6QvvWcZLvqYJop8IN780NlIs8GlxDaoihvOlzLSukVXx9EW3VycamuHhCr2+G/PXXdEqJJFubUsQo4Lo5BfSiFG22pISqa8xejq0c5CfEFzg/EOEaj4bQkK/VXVHxesnvZECkSkAcmAv98slTYolDjkvEJPYp7VVO+eDY2p4+Qe6rfHLXUp+9au/abE7BMNP+S+9s63zrzTO650HDSjozN39Naf2xtZnIySA0KIOrrzA1TOt7FjysZYSDGImVYMuYv7uqmtla22Yw/y2kHAh0BrB+aUquQp0+W63Irzndu7ExSn33YYk34+E35Yzx2S95Citno3g0Y7v4CfcTPODVR31ke8fgko/ZONXKK2NrtewynlVILGlMmapYbJrSJqzcIs5q3NjbW7PzvdhhdXquYmnK+qQkoNspWzFlKzBPDlZETQPWPOzzrHHG7PWdhSSGp0q0Hh9DRSMCA6t9TTE5FYfV7HT2Lunew8MVOTFNWsiSrBmh3dbG6xJzeCWRPdChH71H3qaNaJIt0LwoIanOF8kbSspPSMhfJN2FRfsbPKymMISW6RIg71/Ehfws9JfenxHXO9/EyFFKZ8X5Abqn70DAqXwHmH8KmTDhb8uemxwZwf2PFBIou221raIZMAAUrwtJjYl0Twr3nc4ajbgNvNl5PqY6Lw7E3lQRGClezB9Pnc/rZRHmRHrhUnix2F5t1uiF7MUlBIaXFFcpixGn3IlIp+5AkYLqRqIPehWdo1rpZAYgH6DCGmn/Uh2h7o8gV7PX2UhDINFF4PL+QiIubixLlDVmZNovW4aP+jyIC3MhHuCt5ftl6NJ0GRMRmaFl0czEYsl8rah0ofrnaUqkiTXD7uDyJ0yqNJVpgp+JVx00M6FEOk8jMi4YqE1ZkpAqw6wFbSGfcl8+kEhaZiF456tzArGQd/mtaxvFMdJm8/g7Cj2eTmLy+xFQ2mxIdzCrZyVvCEC6oK+ue5pumKZMGpTKZ7MRcof/93Qc+7p1KeLabHvqpQ7U2UEs5FCt0zY25qX22G/2fpZ2oVOIC5mClkyNDJkkMYlr/22M5CKCHBsD9/8ibuE5g0mdk98i3+aJk/gBssf/IsDsgeMkRo6O2qUmPeE+l23z+TyYkjmuPMHMJ7Xuqd+iDfxu4RToL9krvvXo0S1z51boeULu9CdP5bW1toTbGarEDZmF1Z6fOwfg5dMAh6vRpM1UWxcWJOYlJOQlFriku5iX0Id2vdZlmutmVaQtW5ZWMfvnqU/96N0BP83+Oe0nUDHrMWZ2RR1gQ/fFdCFfeilu4qqOuySd4I3r5vMtbA6cDk9o75Shfhg/SV8n/15WZ0xKh19QcukDKOHPTx/npSca7dLAY6/mvbrwDHUhMpMJ93MUEm+/Q2BkfrD21lpmVbXdZJQhbhB6syl8nJ8nvRhL0UccFHaF9DRnyeAaWRbqQA2IC21fXg2cLWvuCela+mOEAc6pjYD10elwLOJG7shqQLa0uZfG/55P6z2YJQU1sjuIE40JS4/Wh/VAHWGYI/8w6gJ0JHeCpAbXIh+eEb4nlU6d0w2SgdgBgmSyDoruo05kaEj7XUPHCxjSnzV0x9RKd04kH7pTeMeDOBAQpRpdE3i1Um3OWYY0z7DMgCuXvlM4d1l2M7LJsqmc0V2YplbMaQzJr/6TA2nOXjan8HzFcvp4TmtkHLRWtqElaw2yeAnDurBrf6U5vHtJd2GY3bqoCSnYYcg17Ija9O67m6Jak5t2FVOYlPSz74XmnqYqjlmmr9dvGtOmbVte+5O9HQUDP3RXWUS1e+wRoKNfnh71CPfE5wPROgfqRLz9/YTcIccnp/wSPFNTdrMlrLbW3t/vRVyI+Ed06iKZiAtzI+Dro6F5XAwoNvnZ+favMn3Ow+TbJyftnw8HbMTPXs4zWyjwde5Vy01Xwbgcf3DfAzrkxDJ9fSSGA+PIXLdK/EVrrGALyXRExN4BI51tMsFipY0D31w4NDjgf69rOPSd9evaaltElupu228P/V1L8F+DFk+UhWdGwBUOvEcGfIyRX4Q+FNOwSbyKTP6EWTVTBUQScdJB0cEkOv3XTMlDnTNyHtj1rTYBqB3D+u2rylLNKpU5texZarmLZlUvPyt/TZU3lelokNeyTGaVmlpaTFKr7LZ0P/eWFqlJZr1dE/wqAXUia2tCj1VTY5Yo5a5SvxMshFbRXImJyTZV3lp2h1rylq1X3lj/vceIpSFTJUwDh8axyvw8n7xr8wZB2JtzsMo82M4XC1UpRmOKSrOi4MeAd/jbyTsBP63I16iMySnG13VyksCrhH9W5KsroLJ1Tt2tf7dH0ZcELvMSxE94adwn4rmBlj89uN/Rwv9GKfb5NVcGImzPUmR9peePy9y54qfcNN5TcQJ3W/TaV3sv08Mz6GKGey94+eA8I5xh3lu3sHafmSFmrAXja4gbeRwc9Hr5rjjj+Ypv9FcwZLU5WXzqe0n4pKHxQxx1BJ/mrJhfd8oLBh/LMFkNyJIeDDnx5a71/+z6UjWPGi19tnvlwpbw3mQsHHh8sAuMjJIywoSkes1MvYXghhhZsQFZgrMRjqm/v/TGtNS3XpSFR4FyHBC7I0Ycax5HYAT+jUhfPTzzCIEB5diBytGFRLnzE1fAb9nfFgjW7r+OqpwZYVukW5hnXKGK9peuQdbAXM2dvHp6XJZs2Elpl7ZTdq6auRV11WbOIjY3oC7fu9o0zZ4O7wy8LLDZrBbb5kc83Wz6bF1mZuoAfSDVvnkz2Pl/Nurz6UUUtKbI3aIBaSU097A70EuhqGtmpBOgDbftg3xg0pjggDqOyT1QVPo+5IhaDeUCUP/OGujHVXo9dOMWadCCpCu/2UXcoyUIkSYchRK68m9N6SjqZ+kOSCtC07QBWp12U3+55VPofRH4FhpmeWb+gzoqMmlKt0IPhBZER3FlH/SdyULMSCdA1GP3yJ1QaGLWlYsNomUxSRuoKiWkvgniMi0nCTJAja/oysWQO8qr/1+XRWh1JaJkEAKWt4ii9hYIaqNZOyPQC8xE6J/KXxt4fudfxWJ4zu9BIZAPgFQW/NWVXQUyG/VP+vQjmv4sMSUBoH9DmKF8f1HM/PHjH03h+7jB/9dJ/v45JMTVmXg+8TJoSXqgDk6XXzpyEpnYI+NK5IkWe2EArWz1nFYjSZzWQFamLTWiDztvZfAogiiDAcHqfXUaSfVBqU3rJ6Wh9edpDLM/lIXW/6eJzsnvd5OE094CqI/i3UcG0fs3rHMA+blKsi+/UJJnKl4Oz1Vv7IiEAoquON2K1NavqlVRCTfFO1O8qhC4iMKfaPVwVo1vT09VmvBguelAfRTvPjIkfr1/w43K4WytCNaqzv6FTzTBwcZUvByeCbUjEPFZQdHZp9uXndqN/aq5XRUf1cJN8U4VE9KQUl5DrPc+0abqcO7gxbenfKiKVB0sFfPPUpdF/D/Cc0CVyrQcttPl9mivzw8gwoQyLqTSxjofhFGcpFlelFXdtF0/jNO8rNt+nNf9vN+v0erS9RmGzKzsnNy8/ILCouKSUqPJbLGWlS8wwO9OK9S1YA3qmYYgwpfUg2T78Dl1AA6vBkMLZDEM7BlE1xFE+3Xia7nrQff4YzeeHCpK4wkUt1VdmYgWn1sOLGX0J50y+ihyQ2lqmVTAKrq+5XgbWOGUeja1PZu1z9oe4PUhNy4ZgXqom+ANyxQgnXt7d1j5cMPcwHGStF+Lj4NaOMf+xZymHysdBk+Mk44Cg/NUjxu4+sbfsd8g5bGgpNSAmHBGrCWEwBfIQby6iD0sToPoW9a1rPcPl6esylRyVa1+xNFAfH3WfoIWp6mhMFA6vtABc8FnYLTh43ckItWxqDNTQSxt4ATYpqviCJOf83JEGmeShHY7eTHkNGjUi42HgbhGfdqoOsBymo8tlMq0h5kQl7T42ByhK0+sys205CrHqXJkKwOYkuP8gMXObvAmvwBjw6dj/tWW4FwfnVcDpjZi0Kjxhg2Zi0nGGmeCOZsvczJXUzYmm2hupjWVuXcA);
  font-weight: normal;
  font-style: normal;
}
.ag-theme-quartz, .ag-theme-quartz-dark, .ag-theme-quartz-auto-dark {
  --ag-active-color: #2196f3;
  --ag-background-color: #fff;
  --ag-foreground-color: #181d1f;
  --ag-border-color: transparent;
  @supports (color: color-mix(in lab, red, red)) {
    --ag-border-color: color-mix(in srgb, transparent, var(--ag-foreground-color) 15%);
  }
  --ag-secondary-border-color: var(--ag-border-color);
  --ag-header-background-color: var(--ag-background-color);
  @supports (color: color-mix(in lab, red, red)) {
    --ag-header-background-color: color-mix(in srgb, var(--ag-background-color), var(--ag-foreground-color) 2%);
  }
  --ag-tooltip-background-color: var(--ag-header-background-color);
  --ag-control-panel-background-color: var(--ag-header-background-color);
  --ag-subheader-background-color: transparent;
  --ag-invalid-color: #e02525;
  --ag-checkbox-unchecked-color: var(--ag-background-color);
  @supports (color: color-mix(in lab, red, red)) {
    --ag-checkbox-unchecked-color: color-mix(in srgb, var(--ag-background-color), var(--ag-foreground-color) 30%);
  }
  --ag-advanced-filter-join-pill-color: #f08e8d;
  --ag-advanced-filter-column-pill-color: #a6e194;
  --ag-advanced-filter-option-pill-color: #f3c08b;
  --ag-advanced-filter-value-pill-color: #85c0e4;
  --ag-header-column-resize-handle-color: var(--ag-secondary-border-color);
  --ag-icon-font-color: transparent;
  @supports (color: color-mix(in lab, red, red)) {
    --ag-icon-font-color: color-mix(in srgb, transparent, var(--ag-foreground-color) 90%);
  }
  --ag-find-match-color: var(--ag-foreground-color);
  --ag-find-match-background-color: #ffff00;
  --ag-find-active-match-color: var(--ag-foreground-color);
  --ag-find-active-match-background-color: #ffa500;
  --ag-panel-background-color: var(--ag-background-color);
  @supports (color: color-mix(in lab, red, red)) {
    --ag-panel-background-color: color-mix(in srgb, var(--ag-background-color), var(--ag-foreground-color) 3%);
  }
  --ag-panel-border-color: transparent;
  @supports (color: color-mix(in lab, red, red)) {
    --ag-panel-border-color: color-mix(in srgb, transparent, var(--ag-foreground-color) 20%);
  }
  --ag-menu-background-color: var(--ag-background-color);
  @supports (color: color-mix(in lab, red, red)) {
    --ag-menu-background-color: color-mix(in srgb, var(--ag-background-color), var(--ag-foreground-color) 3%);
  }
  --ag-menu-border-color: transparent;
  @supports (color: color-mix(in lab, red, red)) {
    --ag-menu-border-color: color-mix(in srgb, transparent, var(--ag-foreground-color) 20%);
  }
  --ag-selected-row-background-color: transparent;
  @supports (color: color-mix(in lab, red, red)) {
    --ag-selected-row-background-color: color-mix(in srgb, transparent, var(--ag-active-color) 8%);
  }
  --ag-row-hover-color: transparent;
  @supports (color: color-mix(in lab, red, red)) {
    --ag-row-hover-color: color-mix(in srgb, transparent, var(--ag-active-color) 12%);
  }
  --ag-column-hover-color: transparent;
  @supports (color: color-mix(in lab, red, red)) {
    --ag-column-hover-color: color-mix(in srgb, transparent, var(--ag-foreground-color) 5%);
  }
  --ag-input-focus-border-color: var(--ag-active-color);
  --ag-range-selection-background-color: transparent;
  @supports (color: color-mix(in lab, red, red)) {
    --ag-range-selection-background-color: color-mix(in srgb, transparent, var(--ag-active-color) 20%);
  }
  --ag-input-focus-box-shadow: 0 0 0 3px transparent;
  @supports (color: color-mix(in lab, red, red)) {
    --ag-input-focus-box-shadow: 0 0 0 3px color-mix(in srgb, transparent, var(--ag-input-focus-border-color) 47%);
  }
  --ag-input-error-focus-box-shadow: 0 0 0 3px
      var(--ag-background-color);
  @supports (color: color-mix(in lab, red, red)) {
    --ag-input-error-focus-box-shadow: 0 0 0 3px
      color-mix(in srgb, var(--ag-background-color), var(--ag-invalid-color) 50%);
  }
  --ag-range-selection-background-color-2: transparent;
  @supports (color: color-mix(in lab, red, red)) {
    --ag-range-selection-background-color-2: color-mix(in srgb, transparent, var(--ag-active-color) 36%);
  }
  --ag-range-selection-background-color-3: transparent;
  @supports (color: color-mix(in lab, red, red)) {
    --ag-range-selection-background-color-3: color-mix(in srgb, transparent, var(--ag-active-color) 49%);
  }
  --ag-range-selection-background-color-4: transparent;
  @supports (color: color-mix(in lab, red, red)) {
    --ag-range-selection-background-color-4: color-mix(in srgb, transparent, var(--ag-active-color) 59%);
  }
  --ag-row-numbers-selected-color: transparent;
  @supports (color: color-mix(in lab, red, red)) {
    --ag-row-numbers-selected-color: color-mix(in srgb, transparent, var(--ag-active-color) 50%);
  }
  --ag-checkbox-background-color: var(--ag-background-color);
  --ag-checkbox-checked-color: var(--ag-active-color);
  --ag-range-selection-border-color: var(--ag-active-color);
  --ag-secondary-foreground-color: var(--ag-foreground-color);
  --ag-input-border-color: var(--ag-border-color);
  --ag-input-border-color-invalid: var(--ag-invalid-color);
  --ag-disabled-foreground-color: transparent;
  @supports (color: color-mix(in lab, red, red)) {
    --ag-disabled-foreground-color: color-mix(in srgb, transparent, var(--ag-foreground-color) 50%);
  }
  --ag-chip-background-color: transparent;
  @supports (color: color-mix(in lab, red, red)) {
    --ag-chip-background-color: color-mix(in srgb, transparent, var(--ag-foreground-color) 7%);
  }
  --ag-chip-border-color: var(--ag-header-background-color);
  @supports (color: color-mix(in lab, red, red)) {
    --ag-chip-border-color: color-mix(in srgb, var(--ag-header-background-color), var(--ag-foreground-color) 13%);
  }
  --ag-input-disabled-border-color: var(--ag-border-color);
  --ag-input-disabled-background-color: var(--ag-background-color);
  @supports (color: color-mix(in lab, red, red)) {
    --ag-input-disabled-background-color: color-mix(in srgb, var(--ag-background-color), var(--ag-foreground-color) 6%);
  }
  --ag-modal-overlay-background-color: transparent;
  @supports (color: color-mix(in lab, red, red)) {
    --ag-modal-overlay-background-color: color-mix(in srgb, transparent, var(--ag-background-color) 66%);
  }
  --ag-chart-menu-label-color: transparent;
  @supports (color: color-mix(in lab, red, red)) {
    --ag-chart-menu-label-color: color-mix(in srgb, transparent, var(--ag-foreground-color) 80%);
  }
  --ag-chart-menu-pill-select-button-color: transparent;
  @supports (color: color-mix(in lab, red, red)) {
    --ag-chart-menu-pill-select-button-color: color-mix(in srgb, transparent, var(--ag-foreground-color) 70%);
  }
  --ag-filter-panel-card-subtle-color: transparent;
  @supports (color: color-mix(in lab, red, red)) {
    --ag-filter-panel-card-subtle-color: color-mix(in srgb, transparent, var(--ag-foreground-color) 70%);
  }
  --ag-column-drag-indicator-color: var(--ag-active-color);
  --ag-borders: solid 1px;
  --ag-border-radius: 4px;
  --ag-wrapper-border-radius: 8px;
  --ag-borders-side-button: none;
  --ag-side-button-selected-background-color: transparent;
  --ag-header-column-resize-handle-display: block;
  --ag-header-column-resize-handle-width: 2px;
  --ag-header-column-resize-handle-height: 30%;
  --ag-grid-size: 8px;
  --ag-icon-size: 16px;
  --ag-header-height: calc(var(--ag-font-size) + var(--ag-grid-size) * 4.25);
  --ag-row-height: calc(var(--ag-font-size) + var(--ag-grid-size) * 3.5);
  --ag-list-item-height: calc(
      var(--ag-icon-size) + var(--ag-widget-vertical-spacing)
  );
  --ag-column-select-indent-size: var(--ag-icon-size);
  --ag-set-filter-indent-size: var(--ag-icon-size);
  --ag-filter-tool-panel-group-indent: var(--ag-grid-size);
  --ag-advanced-filter-builder-indent-size: calc(var(--ag-icon-size) + var(--ag-grid-size) * 2);
  --ag-cell-horizontal-padding: calc(var(--ag-grid-size) * 2);
  --ag-cell-widget-spacing: calc(var(--ag-grid-size) * 1.5);
  --ag-widget-container-vertical-padding: calc(var(--ag-grid-size) * 1.5);
  --ag-widget-container-horizontal-padding: calc(var(--ag-grid-size) * 1.5);
  --ag-widget-horizontal-spacing: calc(var(--ag-grid-size) * 1.5);
  --ag-widget-vertical-spacing: calc(var(--ag-grid-size) * 1);
  --ag-toggle-button-height: 18px;
  --ag-toggle-button-width: 28px;
  --ag-toggle-button-border-width: 2px;
  --ag-font-family: "IBM Plex Sans", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen-Sans, Ubuntu,
      Cantarell, "Helvetica Neue", sans-serif;
  --ag-font-size: 14px;
  --ag-icon-font-family: agGridQuartz;
  --ag-tab-min-width: 290px;
  --ag-chart-menu-panel-width: 260px;
  --ag-card-shadow: 0 1px 4px 1px rgba(186, 191, 199, 0.4);
  --ag-popup-shadow: 0 0 16px 0 rgba(0, 0, 0, 0.15);
  --ag-side-bar-panel-width: 250px;
  --ag-filter-panel-apply-button-color: var(--ag-background-color);
  --ag-filter-panel-apply-button-background-color: var(--ag-active-color);
  --ag-column-panel-apply-button-color: var(--ag-background-color);
  --ag-column-panel-apply-button-background-color: var(--ag-active-color);
}
.ag-theme-quartz-dark {
  --ag-background-color: color-mix(in srgb, #fff, #182230 97%);
  --ag-foreground-color: #fff;
  --ag-border-color: rgba(255, 255, 255, 0.16);
  --ag-secondary-border-color: transparent;
  @supports (color: color-mix(in lab, red, red)) {
    --ag-secondary-border-color: color-mix(in srgb, transparent, var(--ag-foreground-color) 10%);
  }
  --ag-header-background-color: color-mix(in srgb, #fff, #182230 93%);
  --ag-tooltip-background-color: color-mix(in srgb, #fff, #182230 96%);
  --ag-control-panel-background-color: color-mix(in srgb, #fff, #182230 93%);
  --ag-input-disabled-background-color: #68686e12;
  --ag-card-shadow: 0 1px 20px 1px black;
  --ag-input-border-color: var(--ag-border-color);
  --ag-input-disabled-border-color: rgba(255, 255, 255, 0.07);
  --ag-checkbox-unchecked-color: var(--ag-background-color);
  @supports (color: color-mix(in lab, red, red)) {
    --ag-checkbox-unchecked-color: color-mix(in srgb, var(--ag-background-color), var(--ag-foreground-color) 40%);
  }
  --ag-row-hover-color: transparent;
  @supports (color: color-mix(in lab, red, red)) {
    --ag-row-hover-color: color-mix(in srgb, transparent, var(--ag-active-color) 20%);
  }
  --ag-selected-row-background-color: var(--ag-row-hover-color);
  --ag-panel-background-color: var(--ag-background-color);
  @supports (color: color-mix(in lab, red, red)) {
    --ag-panel-background-color: color-mix(in srgb, var(--ag-background-color), var(--ag-foreground-color) 10%);
  }
  --ag-panel-border-color: transparent;
  @supports (color: color-mix(in lab, red, red)) {
    --ag-panel-border-color: color-mix(in srgb, transparent, var(--ag-foreground-color) 10%);
  }
  --ag-menu-background-color: var(--ag-background-color);
  @supports (color: color-mix(in lab, red, red)) {
    --ag-menu-background-color: color-mix(in srgb, var(--ag-background-color), var(--ag-foreground-color) 10%);
  }
  --ag-menu-border-color: transparent;
  @supports (color: color-mix(in lab, red, red)) {
    --ag-menu-border-color: color-mix(in srgb, transparent, var(--ag-foreground-color) 10%);
  }
  --ag-advanced-filter-join-pill-color: #7a3a37;
  --ag-advanced-filter-column-pill-color: #355f2d;
  --ag-advanced-filter-option-pill-color: #5a3168;
  --ag-advanced-filter-value-pill-color: #374c86;
  --ag-find-match-color: var(--ag-background-color);
  --ag-find-active-match-color: var(--ag-background-color);
  --ag-filter-panel-apply-button-color: var(--ag-foreground-color);
  --ag-column-panel-apply-button-color: var(--ag-foreground-color);
  --ag-popup-shadow: 0 0px 20px rgba(0, 0, 0, 0.3);
  --ag-row-loading-skeleton-effect-color: rgba(202, 203, 204, 0.4);
  --ag-cell-batch-edit-text-color: #f3d0b3;
  --ag-formula-token-1-color: #4da3e5;
  --ag-formula-token-1-background-color: rgb(77 163 229 / 16%);
  --ag-formula-token-2-color: #f55864;
  --ag-formula-token-2-background-color: rgb(245 88 100 / 16%);
  --ag-formula-token-3-color: #b688f2;
  --ag-formula-token-3-background-color: rgb(182 136 242 / 16%);
  --ag-formula-token-4-color: #24bb4a;
  --ag-formula-token-4-background-color: rgb(36 187 74 / 16%);
  --ag-formula-token-5-color: #e772ba;
  --ag-formula-token-5-background-color: rgb(231 114 186 / 16%);
  --ag-formula-token-6-color: #f69b5f;
  --ag-formula-token-6-background-color: rgb(246 155 95 / 16%);
  --ag-formula-token-7-color: #a3e6ff;
  --ag-formula-token-7-background-color: rgb(163 230 255 / 16%);
  color-scheme: dark;
}
@media (prefers-color-scheme: dark) {
  .ag-theme-quartz-auto-dark {
    --ag-background-color: color-mix(in srgb, #fff, #182230 97%);
    --ag-foreground-color: #fff;
    --ag-border-color: rgba(255, 255, 255, 0.16);
    --ag-secondary-border-color: transparent;
    @supports (color: color-mix(in lab, red, red)) {
      --ag-secondary-border-color: color-mix(in srgb, transparent, var(--ag-foreground-color) 10%);
    }
    --ag-header-background-color: color-mix(in srgb, #fff, #182230 93%);
    --ag-tooltip-background-color: color-mix(in srgb, #fff, #182230 96%);
    --ag-control-panel-background-color: color-mix(in srgb, #fff, #182230 93%);
    --ag-input-disabled-background-color: #68686e12;
    --ag-card-shadow: 0 1px 20px 1px black;
    --ag-input-border-color: var(--ag-border-color);
    --ag-input-disabled-border-color: rgba(255, 255, 255, 0.07);
    --ag-checkbox-unchecked-color: var(--ag-background-color);
    @supports (color: color-mix(in lab, red, red)) {
      --ag-checkbox-unchecked-color: color-mix(in srgb, var(--ag-background-color), var(--ag-foreground-color) 40%);
    }
    --ag-row-hover-color: transparent;
    @supports (color: color-mix(in lab, red, red)) {
      --ag-row-hover-color: color-mix(in srgb, transparent, var(--ag-active-color) 20%);
    }
    --ag-selected-row-background-color: var(--ag-row-hover-color);
    --ag-panel-background-color: var(--ag-background-color);
    @supports (color: color-mix(in lab, red, red)) {
      --ag-panel-background-color: color-mix(in srgb, var(--ag-background-color), var(--ag-foreground-color) 10%);
    }
    --ag-panel-border-color: transparent;
    @supports (color: color-mix(in lab, red, red)) {
      --ag-panel-border-color: color-mix(in srgb, transparent, var(--ag-foreground-color) 10%);
    }
    --ag-menu-background-color: var(--ag-background-color);
    @supports (color: color-mix(in lab, red, red)) {
      --ag-menu-background-color: color-mix(in srgb, var(--ag-background-color), var(--ag-foreground-color) 10%);
    }
    --ag-menu-border-color: transparent;
    @supports (color: color-mix(in lab, red, red)) {
      --ag-menu-border-color: color-mix(in srgb, transparent, var(--ag-foreground-color) 10%);
    }
    --ag-advanced-filter-join-pill-color: #7a3a37;
    --ag-advanced-filter-column-pill-color: #355f2d;
    --ag-advanced-filter-option-pill-color: #5a3168;
    --ag-advanced-filter-value-pill-color: #374c86;
    --ag-find-match-color: var(--ag-background-color);
    --ag-find-active-match-color: var(--ag-background-color);
    --ag-filter-panel-apply-button-color: var(--ag-foreground-color);
    --ag-column-panel-apply-button-color: var(--ag-foreground-color);
    --ag-popup-shadow: 0 0px 20px rgba(0, 0, 0, 0.3);
    --ag-row-loading-skeleton-effect-color: rgba(202, 203, 204, 0.4);
    --ag-cell-batch-edit-text-color: #f3d0b3;
    --ag-formula-token-1-color: #4da3e5;
    --ag-formula-token-1-background-color: rgb(77 163 229 / 16%);
    --ag-formula-token-2-color: #f55864;
    --ag-formula-token-2-background-color: rgb(245 88 100 / 16%);
    --ag-formula-token-3-color: #b688f2;
    --ag-formula-token-3-background-color: rgb(182 136 242 / 16%);
    --ag-formula-token-4-color: #24bb4a;
    --ag-formula-token-4-background-color: rgb(36 187 74 / 16%);
    --ag-formula-token-5-color: #e772ba;
    --ag-formula-token-5-background-color: rgb(231 114 186 / 16%);
    --ag-formula-token-6-color: #f69b5f;
    --ag-formula-token-6-background-color: rgb(246 155 95 / 16%);
    --ag-formula-token-7-color: #a3e6ff;
    --ag-formula-token-7-background-color: rgb(163 230 255 / 16%);
    color-scheme: dark;
  }
}
.ag-theme-quartz .ag-filter-toolpanel-header, .ag-theme-quartz .ag-filter-toolpanel-search, .ag-theme-quartz .ag-status-bar, .ag-theme-quartz .ag-header-row, .ag-theme-quartz .ag-row-number-cell, .ag-theme-quartz .ag-panel-title-bar-title, .ag-theme-quartz .ag-multi-filter-group-title-bar, .ag-theme-quartz .ag-filter-card-title, .ag-theme-quartz-dark .ag-filter-toolpanel-header, .ag-theme-quartz-dark .ag-filter-toolpanel-search, .ag-theme-quartz-dark .ag-status-bar, .ag-theme-quartz-dark .ag-header-row, .ag-theme-quartz-dark .ag-row-number-cell, .ag-theme-quartz-dark .ag-panel-title-bar-title, .ag-theme-quartz-dark .ag-multi-filter-group-title-bar, .ag-theme-quartz-dark .ag-filter-card-title, .ag-theme-quartz-auto-dark .ag-filter-toolpanel-header, .ag-theme-quartz-auto-dark .ag-filter-toolpanel-search, .ag-theme-quartz-auto-dark .ag-status-bar, .ag-theme-quartz-auto-dark .ag-header-row, .ag-theme-quartz-auto-dark .ag-row-number-cell, .ag-theme-quartz-auto-dark .ag-panel-title-bar-title, .ag-theme-quartz-auto-dark .ag-multi-filter-group-title-bar, .ag-theme-quartz-auto-dark .ag-filter-card-title {
  font-weight: 500;
  color: var(--ag-header-foreground-color);
}
.ag-theme-quartz input[class^=ag-]:not([type]), .ag-theme-quartz input[class^=ag-][type=text], .ag-theme-quartz input[class^=ag-][type=number], .ag-theme-quartz input[class^=ag-][type=tel], .ag-theme-quartz input[class^=ag-][type=date], .ag-theme-quartz input[class^=ag-][type=datetime-local], .ag-theme-quartz textarea[class^=ag-], .ag-theme-quartz-dark input[class^=ag-]:not([type]), .ag-theme-quartz-dark input[class^=ag-][type=text], .ag-theme-quartz-dark input[class^=ag-][type=number], .ag-theme-quartz-dark input[class^=ag-][type=tel], .ag-theme-quartz-dark input[class^=ag-][type=date], .ag-theme-quartz-dark input[class^=ag-][type=datetime-local], .ag-theme-quartz-dark textarea[class^=ag-], .ag-theme-quartz-auto-dark input[class^=ag-]:not([type]), .ag-theme-quartz-auto-dark input[class^=ag-][type=text], .ag-theme-quartz-auto-dark input[class^=ag-][type=number], .ag-theme-quartz-auto-dark input[class^=ag-][type=tel], .ag-theme-quartz-auto-dark input[class^=ag-][type=date], .ag-theme-quartz-auto-dark input[class^=ag-][type=datetime-local], .ag-theme-quartz-auto-dark textarea[class^=ag-] {
  min-height: calc(var(--ag-grid-size) * 4);
  border-radius: var(--ag-border-radius);
}
.ag-theme-quartz .ag-ltr input[class^=ag-]:not([type]), .ag-theme-quartz .ag-ltr input[class^=ag-][type=text], .ag-theme-quartz .ag-ltr input[class^=ag-][type=number], .ag-theme-quartz .ag-ltr input[class^=ag-][type=tel], .ag-theme-quartz .ag-ltr input[class^=ag-][type=date], .ag-theme-quartz .ag-ltr input[class^=ag-][type=datetime-local], .ag-theme-quartz .ag-ltr textarea[class^=ag-], .ag-theme-quartz-dark .ag-ltr input[class^=ag-]:not([type]), .ag-theme-quartz-dark .ag-ltr input[class^=ag-][type=text], .ag-theme-quartz-dark .ag-ltr input[class^=ag-][type=number], .ag-theme-quartz-dark .ag-ltr input[class^=ag-][type=tel], .ag-theme-quartz-dark .ag-ltr input[class^=ag-][type=date], .ag-theme-quartz-dark .ag-ltr input[class^=ag-][type=datetime-local], .ag-theme-quartz-dark .ag-ltr textarea[class^=ag-], .ag-theme-quartz-auto-dark .ag-ltr input[class^=ag-]:not([type]), .ag-theme-quartz-auto-dark .ag-ltr input[class^=ag-][type=text], .ag-theme-quartz-auto-dark .ag-ltr input[class^=ag-][type=number], .ag-theme-quartz-auto-dark .ag-ltr input[class^=ag-][type=tel], .ag-theme-quartz-auto-dark .ag-ltr input[class^=ag-][type=date], .ag-theme-quartz-auto-dark .ag-ltr input[class^=ag-][type=datetime-local], .ag-theme-quartz-auto-dark .ag-ltr textarea[class^=ag-] {
  padding-left: var(--ag-grid-size);
}
.ag-theme-quartz .ag-rtl input[class^=ag-]:not([type]), .ag-theme-quartz .ag-rtl input[class^=ag-][type=text], .ag-theme-quartz .ag-rtl input[class^=ag-][type=number], .ag-theme-quartz .ag-rtl input[class^=ag-][type=tel], .ag-theme-quartz .ag-rtl input[class^=ag-][type=date], .ag-theme-quartz .ag-rtl input[class^=ag-][type=datetime-local], .ag-theme-quartz .ag-rtl textarea[class^=ag-], .ag-theme-quartz-dark .ag-rtl input[class^=ag-]:not([type]), .ag-theme-quartz-dark .ag-rtl input[class^=ag-][type=text], .ag-theme-quartz-dark .ag-rtl input[class^=ag-][type=number], .ag-theme-quartz-dark .ag-rtl input[class^=ag-][type=tel], .ag-theme-quartz-dark .ag-rtl input[class^=ag-][type=date], .ag-theme-quartz-dark .ag-rtl input[class^=ag-][type=datetime-local], .ag-theme-quartz-dark .ag-rtl textarea[class^=ag-], .ag-theme-quartz-auto-dark .ag-rtl input[class^=ag-]:not([type]), .ag-theme-quartz-auto-dark .ag-rtl input[class^=ag-][type=text], .ag-theme-quartz-auto-dark .ag-rtl input[class^=ag-][type=number], .ag-theme-quartz-auto-dark .ag-rtl input[class^=ag-][type=tel], .ag-theme-quartz-auto-dark .ag-rtl input[class^=ag-][type=date], .ag-theme-quartz-auto-dark .ag-rtl input[class^=ag-][type=datetime-local], .ag-theme-quartz-auto-dark .ag-rtl textarea[class^=ag-] {
  padding-right: var(--ag-grid-size);
}
.ag-theme-quartz .ag-picker-field-wrapper, .ag-theme-quartz-dark .ag-picker-field-wrapper, .ag-theme-quartz-auto-dark .ag-picker-field-wrapper {
  min-height: calc(var(--ag-grid-size) * 4);
}
.ag-theme-quartz .ag-tab, .ag-theme-quartz-dark .ag-tab, .ag-theme-quartz-auto-dark .ag-tab {
  padding: var(--ag-grid-size);
  border-left: var(--ag-borders) transparent;
  border-right: var(--ag-borders) transparent;
  flex: 1 1 auto;
}
.ag-theme-quartz .ag-tab-selected, .ag-theme-quartz-dark .ag-tab-selected, .ag-theme-quartz-auto-dark .ag-tab-selected {
  background-color: var(--ag-background-color);
}
.ag-theme-quartz .ag-ltr .ag-tab-selected:not(:first-of-type), .ag-theme-quartz-dark .ag-ltr .ag-tab-selected:not(:first-of-type), .ag-theme-quartz-auto-dark .ag-ltr .ag-tab-selected:not(:first-of-type) {
  border-left-color: var(--ag-border-color);
}
.ag-theme-quartz .ag-rtl .ag-tab-selected:not(:first-of-type), .ag-theme-quartz-dark .ag-rtl .ag-tab-selected:not(:first-of-type), .ag-theme-quartz-auto-dark .ag-rtl .ag-tab-selected:not(:first-of-type) {
  border-right-color: var(--ag-border-color);
}
.ag-theme-quartz .ag-ltr .ag-tab-selected:not(:last-of-type), .ag-theme-quartz-dark .ag-ltr .ag-tab-selected:not(:last-of-type), .ag-theme-quartz-auto-dark .ag-ltr .ag-tab-selected:not(:last-of-type) {
  border-right-color: var(--ag-border-color);
}
.ag-theme-quartz .ag-rtl .ag-tab-selected:not(:last-of-type), .ag-theme-quartz-dark .ag-rtl .ag-tab-selected:not(:last-of-type), .ag-theme-quartz-auto-dark .ag-rtl .ag-tab-selected:not(:last-of-type) {
  border-left-color: var(--ag-border-color);
}
.ag-theme-quartz .ag-tab:not(.ag-tab-selected), .ag-theme-quartz-dark .ag-tab:not(.ag-tab-selected), .ag-theme-quartz-auto-dark .ag-tab:not(.ag-tab-selected) {
  opacity: 0.7;
}
.ag-theme-quartz .ag-tab:not(.ag-tab-selected):hover, .ag-theme-quartz-dark .ag-tab:not(.ag-tab-selected):hover, .ag-theme-quartz-auto-dark .ag-tab:not(.ag-tab-selected):hover {
  opacity: 1;
}
.ag-theme-quartz .ag-menu, .ag-theme-quartz-dark .ag-menu, .ag-theme-quartz-auto-dark .ag-menu {
  color: transparent;
  @supports (color: color-mix(in lab, red, red)) {
    color: color-mix(in srgb, transparent, var(--ag-foreground-color) 95%);
  }
}
.ag-theme-quartz .ag-panel-content-wrapper .ag-column-select, .ag-theme-quartz-dark .ag-panel-content-wrapper .ag-column-select, .ag-theme-quartz-auto-dark .ag-panel-content-wrapper .ag-column-select {
  background-color: var(--ag-control-panel-background-color);
  color: transparent;
  @supports (color: color-mix(in lab, red, red)) {
    color: color-mix(in srgb, transparent, var(--ag-foreground-color) 95%);
  }
}
.ag-theme-quartz .ag-menu-header, .ag-theme-quartz-dark .ag-menu-header, .ag-theme-quartz-auto-dark .ag-menu-header {
  background-color: var(--ag-control-panel-background-color);
}
.ag-theme-quartz .ag-menu-option, .ag-theme-quartz-dark .ag-menu-option, .ag-theme-quartz-auto-dark .ag-menu-option {
  font-weight: 500;
  cursor: pointer;
}
.ag-theme-quartz .ag-ltr .ag-menu-option-popup-pointer .ag-icon, .ag-theme-quartz-dark .ag-ltr .ag-menu-option-popup-pointer .ag-icon, .ag-theme-quartz-auto-dark .ag-ltr .ag-menu-option-popup-pointer .ag-icon {
  text-align: right;
}
.ag-theme-quartz .ag-rtl .ag-menu-option-popup-pointer .ag-icon, .ag-theme-quartz-dark .ag-rtl .ag-menu-option-popup-pointer .ag-icon, .ag-theme-quartz-auto-dark .ag-rtl .ag-menu-option-popup-pointer .ag-icon {
  text-align: left;
}
.ag-theme-quartz .ag-tabs-header, .ag-theme-quartz-dark .ag-tabs-header, .ag-theme-quartz-auto-dark .ag-tabs-header {
  border-bottom: var(--ag-borders) var(--ag-border-color);
  display: flex;
  background-color: transparent;
  @supports (color: color-mix(in lab, red, red)) {
    background-color: color-mix(in srgb, transparent, var(--ag-foreground-color) 5%);
  }
}
.ag-theme-quartz .ag-side-bar, .ag-theme-quartz-dark .ag-side-bar, .ag-theme-quartz-auto-dark .ag-side-bar {
  background-color: var(--ag-control-panel-background-color);
  min-width: calc(var(--ag-icon-size) + var(--ag-grid-size) * 2);
}
.ag-theme-quartz .ag-side-buttons, .ag-theme-quartz-dark .ag-side-buttons, .ag-theme-quartz-auto-dark .ag-side-buttons {
  padding: 0;
  align-self: stretch;
  width: calc(var(--ag-icon-size) + var(--ag-grid-size) * 2);
  background: var(--ag-control-panel-background-color);
}
.ag-theme-quartz .ag-side-button, .ag-theme-quartz-dark .ag-side-button, .ag-theme-quartz-auto-dark .ag-side-button {
  border-top: var(--ag-borders) transparent;
  border-bottom: var(--ag-borders) transparent;
}
@media (max-resolution: 1.5x) {
  .ag-theme-quartz .ag-side-button-label, .ag-theme-quartz-dark .ag-side-button-label, .ag-theme-quartz-auto-dark .ag-side-button-label {
    font-family: "Segoe UI", var(--ag-font-family);
    transform: rotate(0.05deg);
  }
}
.ag-theme-quartz .ag-side-button.ag-selected, .ag-theme-quartz-dark .ag-side-button.ag-selected, .ag-theme-quartz-auto-dark .ag-side-button.ag-selected {
  border-bottom-color: var(--ag-border-color);
  background-color: var(--ag-background-color);
}
.ag-theme-quartz .ag-side-button.ag-selected:not(:first-of-type), .ag-theme-quartz-dark .ag-side-button.ag-selected:not(:first-of-type), .ag-theme-quartz-auto-dark .ag-side-button.ag-selected:not(:first-of-type) {
  border-top-color: var(--ag-border-color);
}
.ag-theme-quartz .ag-column-panel-column-select, .ag-theme-quartz-dark .ag-column-panel-column-select, .ag-theme-quartz-auto-dark .ag-column-panel-column-select {
  border-top: none;
}
.ag-theme-quartz .ag-column-panel-column-select:not(.ag-last-visible-child), .ag-theme-quartz-dark .ag-column-panel-column-select:not(.ag-last-visible-child), .ag-theme-quartz-auto-dark .ag-column-panel-column-select:not(.ag-last-visible-child) {
  border-bottom: 1px solid var(--ag-secondary-border-color);
}
.ag-theme-quartz .ag-filter-toolpanel-search, .ag-theme-quartz-dark .ag-filter-toolpanel-search, .ag-theme-quartz-auto-dark .ag-filter-toolpanel-search {
  height: initial;
  margin-top: var(--ag-widget-container-vertical-padding);
}
.ag-theme-quartz .ag-filter-toolpanel-search-input, .ag-theme-quartz-dark .ag-filter-toolpanel-search-input, .ag-theme-quartz-auto-dark .ag-filter-toolpanel-search-input {
  margin: 0;
}
.ag-theme-quartz .ag-filter-apply-panel, .ag-theme-quartz-dark .ag-filter-apply-panel, .ag-theme-quartz-auto-dark .ag-filter-apply-panel {
  border: none;
  padding-top: var(--ag-widget-vertical-spacing);
}
.ag-theme-quartz .ag-chart-tabbed-menu-body, .ag-theme-quartz-dark .ag-chart-tabbed-menu-body, .ag-theme-quartz-auto-dark .ag-chart-tabbed-menu-body {
  position: relative;
}
.ag-theme-quartz .ag-chart-tabbed-menu-body::after, .ag-theme-quartz-dark .ag-chart-tabbed-menu-body::after, .ag-theme-quartz-auto-dark .ag-chart-tabbed-menu-body::after {
  content: "";
  position: absolute;
  display: block;
  top: 0;
  left: 0;
  right: 0;
  height: 16px;
  background: linear-gradient(var(--ag-control-panel-background-color), transparent);
}
.ag-theme-quartz .ag-charts-settings-group-title-bar, .ag-theme-quartz .ag-charts-data-group-title-bar, .ag-theme-quartz .ag-charts-format-top-level-group-title-bar, .ag-theme-quartz .ag-charts-advanced-settings-top-level-group-title-bar, .ag-theme-quartz .ag-charts-settings-group-container, .ag-theme-quartz-dark .ag-charts-settings-group-title-bar, .ag-theme-quartz-dark .ag-charts-data-group-title-bar, .ag-theme-quartz-dark .ag-charts-format-top-level-group-title-bar, .ag-theme-quartz-dark .ag-charts-advanced-settings-top-level-group-title-bar, .ag-theme-quartz-dark .ag-charts-settings-group-container, .ag-theme-quartz-auto-dark .ag-charts-settings-group-title-bar, .ag-theme-quartz-auto-dark .ag-charts-data-group-title-bar, .ag-theme-quartz-auto-dark .ag-charts-format-top-level-group-title-bar, .ag-theme-quartz-auto-dark .ag-charts-advanced-settings-top-level-group-title-bar, .ag-theme-quartz-auto-dark .ag-charts-settings-group-container {
  border-top: none;
  font-weight: 500;
}
.ag-theme-quartz .ag-chart-mini-thumbnail, .ag-theme-quartz-dark .ag-chart-mini-thumbnail, .ag-theme-quartz-auto-dark .ag-chart-mini-thumbnail {
  background-color: var(--ag-background-color);
  margin-top: 0;
  margin-bottom: 0;
}
.ag-theme-quartz .ag-chart-settings-nav-bar, .ag-theme-quartz-dark .ag-chart-settings-nav-bar, .ag-theme-quartz-auto-dark .ag-chart-settings-nav-bar {
  border-top: var(--ag-borders-secondary) var(--ag-secondary-border-color);
}
.ag-theme-quartz .ag-charts-format-sub-level-group-title-bar, .ag-theme-quartz-dark .ag-charts-format-sub-level-group-title-bar, .ag-theme-quartz-auto-dark .ag-charts-format-sub-level-group-title-bar {
  background: none;
  font-weight: 500;
}
.ag-theme-quartz .ag-chart-data-section .ag-label:not(.ag-group-title-bar), .ag-theme-quartz .ag-chart-format-section .ag-label:not(.ag-group-title-bar), .ag-theme-quartz-dark .ag-chart-data-section .ag-label:not(.ag-group-title-bar), .ag-theme-quartz-dark .ag-chart-format-section .ag-label:not(.ag-group-title-bar), .ag-theme-quartz-auto-dark .ag-chart-data-section .ag-label:not(.ag-group-title-bar), .ag-theme-quartz-auto-dark .ag-chart-format-section .ag-label:not(.ag-group-title-bar) {
  color: var(--ag-chart-menu-label-color);
}
.ag-theme-quartz .ag-chart-data-section .ag-label-align-top .ag-label, .ag-theme-quartz .ag-chart-format-section .ag-label-align-top .ag-label, .ag-theme-quartz-dark .ag-chart-data-section .ag-label-align-top .ag-label, .ag-theme-quartz-dark .ag-chart-format-section .ag-label-align-top .ag-label, .ag-theme-quartz-auto-dark .ag-chart-data-section .ag-label-align-top .ag-label, .ag-theme-quartz-auto-dark .ag-chart-format-section .ag-label-align-top .ag-label {
  margin-top: calc(var(--ag-widget-vertical-spacing) * 0.5);
  margin-bottom: var(--ag-widget-vertical-spacing);
}
.ag-theme-quartz .ag-chart-data-section .ag-slider.ag-label-align-top .ag-label, .ag-theme-quartz .ag-chart-format-section .ag-slider.ag-label-align-top .ag-label, .ag-theme-quartz-dark .ag-chart-data-section .ag-slider.ag-label-align-top .ag-label, .ag-theme-quartz-dark .ag-chart-format-section .ag-slider.ag-label-align-top .ag-label, .ag-theme-quartz-auto-dark .ag-chart-data-section .ag-slider.ag-label-align-top .ag-label, .ag-theme-quartz-auto-dark .ag-chart-format-section .ag-slider.ag-label-align-top .ag-label {
  margin-bottom: 0;
}
.ag-theme-quartz .ag-chart-data-section label, .ag-theme-quartz .ag-chart-format-section label, .ag-theme-quartz-dark .ag-chart-data-section label, .ag-theme-quartz-dark .ag-chart-format-section label, .ag-theme-quartz-auto-dark .ag-chart-data-section label, .ag-theme-quartz-auto-dark .ag-chart-format-section label {
  display: inline-block;
}
.ag-theme-quartz .ag-chart-format-wrapper, .ag-theme-quartz .ag-chart-data-wrapper, .ag-theme-quartz .ag-charts-format-top-level-group, .ag-theme-quartz .ag-charts-format-top-level-group-title-bar, .ag-theme-quartz .ag-charts-format-top-level-group .ag-charts-format-top-level-group-container, .ag-theme-quartz .ag-charts-format-top-level-group-item, .ag-theme-quartz .ag-charts-format-sub-level-group, .ag-theme-quartz .ag-charts-format-sub-level-group-title-bar, .ag-theme-quartz .ag-charts-format-sub-level-group-container, .ag-theme-quartz .ag-charts-format-sub-level-group-item:last-child, .ag-theme-quartz .ag-charts-format-sub-level-group-container > *, .ag-theme-quartz .ag-charts-data-group-title-bar, .ag-theme-quartz .ag-charts-data-group-container, .ag-theme-quartz .ag-charts-settings-group-title-bar, .ag-theme-quartz .ag-charts-settings-group-container, .ag-theme-quartz-dark .ag-chart-format-wrapper, .ag-theme-quartz-dark .ag-chart-data-wrapper, .ag-theme-quartz-dark .ag-charts-format-top-level-group, .ag-theme-quartz-dark .ag-charts-format-top-level-group-title-bar, .ag-theme-quartz-dark .ag-charts-format-top-level-group .ag-charts-format-top-level-group-container, .ag-theme-quartz-dark .ag-charts-format-top-level-group-item, .ag-theme-quartz-dark .ag-charts-format-sub-level-group, .ag-theme-quartz-dark .ag-charts-format-sub-level-group-title-bar, .ag-theme-quartz-dark .ag-charts-format-sub-level-group-container, .ag-theme-quartz-dark .ag-charts-format-sub-level-group-item:last-child, .ag-theme-quartz-dark .ag-charts-format-sub-level-group-container > *, .ag-theme-quartz-dark .ag-charts-data-group-title-bar, .ag-theme-quartz-dark .ag-charts-data-group-container, .ag-theme-quartz-dark .ag-charts-settings-group-title-bar, .ag-theme-quartz-dark .ag-charts-settings-group-container, .ag-theme-quartz-auto-dark .ag-chart-format-wrapper, .ag-theme-quartz-auto-dark .ag-chart-data-wrapper, .ag-theme-quartz-auto-dark .ag-charts-format-top-level-group, .ag-theme-quartz-auto-dark .ag-charts-format-top-level-group-title-bar, .ag-theme-quartz-auto-dark .ag-charts-format-top-level-group .ag-charts-format-top-level-group-container, .ag-theme-quartz-auto-dark .ag-charts-format-top-level-group-item, .ag-theme-quartz-auto-dark .ag-charts-format-sub-level-group, .ag-theme-quartz-auto-dark .ag-charts-format-sub-level-group-title-bar, .ag-theme-quartz-auto-dark .ag-charts-format-sub-level-group-container, .ag-theme-quartz-auto-dark .ag-charts-format-sub-level-group-item:last-child, .ag-theme-quartz-auto-dark .ag-charts-format-sub-level-group-container > *, .ag-theme-quartz-auto-dark .ag-charts-data-group-title-bar, .ag-theme-quartz-auto-dark .ag-charts-data-group-container, .ag-theme-quartz-auto-dark .ag-charts-settings-group-title-bar, .ag-theme-quartz-auto-dark .ag-charts-settings-group-container {
  padding: 0;
  margin: 0;
}
.ag-theme-quartz .ag-charts-format-top-level-group, .ag-theme-quartz .ag-charts-data-group, .ag-theme-quartz-dark .ag-charts-format-top-level-group, .ag-theme-quartz-dark .ag-charts-data-group, .ag-theme-quartz-auto-dark .ag-charts-format-top-level-group, .ag-theme-quartz-auto-dark .ag-charts-data-group {
  border-top: var(--ag-borders-secondary) var(--ag-secondary-border-color);
}
.ag-theme-quartz .ag-charts-format-top-level-group-title-bar, .ag-theme-quartz .ag-charts-data-group-title-bar, .ag-theme-quartz .ag-charts-settings-group-title-bar, .ag-theme-quartz-dark .ag-charts-format-top-level-group-title-bar, .ag-theme-quartz-dark .ag-charts-data-group-title-bar, .ag-theme-quartz-dark .ag-charts-settings-group-title-bar, .ag-theme-quartz-auto-dark .ag-charts-format-top-level-group-title-bar, .ag-theme-quartz-auto-dark .ag-charts-data-group-title-bar, .ag-theme-quartz-auto-dark .ag-charts-settings-group-title-bar {
  padding: var(--ag-widget-container-vertical-padding) var(--ag-widget-container-horizontal-padding);
}
.ag-theme-quartz .ag-charts-format-top-level-group .ag-charts-format-top-level-group-container, .ag-theme-quartz .ag-charts-data-group .ag-charts-data-group-container, .ag-theme-quartz .ag-charts-settings-group .ag-charts-settings-group-container, .ag-theme-quartz-dark .ag-charts-format-top-level-group .ag-charts-format-top-level-group-container, .ag-theme-quartz-dark .ag-charts-data-group .ag-charts-data-group-container, .ag-theme-quartz-dark .ag-charts-settings-group .ag-charts-settings-group-container, .ag-theme-quartz-auto-dark .ag-charts-format-top-level-group .ag-charts-format-top-level-group-container, .ag-theme-quartz-auto-dark .ag-charts-data-group .ag-charts-data-group-container, .ag-theme-quartz-auto-dark .ag-charts-settings-group .ag-charts-settings-group-container {
  padding: 0 var(--ag-widget-container-horizontal-padding);
}
.ag-theme-quartz .ag-charts-format-sub-level-group-title-bar, .ag-theme-quartz-dark .ag-charts-format-sub-level-group-title-bar, .ag-theme-quartz-auto-dark .ag-charts-format-sub-level-group-title-bar {
  padding: var(--ag-widget-vertical-spacing) 0;
}
.ag-theme-quartz .ag-charts-format-sub-level-group-container, .ag-theme-quartz-dark .ag-charts-format-sub-level-group-container, .ag-theme-quartz-auto-dark .ag-charts-format-sub-level-group-container {
  padding-top: var(--ag-widget-vertical-spacing);
  padding-bottom: var(--ag-widget-container-vertical-padding);
}
.ag-theme-quartz .ag-charts-format-top-level-group-container > *, .ag-theme-quartz .ag-charts-format-sub-level-group-container > *, .ag-theme-quartz-dark .ag-charts-format-top-level-group-container > *, .ag-theme-quartz-dark .ag-charts-format-sub-level-group-container > *, .ag-theme-quartz-auto-dark .ag-charts-format-top-level-group-container > *, .ag-theme-quartz-auto-dark .ag-charts-format-sub-level-group-container > * {
  margin-bottom: var(--ag-widget-vertical-spacing);
}
.ag-theme-quartz .ag-charts-data-group-item, .ag-theme-quartz-dark .ag-charts-data-group-item, .ag-theme-quartz-auto-dark .ag-charts-data-group-item {
  padding-bottom: var(--ag-widget-container-vertical-padding);
}
.ag-theme-quartz .ag-chart-settings-mini-wrapper, .ag-theme-quartz-dark .ag-chart-settings-mini-wrapper, .ag-theme-quartz-auto-dark .ag-chart-settings-mini-wrapper {
  padding-bottom: var(--ag-widget-container-vertical-padding);
}
.ag-theme-quartz .ag-chart-advanced-settings-section, .ag-theme-quartz-dark .ag-chart-advanced-settings-section, .ag-theme-quartz-auto-dark .ag-chart-advanced-settings-section {
  padding-top: var(--ag-widget-container-vertical-padding);
  padding-bottom: var(--ag-widget-container-vertical-padding);
}
.ag-theme-quartz .ag-charts-advanced-settings-top-level-group .ag-charts-advanced-settings-top-level-group-title-bar, .ag-theme-quartz .ag-charts-advanced-settings-top-level-group .ag-charts-advanced-settings-top-level-group-container, .ag-theme-quartz-dark .ag-charts-advanced-settings-top-level-group .ag-charts-advanced-settings-top-level-group-title-bar, .ag-theme-quartz-dark .ag-charts-advanced-settings-top-level-group .ag-charts-advanced-settings-top-level-group-container, .ag-theme-quartz-auto-dark .ag-charts-advanced-settings-top-level-group .ag-charts-advanced-settings-top-level-group-title-bar, .ag-theme-quartz-auto-dark .ag-charts-advanced-settings-top-level-group .ag-charts-advanced-settings-top-level-group-container {
  padding: 0 var(--ag-widget-container-horizontal-padding);
}
.ag-theme-quartz .ag-charts-advanced-settings-top-level-group-container, .ag-theme-quartz-dark .ag-charts-advanced-settings-top-level-group-container, .ag-theme-quartz-auto-dark .ag-charts-advanced-settings-top-level-group-container {
  margin: 0;
}
.ag-theme-quartz .ag-charts-advanced-settings-top-level-group-item, .ag-theme-quartz-dark .ag-charts-advanced-settings-top-level-group-item, .ag-theme-quartz-auto-dark .ag-charts-advanced-settings-top-level-group-item {
  margin-top: calc(var(--ag-widget-vertical-spacing) * 2);
  margin-bottom: 0;
}
.ag-theme-quartz .ag-ltr .ag-group-title-bar-icon, .ag-theme-quartz-dark .ag-ltr .ag-group-title-bar-icon, .ag-theme-quartz-auto-dark .ag-ltr .ag-group-title-bar-icon {
  margin-right: var(--ag-grid-size);
}
.ag-theme-quartz .ag-rtl .ag-group-title-bar-icon, .ag-theme-quartz-dark .ag-rtl .ag-group-title-bar-icon, .ag-theme-quartz-auto-dark .ag-rtl .ag-group-title-bar-icon {
  margin-left: var(--ag-grid-size);
}
.ag-theme-quartz .ag-spectrum-color, .ag-theme-quartz .ag-spectrum-fill, .ag-theme-quartz-dark .ag-spectrum-color, .ag-theme-quartz-dark .ag-spectrum-fill, .ag-theme-quartz-auto-dark .ag-spectrum-color, .ag-theme-quartz-auto-dark .ag-spectrum-fill {
  border-radius: var(--ag-border-radius);
}
.ag-theme-quartz .ag-spectrum-dragger, .ag-theme-quartz-dark .ag-spectrum-dragger, .ag-theme-quartz-auto-dark .ag-spectrum-dragger {
  border-radius: 18px;
  height: 18px;
  width: 18px;
  border: 3px solid white;
}
.ag-theme-quartz .ag-spectrum-tools, .ag-theme-quartz-dark .ag-spectrum-tools, .ag-theme-quartz-auto-dark .ag-spectrum-tools {
  padding-left: 0;
  padding-right: 0;
  padding-bottom: 0;
}
.ag-theme-quartz .ag-spectrum-tool, .ag-theme-quartz-dark .ag-spectrum-tool, .ag-theme-quartz-auto-dark .ag-spectrum-tool {
  height: 12px;
}
.ag-theme-quartz .ag-spectrum-hue-background, .ag-theme-quartz .ag-spectrum-alpha-background, .ag-theme-quartz-dark .ag-spectrum-hue-background, .ag-theme-quartz-dark .ag-spectrum-alpha-background, .ag-theme-quartz-auto-dark .ag-spectrum-hue-background, .ag-theme-quartz-auto-dark .ag-spectrum-alpha-background {
  border-radius: 12px;
}
.ag-theme-quartz .ag-spectrum-slider, .ag-theme-quartz-dark .ag-spectrum-slider, .ag-theme-quartz-auto-dark .ag-spectrum-slider {
  margin-top: -15px;
  width: 18px;
  height: 18px;
  border-radius: 18px;
  border: 3px solid rgb(248, 248, 248);
}
.ag-theme-quartz .ag-recent-colors, .ag-theme-quartz-dark .ag-recent-colors, .ag-theme-quartz-auto-dark .ag-recent-colors {
  margin-left: var(--ag-grid-size);
  margin-right: var(--ag-grid-size);
  margin-bottom: 2px;
}
.ag-theme-quartz .ag-color-input-color, .ag-theme-quartz .ag-color-picker-color, .ag-theme-quartz .ag-recent-color, .ag-theme-quartz-dark .ag-color-input-color, .ag-theme-quartz-dark .ag-color-picker-color, .ag-theme-quartz-dark .ag-recent-color, .ag-theme-quartz-auto-dark .ag-color-input-color, .ag-theme-quartz-auto-dark .ag-color-picker-color, .ag-theme-quartz-auto-dark .ag-recent-color {
  border-radius: 4px;
}
.ag-theme-quartz .ag-recent-color, .ag-theme-quartz-dark .ag-recent-color, .ag-theme-quartz-auto-dark .ag-recent-color {
  border: var(--ag-borders-secondary) var(--ag-secondary-border-color);
}
.ag-theme-quartz.ag-dnd-ghost, .ag-theme-quartz-dark.ag-dnd-ghost, .ag-theme-quartz-auto-dark.ag-dnd-ghost {
  font-weight: 500;
}
.ag-theme-quartz .ag-standard-button, .ag-theme-quartz-dark .ag-standard-button, .ag-theme-quartz-auto-dark .ag-standard-button {
  font-family: inherit;
  appearance: none;
  -webkit-appearance: none;
  border-radius: var(--ag-border-radius);
  border: solid 1px var(--ag-input-border-color);
  background-color: var(--ag-background-color);
  padding: var(--ag-grid-size) calc(var(--ag-grid-size) * 2);
  cursor: pointer;
}
.ag-theme-quartz .ag-standard-button:hover, .ag-theme-quartz-dark .ag-standard-button:hover, .ag-theme-quartz-auto-dark .ag-standard-button:hover {
  background-color: var(--ag-row-hover-color);
}
.ag-theme-quartz .ag-standard-button:active, .ag-theme-quartz-dark .ag-standard-button:active, .ag-theme-quartz-auto-dark .ag-standard-button:active {
  border-color: var(--ag-active-color);
}
.ag-theme-quartz .ag-standard-button:disabled, .ag-theme-quartz-dark .ag-standard-button:disabled, .ag-theme-quartz-auto-dark .ag-standard-button:disabled {
  color: var(--ag-disabled-foreground-color);
  background-color: var(--ag-input-disabled-background-color);
  border-color: var(--ag-input-disabled-border-color);
}
.ag-theme-quartz .ag-column-drop-cell, .ag-theme-quartz-dark .ag-column-drop-cell, .ag-theme-quartz-auto-dark .ag-column-drop-cell {
  border-radius: calc(var(--ag-grid-size) * 3);
  height: calc(var(--ag-grid-size) * 3);
  padding: 0 var(--ag-grid-size);
}
.ag-theme-quartz .ag-column-drop-cell-button, .ag-theme-quartz-dark .ag-column-drop-cell-button, .ag-theme-quartz-auto-dark .ag-column-drop-cell-button {
  min-width: 0;
  margin: 0;
}
.ag-theme-quartz .ag-column-drop-cell-drag-handle, .ag-theme-quartz-dark .ag-column-drop-cell-drag-handle, .ag-theme-quartz-auto-dark .ag-column-drop-cell-drag-handle {
  margin-left: 0;
}
.ag-theme-quartz .ag-column-drop-vertical, .ag-theme-quartz-dark .ag-column-drop-vertical, .ag-theme-quartz-auto-dark .ag-column-drop-vertical {
  min-height: 75px;
}
.ag-theme-quartz .ag-column-drop-vertical-title-bar, .ag-theme-quartz-dark .ag-column-drop-vertical-title-bar, .ag-theme-quartz-auto-dark .ag-column-drop-vertical-title-bar {
  padding: var(--ag-widget-container-vertical-padding) calc(var(--ag-grid-size) * 2) 0;
}
.ag-theme-quartz .ag-ltr .ag-column-drop-vertical-icon, .ag-theme-quartz-dark .ag-ltr .ag-column-drop-vertical-icon, .ag-theme-quartz-auto-dark .ag-ltr .ag-column-drop-vertical-icon {
  margin-left: 0;
  margin-right: var(--ag-widget-horizontal-spacing);
}
.ag-theme-quartz .ag-rtl .ag-column-drop-vertical-icon, .ag-theme-quartz-dark .ag-rtl .ag-column-drop-vertical-icon, .ag-theme-quartz-auto-dark .ag-rtl .ag-column-drop-vertical-icon {
  margin-right: 0;
  margin-left: var(--ag-widget-horizontal-spacing);
}
.ag-theme-quartz .ag-column-drop-vertical-empty-message, .ag-theme-quartz-dark .ag-column-drop-vertical-empty-message, .ag-theme-quartz-auto-dark .ag-column-drop-vertical-empty-message {
  display: flex;
  align-items: center;
  justify-content: center;
  border: dashed 1px;
  border-color: var(--ag-border-color);
  margin: calc(var(--ag-grid-size) * 1.5) calc(var(--ag-grid-size) * 2);
  padding: calc(var(--ag-grid-size) * 2);
}
.ag-theme-quartz .ag-column-drop-empty-message, .ag-theme-quartz-dark .ag-column-drop-empty-message, .ag-theme-quartz-auto-dark .ag-column-drop-empty-message {
  color: var(--ag-foreground-color);
}
.ag-theme-quartz .ag-pill-select .ag-column-drop, .ag-theme-quartz-dark .ag-pill-select .ag-column-drop, .ag-theme-quartz-auto-dark .ag-pill-select .ag-column-drop {
  min-height: unset;
}
.ag-theme-quartz .ag-pill-select .ag-picker-field-display, .ag-theme-quartz-dark .ag-pill-select .ag-picker-field-display, .ag-theme-quartz-auto-dark .ag-pill-select .ag-picker-field-display {
  font-weight: 500;
  color: var(--ag-chart-menu-pill-select-button-color);
}
.ag-theme-quartz .ag-pill-select .ag-picker-field-icon .ag-icon, .ag-theme-quartz-dark .ag-pill-select .ag-picker-field-icon .ag-icon, .ag-theme-quartz-auto-dark .ag-pill-select .ag-picker-field-icon .ag-icon {
  color: var(--ag-chart-menu-pill-select-button-color);
}
.ag-theme-quartz .ag-status-bar, .ag-theme-quartz-dark .ag-status-bar, .ag-theme-quartz-auto-dark .ag-status-bar {
  font-weight: normal;
}
.ag-theme-quartz .ag-status-name-value, .ag-theme-quartz-dark .ag-status-name-value, .ag-theme-quartz-auto-dark .ag-status-name-value {
  padding: var(--ag-widget-container-vertical-padding) 0;
}
.ag-theme-quartz .ag-status-name-value-value, .ag-theme-quartz .ag-paging-number, .ag-theme-quartz .ag-paging-row-summary-panel-number, .ag-theme-quartz-dark .ag-status-name-value-value, .ag-theme-quartz-dark .ag-paging-number, .ag-theme-quartz-dark .ag-paging-row-summary-panel-number, .ag-theme-quartz-auto-dark .ag-status-name-value-value, .ag-theme-quartz-auto-dark .ag-paging-number, .ag-theme-quartz-auto-dark .ag-paging-row-summary-panel-number {
  font-weight: 500;
}
.ag-theme-quartz .ag-column-drop-cell-button, .ag-theme-quartz-dark .ag-column-drop-cell-button, .ag-theme-quartz-auto-dark .ag-column-drop-cell-button {
  opacity: 0.75;
}
.ag-theme-quartz .ag-column-drop-cell-button:hover, .ag-theme-quartz-dark .ag-column-drop-cell-button:hover, .ag-theme-quartz-auto-dark .ag-column-drop-cell-button:hover {
  opacity: 1;
}
.ag-theme-quartz .ag-header-cell-menu-button, .ag-theme-quartz .ag-header-cell-filter-button, .ag-theme-quartz .ag-panel-title-bar-button, .ag-theme-quartz .ag-header-expand-icon, .ag-theme-quartz .ag-column-group-icons, .ag-theme-quartz .ag-set-filter-group-icons, .ag-theme-quartz .ag-group-expanded .ag-icon, .ag-theme-quartz .ag-group-contracted .ag-icon, .ag-theme-quartz .ag-chart-settings-prev, .ag-theme-quartz .ag-chart-settings-next, .ag-theme-quartz .ag-group-title-bar-icon, .ag-theme-quartz .ag-column-select-header-icon, .ag-theme-quartz .ag-floating-filter-button-button, .ag-theme-quartz .ag-filter-toolpanel-expand, .ag-theme-quartz .ag-panel-title-bar-button-icon, .ag-theme-quartz .ag-chart-menu-icon, .ag-theme-quartz-dark .ag-header-cell-menu-button, .ag-theme-quartz-dark .ag-header-cell-filter-button, .ag-theme-quartz-dark .ag-panel-title-bar-button, .ag-theme-quartz-dark .ag-header-expand-icon, .ag-theme-quartz-dark .ag-column-group-icons, .ag-theme-quartz-dark .ag-set-filter-group-icons, .ag-theme-quartz-dark .ag-group-expanded .ag-icon, .ag-theme-quartz-dark .ag-group-contracted .ag-icon, .ag-theme-quartz-dark .ag-chart-settings-prev, .ag-theme-quartz-dark .ag-chart-settings-next, .ag-theme-quartz-dark .ag-group-title-bar-icon, .ag-theme-quartz-dark .ag-column-select-header-icon, .ag-theme-quartz-dark .ag-floating-filter-button-button, .ag-theme-quartz-dark .ag-filter-toolpanel-expand, .ag-theme-quartz-dark .ag-panel-title-bar-button-icon, .ag-theme-quartz-dark .ag-chart-menu-icon, .ag-theme-quartz-auto-dark .ag-header-cell-menu-button, .ag-theme-quartz-auto-dark .ag-header-cell-filter-button, .ag-theme-quartz-auto-dark .ag-panel-title-bar-button, .ag-theme-quartz-auto-dark .ag-header-expand-icon, .ag-theme-quartz-auto-dark .ag-column-group-icons, .ag-theme-quartz-auto-dark .ag-set-filter-group-icons, .ag-theme-quartz-auto-dark .ag-group-expanded .ag-icon, .ag-theme-quartz-auto-dark .ag-group-contracted .ag-icon, .ag-theme-quartz-auto-dark .ag-chart-settings-prev, .ag-theme-quartz-auto-dark .ag-chart-settings-next, .ag-theme-quartz-auto-dark .ag-group-title-bar-icon, .ag-theme-quartz-auto-dark .ag-column-select-header-icon, .ag-theme-quartz-auto-dark .ag-floating-filter-button-button, .ag-theme-quartz-auto-dark .ag-filter-toolpanel-expand, .ag-theme-quartz-auto-dark .ag-panel-title-bar-button-icon, .ag-theme-quartz-auto-dark .ag-chart-menu-icon {
  --ag-quartz-icon-hover-color: transparent;
  @supports (color: color-mix(in lab, red, red)) {
    --ag-quartz-icon-hover-color: color-mix(in srgb, transparent, var(--ag-foreground-color) 10%);
  }
}
.ag-theme-quartz .ag-header-cell-menu-button:hover, .ag-theme-quartz .ag-header-cell-filter-button:hover, .ag-theme-quartz .ag-panel-title-bar-button:hover, .ag-theme-quartz .ag-header-expand-icon:hover, .ag-theme-quartz .ag-column-group-icons:hover, .ag-theme-quartz .ag-set-filter-group-icons:hover, .ag-theme-quartz .ag-group-expanded .ag-icon:hover, .ag-theme-quartz .ag-group-contracted .ag-icon:hover, .ag-theme-quartz .ag-chart-settings-prev:hover, .ag-theme-quartz .ag-chart-settings-next:hover, .ag-theme-quartz .ag-group-title-bar-icon:hover, .ag-theme-quartz .ag-column-select-header-icon:hover, .ag-theme-quartz .ag-floating-filter-button-button:hover, .ag-theme-quartz .ag-filter-toolpanel-expand:hover, .ag-theme-quartz .ag-panel-title-bar-button-icon:hover, .ag-theme-quartz .ag-chart-menu-icon:hover, .ag-theme-quartz-dark .ag-header-cell-menu-button:hover, .ag-theme-quartz-dark .ag-header-cell-filter-button:hover, .ag-theme-quartz-dark .ag-panel-title-bar-button:hover, .ag-theme-quartz-dark .ag-header-expand-icon:hover, .ag-theme-quartz-dark .ag-column-group-icons:hover, .ag-theme-quartz-dark .ag-set-filter-group-icons:hover, .ag-theme-quartz-dark .ag-group-expanded .ag-icon:hover, .ag-theme-quartz-dark .ag-group-contracted .ag-icon:hover, .ag-theme-quartz-dark .ag-chart-settings-prev:hover, .ag-theme-quartz-dark .ag-chart-settings-next:hover, .ag-theme-quartz-dark .ag-group-title-bar-icon:hover, .ag-theme-quartz-dark .ag-column-select-header-icon:hover, .ag-theme-quartz-dark .ag-floating-filter-button-button:hover, .ag-theme-quartz-dark .ag-filter-toolpanel-expand:hover, .ag-theme-quartz-dark .ag-panel-title-bar-button-icon:hover, .ag-theme-quartz-dark .ag-chart-menu-icon:hover, .ag-theme-quartz-auto-dark .ag-header-cell-menu-button:hover, .ag-theme-quartz-auto-dark .ag-header-cell-filter-button:hover, .ag-theme-quartz-auto-dark .ag-panel-title-bar-button:hover, .ag-theme-quartz-auto-dark .ag-header-expand-icon:hover, .ag-theme-quartz-auto-dark .ag-column-group-icons:hover, .ag-theme-quartz-auto-dark .ag-set-filter-group-icons:hover, .ag-theme-quartz-auto-dark .ag-group-expanded .ag-icon:hover, .ag-theme-quartz-auto-dark .ag-group-contracted .ag-icon:hover, .ag-theme-quartz-auto-dark .ag-chart-settings-prev:hover, .ag-theme-quartz-auto-dark .ag-chart-settings-next:hover, .ag-theme-quartz-auto-dark .ag-group-title-bar-icon:hover, .ag-theme-quartz-auto-dark .ag-column-select-header-icon:hover, .ag-theme-quartz-auto-dark .ag-floating-filter-button-button:hover, .ag-theme-quartz-auto-dark .ag-filter-toolpanel-expand:hover, .ag-theme-quartz-auto-dark .ag-panel-title-bar-button-icon:hover, .ag-theme-quartz-auto-dark .ag-chart-menu-icon:hover {
  border-radius: 1px;
  background-color: var(--ag-quartz-icon-hover-color);
  box-shadow: 0 0 0 4px var(--ag-quartz-icon-hover-color);
}
.ag-theme-quartz .ag-filter-active, .ag-theme-quartz .ag-filter-toolpanel-group-instance-header-icon, .ag-theme-quartz .ag-filter-toolpanel-instance-header-icon, .ag-theme-quartz-dark .ag-filter-active, .ag-theme-quartz-dark .ag-filter-toolpanel-group-instance-header-icon, .ag-theme-quartz-dark .ag-filter-toolpanel-instance-header-icon, .ag-theme-quartz-auto-dark .ag-filter-active, .ag-theme-quartz-auto-dark .ag-filter-toolpanel-group-instance-header-icon, .ag-theme-quartz-auto-dark .ag-filter-toolpanel-instance-header-icon {
  position: relative;
}
.ag-theme-quartz .ag-filter-active::after, .ag-theme-quartz .ag-filter-toolpanel-group-instance-header-icon::after, .ag-theme-quartz .ag-filter-toolpanel-instance-header-icon::after, .ag-theme-quartz-dark .ag-filter-active::after, .ag-theme-quartz-dark .ag-filter-toolpanel-group-instance-header-icon::after, .ag-theme-quartz-dark .ag-filter-toolpanel-instance-header-icon::after, .ag-theme-quartz-auto-dark .ag-filter-active::after, .ag-theme-quartz-auto-dark .ag-filter-toolpanel-group-instance-header-icon::after, .ag-theme-quartz-auto-dark .ag-filter-toolpanel-instance-header-icon::after {
  content: "";
  position: absolute;
  width: 6px;
  height: 6px;
  top: -1px;
  right: -1px;
  border-radius: 50%;
  background-color: var(--ag-active-color);
}
.ag-theme-quartz .ag-filter-active, .ag-theme-quartz-dark .ag-filter-active, .ag-theme-quartz-auto-dark .ag-filter-active {
  --ag-quartz-icon-active-color: transparent;
  @supports (color: color-mix(in lab, red, red)) {
    --ag-quartz-icon-active-color: color-mix(in srgb, transparent, var(--ag-active-color) 14%);
  }
  --ag-quartz-icon-hover-color: transparent;
  @supports (color: color-mix(in lab, red, red)) {
    --ag-quartz-icon-hover-color: color-mix(in srgb, transparent, var(--ag-active-color) 28%);
  }
  border-radius: 1px;
  background-color: var(--ag-quartz-icon-active-color);
  box-shadow: 0 0 0 4px var(--ag-quartz-icon-active-color);
}
.ag-theme-quartz .ag-filter-active .ag-icon-filter, .ag-theme-quartz-dark .ag-filter-active .ag-icon-filter, .ag-theme-quartz-auto-dark .ag-filter-active .ag-icon-filter {
  clip-path: path("M8,0C8,4.415 11.585,8 16,8L16,16L0,16L0,0L8,0Z");
}
.ag-theme-quartz .ag-chart-menu, .ag-theme-quartz-dark .ag-chart-menu, .ag-theme-quartz-auto-dark .ag-chart-menu {
  --ag-icon-size: 20px;
  background-color: transparent;
  @supports (color: color-mix(in lab, red, red)) {
    background-color: color-mix(in srgb, transparent, var(--ag-background-color) 30%);
  }
  padding: 4px 2px;
}
.ag-theme-quartz .ag-chart-menu-icon, .ag-theme-quartz-dark .ag-chart-menu-icon, .ag-theme-quartz-auto-dark .ag-chart-menu-icon {
  opacity: 0.8;
}
.ag-theme-quartz .ag-drag-handle, .ag-theme-quartz-dark .ag-drag-handle, .ag-theme-quartz-auto-dark .ag-drag-handle {
  color: var(--ag-icon-font-color);
}
.ag-theme-quartz .ag-menu-option-icon, .ag-theme-quartz .ag-compact-menu-option-icon, .ag-theme-quartz-dark .ag-menu-option-icon, .ag-theme-quartz-dark .ag-compact-menu-option-icon, .ag-theme-quartz-auto-dark .ag-menu-option-icon, .ag-theme-quartz-auto-dark .ag-compact-menu-option-icon {
  width: var(--ag-icon-size);
  cursor: pointer;
}
.ag-theme-quartz .ag-ltr .ag-menu-option-icon, .ag-theme-quartz .ag-ltr .ag-compact-menu-option-icon, .ag-theme-quartz-dark .ag-ltr .ag-menu-option-icon, .ag-theme-quartz-dark .ag-ltr .ag-compact-menu-option-icon, .ag-theme-quartz-auto-dark .ag-ltr .ag-menu-option-icon, .ag-theme-quartz-auto-dark .ag-ltr .ag-compact-menu-option-icon {
  padding-left: calc(var(--ag-grid-size) * 1.5);
}
.ag-theme-quartz .ag-rtl .ag-menu-option-icon, .ag-theme-quartz .ag-rtl .ag-compact-menu-option-icon, .ag-theme-quartz-dark .ag-rtl .ag-menu-option-icon, .ag-theme-quartz-dark .ag-rtl .ag-compact-menu-option-icon, .ag-theme-quartz-auto-dark .ag-rtl .ag-menu-option-icon, .ag-theme-quartz-auto-dark .ag-rtl .ag-compact-menu-option-icon {
  padding-right: calc(var(--ag-grid-size) * 1.5);
}
.ag-theme-quartz .ag-chart-settings-card-item.ag-not-selected:hover, .ag-theme-quartz-dark .ag-chart-settings-card-item.ag-not-selected:hover, .ag-theme-quartz-auto-dark .ag-chart-settings-card-item.ag-not-selected:hover {
  opacity: 0.35;
}
.ag-theme-quartz .ag-ltr .ag-panel-title-bar-button, .ag-theme-quartz-dark .ag-ltr .ag-panel-title-bar-button, .ag-theme-quartz-auto-dark .ag-ltr .ag-panel-title-bar-button {
  margin-left: calc(var(--ag-grid-size) * 2);
  margin-right: var(--ag-grid-size);
}
.ag-theme-quartz .ag-rtl .ag-panel-title-bar-button, .ag-theme-quartz-dark .ag-rtl .ag-panel-title-bar-button, .ag-theme-quartz-auto-dark .ag-rtl .ag-panel-title-bar-button {
  margin-right: calc(var(--ag-grid-size) * 2);
  margin-left: var(--ag-grid-size);
}
.ag-theme-quartz .ag-multi-filter-group-title-bar, .ag-theme-quartz-dark .ag-multi-filter-group-title-bar, .ag-theme-quartz-auto-dark .ag-multi-filter-group-title-bar {
  padding: calc(var(--ag-grid-size) * 1.5) var(--ag-grid-size);
}
.ag-theme-quartz .ag-ltr .ag-filter-toolpanel-instance-body, .ag-theme-quartz-dark .ag-ltr .ag-filter-toolpanel-instance-body, .ag-theme-quartz-auto-dark .ag-ltr .ag-filter-toolpanel-instance-body {
  padding-left: var(--ag-grid-size);
}
.ag-theme-quartz .ag-rtl .ag-filter-toolpanel-instance-body, .ag-theme-quartz-dark .ag-rtl .ag-filter-toolpanel-instance-body, .ag-theme-quartz-auto-dark .ag-rtl .ag-filter-toolpanel-instance-body {
  padding-right: var(--ag-grid-size);
}
.ag-theme-quartz .ag-filter-toolpanel-instance-filter, .ag-theme-quartz-dark .ag-filter-toolpanel-instance-filter, .ag-theme-quartz-auto-dark .ag-filter-toolpanel-instance-filter {
  border: none;
  background-color: var(--ag-control-panel-background-color);
}
.ag-theme-quartz .ag-ltr .ag-filter-toolpanel-instance-filter, .ag-theme-quartz-dark .ag-ltr .ag-filter-toolpanel-instance-filter, .ag-theme-quartz-auto-dark .ag-ltr .ag-filter-toolpanel-instance-filter {
  margin-left: calc(var(--ag-icon-size) * 0.5);
}
.ag-theme-quartz .ag-rtl .ag-filter-toolpanel-instance-filter, .ag-theme-quartz-dark .ag-rtl .ag-filter-toolpanel-instance-filter, .ag-theme-quartz-auto-dark .ag-rtl .ag-filter-toolpanel-instance-filter {
  margin-right: calc(var(--ag-icon-size) * 0.5);
}
.ag-theme-quartz .ag-filter-toolpanel-group-level-0, .ag-theme-quartz-dark .ag-filter-toolpanel-group-level-0, .ag-theme-quartz-auto-dark .ag-filter-toolpanel-group-level-0 {
  border-top: none;
}
.ag-theme-quartz .ag-filter-toolpanel-header, .ag-theme-quartz-dark .ag-filter-toolpanel-header, .ag-theme-quartz-auto-dark .ag-filter-toolpanel-header {
  height: initial;
  padding-top: var(--ag-grid-size);
  padding-bottom: var(--ag-grid-size);
}
.ag-theme-quartz .ag-filter-toolpanel-group-item, .ag-theme-quartz-dark .ag-filter-toolpanel-group-item, .ag-theme-quartz-auto-dark .ag-filter-toolpanel-group-item {
  margin: 0;
}
.ag-theme-quartz .ag-layout-auto-height .ag-center-cols-viewport, .ag-theme-quartz .ag-layout-auto-height .ag-center-cols-container, .ag-theme-quartz .ag-layout-print .ag-center-cols-viewport, .ag-theme-quartz .ag-layout-print .ag-center-cols-container, .ag-theme-quartz-dark .ag-layout-auto-height .ag-center-cols-viewport, .ag-theme-quartz-dark .ag-layout-auto-height .ag-center-cols-container, .ag-theme-quartz-dark .ag-layout-print .ag-center-cols-viewport, .ag-theme-quartz-dark .ag-layout-print .ag-center-cols-container, .ag-theme-quartz-auto-dark .ag-layout-auto-height .ag-center-cols-viewport, .ag-theme-quartz-auto-dark .ag-layout-auto-height .ag-center-cols-container, .ag-theme-quartz-auto-dark .ag-layout-print .ag-center-cols-viewport, .ag-theme-quartz-auto-dark .ag-layout-print .ag-center-cols-container {
  min-height: 150px;
}
.ag-theme-quartz .ag-date-time-list-page-entry-is-current, .ag-theme-quartz-dark .ag-date-time-list-page-entry-is-current, .ag-theme-quartz-auto-dark .ag-date-time-list-page-entry-is-current {
  background-color: var(--ag-active-color);
}
.ag-theme-quartz .ag-advanced-filter-builder-button, .ag-theme-quartz-dark .ag-advanced-filter-builder-button, .ag-theme-quartz-auto-dark .ag-advanced-filter-builder-button {
  padding: var(--ag-grid-size);
  font-weight: 600;
}
.ag-theme-quartz .ag-advanced-filter-builder-item-button-disabled .ag-icon, .ag-theme-quartz .ag-disabled .ag-icon, .ag-theme-quartz .ag-column-select-column-group-readonly .ag-icon, .ag-theme-quartz [disabled] .ag-icon, .ag-theme-quartz-dark .ag-advanced-filter-builder-item-button-disabled .ag-icon, .ag-theme-quartz-dark .ag-disabled .ag-icon, .ag-theme-quartz-dark .ag-column-select-column-group-readonly .ag-icon, .ag-theme-quartz-dark [disabled] .ag-icon, .ag-theme-quartz-auto-dark .ag-advanced-filter-builder-item-button-disabled .ag-icon, .ag-theme-quartz-auto-dark .ag-disabled .ag-icon, .ag-theme-quartz-auto-dark .ag-column-select-column-group-readonly .ag-icon, .ag-theme-quartz-auto-dark [disabled] .ag-icon {
  opacity: 0.6;
}
.ag-theme-quartz .ag-icon-grip, .ag-theme-quartz-dark .ag-icon-grip, .ag-theme-quartz-auto-dark .ag-icon-grip {
  opacity: 0.7;
}
.ag-theme-quartz .ag-column-select-column-readonly.ag-icon-grip, .ag-theme-quartz .ag-column-select-column-readonly .ag-icon-grip, .ag-theme-quartz-dark .ag-column-select-column-readonly.ag-icon-grip, .ag-theme-quartz-dark .ag-column-select-column-readonly .ag-icon-grip, .ag-theme-quartz-auto-dark .ag-column-select-column-readonly.ag-icon-grip, .ag-theme-quartz-auto-dark .ag-column-select-column-readonly .ag-icon-grip {
  opacity: 0.35;
}
.ag-theme-quartz .ag-column-select-header-filter-wrapper .ag-input-wrapper::before, .ag-theme-quartz .ag-filter-toolpanel-search .ag-input-wrapper::before, .ag-theme-quartz .ag-mini-filter .ag-input-wrapper::before, .ag-theme-quartz .ag-filter-filter .ag-input-wrapper::before, .ag-theme-quartz .ag-filter-add-select .ag-input-wrapper::before, .ag-theme-quartz-dark .ag-column-select-header-filter-wrapper .ag-input-wrapper::before, .ag-theme-quartz-dark .ag-filter-toolpanel-search .ag-input-wrapper::before, .ag-theme-quartz-dark .ag-mini-filter .ag-input-wrapper::before, .ag-theme-quartz-dark .ag-filter-filter .ag-input-wrapper::before, .ag-theme-quartz-dark .ag-filter-add-select .ag-input-wrapper::before, .ag-theme-quartz-auto-dark .ag-column-select-header-filter-wrapper .ag-input-wrapper::before, .ag-theme-quartz-auto-dark .ag-filter-toolpanel-search .ag-input-wrapper::before, .ag-theme-quartz-auto-dark .ag-mini-filter .ag-input-wrapper::before, .ag-theme-quartz-auto-dark .ag-filter-filter .ag-input-wrapper::before, .ag-theme-quartz-auto-dark .ag-filter-add-select .ag-input-wrapper::before {
  position: absolute;
  display: block;
  width: 12px;
  height: 12px;
  background-image: url("data:image/svg+xml;charset=utf-8;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIxMiIgaGVpZ2h0PSIxMiIgZmlsbD0ibm9uZSIgc3Ryb2tlPSIjMDAwIiBzdHJva2UtbGluZWNhcD0icm91bmQiIHN0cm9rZS1saW5lam9pbj0icm91bmQiIHN0cm9rZS13aWR0aD0iMS41Ij48cGF0aCBkPSJNNS4zIDlhMy43IDMuNyAwIDEgMCAwLTcuNSAzLjcgMy43IDAgMCAwIDAgNy41Wk0xMC41IDEwLjUgOC4zIDguMiIvPjwvc3ZnPg==");
  background-position: 50% 50%;
  background-size: contain;
  opacity: 40%;
  content: "";
  filter: var(--ag-icon-filter);
}
.ag-theme-quartz .ag-ltr .ag-column-select-header-filter-wrapper .ag-input-wrapper::before, .ag-theme-quartz .ag-ltr .ag-filter-toolpanel-search .ag-input-wrapper::before, .ag-theme-quartz .ag-ltr .ag-mini-filter .ag-input-wrapper::before, .ag-theme-quartz .ag-ltr .ag-filter-filter .ag-input-wrapper::before, .ag-theme-quartz .ag-ltr .ag-filter-add-select .ag-input-wrapper::before, .ag-theme-quartz-dark .ag-ltr .ag-column-select-header-filter-wrapper .ag-input-wrapper::before, .ag-theme-quartz-dark .ag-ltr .ag-filter-toolpanel-search .ag-input-wrapper::before, .ag-theme-quartz-dark .ag-ltr .ag-mini-filter .ag-input-wrapper::before, .ag-theme-quartz-dark .ag-ltr .ag-filter-filter .ag-input-wrapper::before, .ag-theme-quartz-dark .ag-ltr .ag-filter-add-select .ag-input-wrapper::before, .ag-theme-quartz-auto-dark .ag-ltr .ag-column-select-header-filter-wrapper .ag-input-wrapper::before, .ag-theme-quartz-auto-dark .ag-ltr .ag-filter-toolpanel-search .ag-input-wrapper::before, .ag-theme-quartz-auto-dark .ag-ltr .ag-mini-filter .ag-input-wrapper::before, .ag-theme-quartz-auto-dark .ag-ltr .ag-filter-filter .ag-input-wrapper::before, .ag-theme-quartz-auto-dark .ag-ltr .ag-filter-add-select .ag-input-wrapper::before {
  margin-left: var(--ag-grid-size);
}
.ag-theme-quartz .ag-rtl .ag-column-select-header-filter-wrapper .ag-input-wrapper::before, .ag-theme-quartz .ag-rtl .ag-filter-toolpanel-search .ag-input-wrapper::before, .ag-theme-quartz .ag-rtl .ag-mini-filter .ag-input-wrapper::before, .ag-theme-quartz .ag-rtl .ag-filter-filter .ag-input-wrapper::before, .ag-theme-quartz .ag-rtl .ag-filter-add-select .ag-input-wrapper::before, .ag-theme-quartz-dark .ag-rtl .ag-column-select-header-filter-wrapper .ag-input-wrapper::before, .ag-theme-quartz-dark .ag-rtl .ag-filter-toolpanel-search .ag-input-wrapper::before, .ag-theme-quartz-dark .ag-rtl .ag-mini-filter .ag-input-wrapper::before, .ag-theme-quartz-dark .ag-rtl .ag-filter-filter .ag-input-wrapper::before, .ag-theme-quartz-dark .ag-rtl .ag-filter-add-select .ag-input-wrapper::before, .ag-theme-quartz-auto-dark .ag-rtl .ag-column-select-header-filter-wrapper .ag-input-wrapper::before, .ag-theme-quartz-auto-dark .ag-rtl .ag-filter-toolpanel-search .ag-input-wrapper::before, .ag-theme-quartz-auto-dark .ag-rtl .ag-mini-filter .ag-input-wrapper::before, .ag-theme-quartz-auto-dark .ag-rtl .ag-filter-filter .ag-input-wrapper::before, .ag-theme-quartz-auto-dark .ag-rtl .ag-filter-add-select .ag-input-wrapper::before {
  margin-right: var(--ag-grid-size);
}
.ag-theme-quartz .ag-ltr .ag-column-select-header-filter-wrapper input.ag-text-field-input, .ag-theme-quartz .ag-ltr .ag-column-select-header-filter-wrapper input.ag-number-field-input, .ag-theme-quartz .ag-ltr .ag-filter-toolpanel-search input.ag-text-field-input, .ag-theme-quartz .ag-ltr .ag-filter-toolpanel-search input.ag-number-field-input, .ag-theme-quartz .ag-ltr .ag-mini-filter input.ag-text-field-input, .ag-theme-quartz .ag-ltr .ag-mini-filter input.ag-number-field-input, .ag-theme-quartz .ag-ltr .ag-filter-filter input.ag-text-field-input, .ag-theme-quartz .ag-ltr .ag-filter-filter input.ag-number-field-input, .ag-theme-quartz .ag-ltr .ag-filter-add-select input.ag-text-field-input, .ag-theme-quartz .ag-ltr .ag-filter-add-select input.ag-number-field-input, .ag-theme-quartz-dark .ag-ltr .ag-column-select-header-filter-wrapper input.ag-text-field-input, .ag-theme-quartz-dark .ag-ltr .ag-column-select-header-filter-wrapper input.ag-number-field-input, .ag-theme-quartz-dark .ag-ltr .ag-filter-toolpanel-search input.ag-text-field-input, .ag-theme-quartz-dark .ag-ltr .ag-filter-toolpanel-search input.ag-number-field-input, .ag-theme-quartz-dark .ag-ltr .ag-mini-filter input.ag-text-field-input, .ag-theme-quartz-dark .ag-ltr .ag-mini-filter input.ag-number-field-input, .ag-theme-quartz-dark .ag-ltr .ag-filter-filter input.ag-text-field-input, .ag-theme-quartz-dark .ag-ltr .ag-filter-filter input.ag-number-field-input, .ag-theme-quartz-dark .ag-ltr .ag-filter-add-select input.ag-text-field-input, .ag-theme-quartz-dark .ag-ltr .ag-filter-add-select input.ag-number-field-input, .ag-theme-quartz-auto-dark .ag-ltr .ag-column-select-header-filter-wrapper input.ag-text-field-input, .ag-theme-quartz-auto-dark .ag-ltr .ag-column-select-header-filter-wrapper input.ag-number-field-input, .ag-theme-quartz-auto-dark .ag-ltr .ag-filter-toolpanel-search input.ag-text-field-input, .ag-theme-quartz-auto-dark .ag-ltr .ag-filter-toolpanel-search input.ag-number-field-input, .ag-theme-quartz-auto-dark .ag-ltr .ag-mini-filter input.ag-text-field-input, .ag-theme-quartz-auto-dark .ag-ltr .ag-mini-filter input.ag-number-field-input, .ag-theme-quartz-auto-dark .ag-ltr .ag-filter-filter input.ag-text-field-input, .ag-theme-quartz-auto-dark .ag-ltr .ag-filter-filter input.ag-number-field-input, .ag-theme-quartz-auto-dark .ag-ltr .ag-filter-add-select input.ag-text-field-input, .ag-theme-quartz-auto-dark .ag-ltr .ag-filter-add-select input.ag-number-field-input {
  padding-left: 26px;
}
.ag-theme-quartz .ag-rtl .ag-column-select-header-filter-wrapper input.ag-text-field-input, .ag-theme-quartz .ag-rtl .ag-column-select-header-filter-wrapper input.ag-number-field-input, .ag-theme-quartz .ag-rtl .ag-filter-toolpanel-search input.ag-text-field-input, .ag-theme-quartz .ag-rtl .ag-filter-toolpanel-search input.ag-number-field-input, .ag-theme-quartz .ag-rtl .ag-mini-filter input.ag-text-field-input, .ag-theme-quartz .ag-rtl .ag-mini-filter input.ag-number-field-input, .ag-theme-quartz .ag-rtl .ag-filter-filter input.ag-text-field-input, .ag-theme-quartz .ag-rtl .ag-filter-filter input.ag-number-field-input, .ag-theme-quartz .ag-rtl .ag-filter-add-select input.ag-text-field-input, .ag-theme-quartz .ag-rtl .ag-filter-add-select input.ag-number-field-input, .ag-theme-quartz-dark .ag-rtl .ag-column-select-header-filter-wrapper input.ag-text-field-input, .ag-theme-quartz-dark .ag-rtl .ag-column-select-header-filter-wrapper input.ag-number-field-input, .ag-theme-quartz-dark .ag-rtl .ag-filter-toolpanel-search input.ag-text-field-input, .ag-theme-quartz-dark .ag-rtl .ag-filter-toolpanel-search input.ag-number-field-input, .ag-theme-quartz-dark .ag-rtl .ag-mini-filter input.ag-text-field-input, .ag-theme-quartz-dark .ag-rtl .ag-mini-filter input.ag-number-field-input, .ag-theme-quartz-dark .ag-rtl .ag-filter-filter input.ag-text-field-input, .ag-theme-quartz-dark .ag-rtl .ag-filter-filter input.ag-number-field-input, .ag-theme-quartz-dark .ag-rtl .ag-filter-add-select input.ag-text-field-input, .ag-theme-quartz-dark .ag-rtl .ag-filter-add-select input.ag-number-field-input, .ag-theme-quartz-auto-dark .ag-rtl .ag-column-select-header-filter-wrapper input.ag-text-field-input, .ag-theme-quartz-auto-dark .ag-rtl .ag-column-select-header-filter-wrapper input.ag-number-field-input, .ag-theme-quartz-auto-dark .ag-rtl .ag-filter-toolpanel-search input.ag-text-field-input, .ag-theme-quartz-auto-dark .ag-rtl .ag-filter-toolpanel-search input.ag-number-field-input, .ag-theme-quartz-auto-dark .ag-rtl .ag-mini-filter input.ag-text-field-input, .ag-theme-quartz-auto-dark .ag-rtl .ag-mini-filter input.ag-number-field-input, .ag-theme-quartz-auto-dark .ag-rtl .ag-filter-filter input.ag-text-field-input, .ag-theme-quartz-auto-dark .ag-rtl .ag-filter-filter input.ag-number-field-input, .ag-theme-quartz-auto-dark .ag-rtl .ag-filter-add-select input.ag-text-field-input, .ag-theme-quartz-auto-dark .ag-rtl .ag-filter-add-select input.ag-number-field-input {
  padding-right: 26px;
}
.ag-theme-quartz .ag-ltr .ag-column-select-add-group-indent, .ag-theme-quartz-dark .ag-ltr .ag-column-select-add-group-indent, .ag-theme-quartz-auto-dark .ag-ltr .ag-column-select-add-group-indent {
  margin-left: calc(var(--ag-icon-size) + var(--ag-grid-size) * 1.5);
}
.ag-theme-quartz .ag-rtl .ag-column-select-add-group-indent, .ag-theme-quartz-dark .ag-rtl .ag-column-select-add-group-indent, .ag-theme-quartz-auto-dark .ag-rtl .ag-column-select-add-group-indent {
  margin-right: calc(var(--ag-icon-size) + var(--ag-grid-size) * 1.5);
}
.ag-theme-quartz .ag-text-field-input[disabled], .ag-theme-quartz .ag-menu-option-disabled, .ag-theme-quartz-dark .ag-text-field-input[disabled], .ag-theme-quartz-dark .ag-menu-option-disabled, .ag-theme-quartz-auto-dark .ag-text-field-input[disabled], .ag-theme-quartz-auto-dark .ag-menu-option-disabled {
  cursor: not-allowed;
}
.ag-theme-quartz .ag-checkbox-input-wrapper.ag-checked.ag-disabled, .ag-theme-quartz-dark .ag-checkbox-input-wrapper.ag-checked.ag-disabled, .ag-theme-quartz-auto-dark .ag-checkbox-input-wrapper.ag-checked.ag-disabled {
  --ag-checkbox-checked-color: var(--ag-checkbox-unchecked-color);
}
.ag-theme-quartz .ag-checkbox-input, .ag-theme-quartz .ag-toggle-button-input, .ag-theme-quartz .ag-radio-button-input, .ag-theme-quartz input[class^=ag-][type=range], .ag-theme-quartz-dark .ag-checkbox-input, .ag-theme-quartz-dark .ag-toggle-button-input, .ag-theme-quartz-dark .ag-radio-button-input, .ag-theme-quartz-dark input[class^=ag-][type=range], .ag-theme-quartz-auto-dark .ag-checkbox-input, .ag-theme-quartz-auto-dark .ag-toggle-button-input, .ag-theme-quartz-auto-dark .ag-radio-button-input, .ag-theme-quartz-auto-dark input[class^=ag-][type=range] {
  cursor: pointer;
}
.ag-theme-quartz .ag-details-row, .ag-theme-quartz-dark .ag-details-row, .ag-theme-quartz-auto-dark .ag-details-row {
  padding: calc(var(--ag-grid-size) * 3.75);
}
.ag-theme-quartz .ag-list-item-hovered::after, .ag-theme-quartz-dark .ag-list-item-hovered::after, .ag-theme-quartz-auto-dark .ag-list-item-hovered::after {
  background-color: var(--ag-active-color);
}
.ag-theme-quartz .ag-pill .ag-pill-button:hover, .ag-theme-quartz-dark .ag-pill .ag-pill-button:hover, .ag-theme-quartz-auto-dark .ag-pill .ag-pill-button:hover {
  color: var(--ag-active-color);
}
.ag-theme-quartz-dark .ag-column-select-header-filter-wrapper .ag-input-wrapper::before, .ag-theme-quartz-dark .ag-filter-toolpanel-search .ag-input-wrapper::before, .ag-theme-quartz-dark .ag-mini-filter .ag-input-wrapper::before, .ag-theme-quartz-dark .ag-filter-filter .ag-input-wrapper::before {
  opacity: 66%;
  filter: invert(100%);
}
.ag-theme-quartz-dark .ag-chart-menu {
  background-color: rgba(24, 39, 50, 0.3);
  @supports (color: color-mix(in lab, red, red)) {
    background-color: color-mix(in srgb, rgba(24, 39, 50, 0.3), var(--ag-background-color) 30%);
  }
}
.ag-theme-quartz-dark .ag-text-field-input::placeholder {
  color: var(--ag-data-color);
  opacity: 0.8;
}
.leaflet-pane, .leaflet-tile, .leaflet-marker-icon, .leaflet-marker-shadow, .leaflet-tile-container, .leaflet-pane > svg, .leaflet-pane > canvas, .leaflet-zoom-box, .leaflet-image-layer, .leaflet-layer {
  position: absolute;
  left: 0;
  top: 0;
}
.leaflet-container {
  overflow: hidden;
}
.leaflet-tile, .leaflet-marker-icon, .leaflet-marker-shadow {
  -webkit-user-select: none;
  -moz-user-select: none;
  user-select: none;
  -webkit-user-drag: none;
}
.leaflet-tile::selection {
  background: transparent;
}
.leaflet-safari .leaflet-tile {
  image-rendering: -webkit-optimize-contrast;
}
.leaflet-safari .leaflet-tile-container {
  width: 1600px;
  height: 1600px;
  -webkit-transform-origin: 0 0;
}
.leaflet-marker-icon, .leaflet-marker-shadow {
  display: block;
}
.leaflet-container .leaflet-overlay-pane svg {
  max-width: none !important;
  max-height: none !important;
}
.leaflet-container .leaflet-marker-pane img, .leaflet-container .leaflet-shadow-pane img, .leaflet-container .leaflet-tile-pane img, .leaflet-container img.leaflet-image-layer, .leaflet-container .leaflet-tile {
  max-width: none !important;
  max-height: none !important;
  width: auto;
  padding: 0;
}
.leaflet-container img.leaflet-tile {
  mix-blend-mode: plus-lighter;
}
.leaflet-container.leaflet-touch-zoom {
  -ms-touch-action: pan-x pan-y;
  touch-action: pan-x pan-y;
}
.leaflet-container.leaflet-touch-drag {
  -ms-touch-action: pinch-zoom;
  touch-action: none;
  touch-action: pinch-zoom;
}
.leaflet-container.leaflet-touch-drag.leaflet-touch-zoom {
  -ms-touch-action: none;
  touch-action: none;
}
.leaflet-container {
  -webkit-tap-highlight-color: transparent;
}
.leaflet-container a {
  -webkit-tap-highlight-color: rgba(51, 181, 229, 0.4);
}
.leaflet-tile {
  filter: inherit;
  visibility: hidden;
}
.leaflet-tile-loaded {
  visibility: inherit;
}
.leaflet-zoom-box {
  width: 0;
  height: 0;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
  z-index: 800;
}
.leaflet-overlay-pane svg {
  -moz-user-select: none;
}
.leaflet-pane {
  z-index: 400;
}
.leaflet-tile-pane {
  z-index: 200;
}
.leaflet-overlay-pane {
  z-index: 400;
}
.leaflet-shadow-pane {
  z-index: 500;
}
.leaflet-marker-pane {
  z-index: 600;
}
.leaflet-tooltip-pane {
  z-index: 650;
}
.leaflet-popup-pane {
  z-index: 700;
}
.leaflet-map-pane canvas {
  z-index: 100;
}
.leaflet-map-pane svg {
  z-index: 200;
}
.leaflet-vml-shape {
  width: 1px;
  height: 1px;
}
.lvml {
  behavior: url(#default#VML);
  display: inline-block;
  position: absolute;
}
.leaflet-control {
  position: relative;
  z-index: 800;
  pointer-events: visiblePainted;
  pointer-events: auto;
}
.leaflet-top, .leaflet-bottom {
  position: absolute;
  z-index: 1000;
  pointer-events: none;
}
.leaflet-top {
  top: 0;
}
.leaflet-right {
  right: 0;
}
.leaflet-bottom {
  bottom: 0;
}
.leaflet-left {
  left: 0;
}
.leaflet-control {
  float: left;
  clear: both;
}
.leaflet-right .leaflet-control {
  float: right;
}
.leaflet-top .leaflet-control {
  margin-top: 10px;
}
.leaflet-bottom .leaflet-control {
  margin-bottom: 10px;
}
.leaflet-left .leaflet-control {
  margin-left: 10px;
}
.leaflet-right .leaflet-control {
  margin-right: 10px;
}
.leaflet-fade-anim .leaflet-popup {
  opacity: 0;
  -webkit-transition: opacity 0.2s linear;
  -moz-transition: opacity 0.2s linear;
  transition: opacity 0.2s linear;
}
.leaflet-fade-anim .leaflet-map-pane .leaflet-popup {
  opacity: 1;
}
.leaflet-zoom-animated {
  -webkit-transform-origin: 0 0;
  -ms-transform-origin: 0 0;
  transform-origin: 0 0;
}
svg.leaflet-zoom-animated {
  will-change: transform;
}
.leaflet-zoom-anim .leaflet-zoom-animated {
  -webkit-transition: -webkit-transform 0.25s cubic-bezier(0,0,0.25,1);
  -moz-transition: -moz-transform 0.25s cubic-bezier(0,0,0.25,1);
  transition: transform 0.25s cubic-bezier(0,0,0.25,1);
}
.leaflet-zoom-anim .leaflet-tile, .leaflet-pan-anim .leaflet-tile {
  -webkit-transition: none;
  -moz-transition: none;
  transition: none;
}
.leaflet-zoom-anim .leaflet-zoom-hide {
  visibility: hidden;
}
.leaflet-interactive {
  cursor: pointer;
}
.leaflet-grab {
  cursor: -webkit-grab;
  cursor: -moz-grab;
  cursor: grab;
}
.leaflet-crosshair, .leaflet-crosshair .leaflet-interactive {
  cursor: crosshair;
}
.leaflet-popup-pane, .leaflet-control {
  cursor: auto;
}
.leaflet-dragging .leaflet-grab, .leaflet-dragging .leaflet-grab .leaflet-interactive, .leaflet-dragging .leaflet-marker-draggable {
  cursor: move;
  cursor: -webkit-grabbing;
  cursor: -moz-grabbing;
  cursor: grabbing;
}
.leaflet-marker-icon, .leaflet-marker-shadow, .leaflet-image-layer, .leaflet-pane > svg path, .leaflet-tile-container {
  pointer-events: none;
}
.leaflet-marker-icon.leaflet-interactive, .leaflet-image-layer.leaflet-interactive, .leaflet-pane > svg path.leaflet-interactive, svg.leaflet-image-layer.leaflet-interactive path {
  pointer-events: visiblePainted;
  pointer-events: auto;
}
.leaflet-container {
  background: #ddd;
  outline-offset: 1px;
}
.leaflet-container a {
  color: #0078A8;
}
.leaflet-zoom-box {
  border: 2px dotted #38f;
  background: rgba(255,255,255,0.5);
}
.leaflet-container {
  font-family: "Helvetica Neue", Arial, Helvetica, sans-serif;
  font-size: 12px;
  font-size: 0.75rem;
  line-height: 1.5;
}
.leaflet-bar {
  box-shadow: 0 1px 5px rgba(0,0,0,0.65);
  border-radius: 4px;
}
.leaflet-bar a {
  background-color: #fff;
  border-bottom: 1px solid #ccc;
  width: 26px;
  height: 26px;
  line-height: 26px;
  display: block;
  text-align: center;
  text-decoration: none;
  color: black;
}
.leaflet-bar a, .leaflet-control-layers-toggle {
  background-position: 50% 50%;
  background-repeat: no-repeat;
  display: block;
}
.leaflet-bar a:hover, .leaflet-bar a:focus {
  background-color: #f4f4f4;
}
.leaflet-bar a:first-child {
  border-top-left-radius: 4px;
  border-top-right-radius: 4px;
}
.leaflet-bar a:last-child {
  border-bottom-left-radius: 4px;
  border-bottom-right-radius: 4px;
  border-bottom: none;
}
.leaflet-bar a.leaflet-disabled {
  cursor: default;
  background-color: #f4f4f4;
  color: #bbb;
}
.leaflet-touch .leaflet-bar a {
  width: 30px;
  height: 30px;
  line-height: 30px;
}
.leaflet-touch .leaflet-bar a:first-child {
  border-top-left-radius: 2px;
  border-top-right-radius: 2px;
}
.leaflet-touch .leaflet-bar a:last-child {
  border-bottom-left-radius: 2px;
  border-bottom-right-radius: 2px;
}
.leaflet-control-zoom-in, .leaflet-control-zoom-out {
  font: bold 18px 'Lucida Console', Monaco, monospace;
  text-indent: 1px;
}
.leaflet-touch .leaflet-control-zoom-in, .leaflet-touch .leaflet-control-zoom-out {
  font-size: 22px;
}
.leaflet-control-layers {
  box-shadow: 0 1px 5px rgba(0,0,0,0.4);
  background: #fff;
  border-radius: 5px;
}
.leaflet-control-layers-toggle {
  background-image: url("images/layers.png");
  width: 36px;
  height: 36px;
}
.leaflet-retina .leaflet-control-layers-toggle {
  background-image: url("images/layers-2x.png");
  background-size: 26px 26px;
}
.leaflet-touch .leaflet-control-layers-toggle {
  width: 44px;
  height: 44px;
}
.leaflet-control-layers .leaflet-control-layers-list, .leaflet-control-layers-expanded .leaflet-control-layers-toggle {
  display: none;
}
.leaflet-control-layers-expanded .leaflet-control-layers-list {
  display: block;
  position: relative;
}
.leaflet-control-layers-expanded {
  padding: 6px 10px 6px 6px;
  color: #333;
  background: #fff;
}
.leaflet-control-layers-scrollbar {
  overflow-y: scroll;
  overflow-x: hidden;
  padding-right: 5px;
}
.leaflet-control-layers-selector {
  margin-top: 2px;
  position: relative;
  top: 1px;
}
.leaflet-control-layers label {
  display: block;
  font-size: 13px;
  font-size: 1.08333em;
}
.leaflet-control-layers-separator {
  height: 0;
  border-top: 1px solid #ddd;
  margin: 5px -10px 5px -6px;
}
.leaflet-default-icon-path {
  background-image: url("images/marker-icon.png");
}
.leaflet-container .leaflet-control-attribution {
  background: #fff;
  background: rgba(255, 255, 255, 0.8);
  margin: 0;
}
.leaflet-control-attribution, .leaflet-control-scale-line {
  padding: 0 5px;
  color: #333;
  line-height: 1.4;
}
.leaflet-control-attribution a {
  text-decoration: none;
}
.leaflet-control-attribution a:hover, .leaflet-control-attribution a:focus {
  text-decoration: underline;
}
.leaflet-attribution-flag {
  display: inline !important;
  vertical-align: baseline !important;
  width: 1em;
  height: 0.6669em;
}
.leaflet-left .leaflet-control-scale {
  margin-left: 5px;
}
.leaflet-bottom .leaflet-control-scale {
  margin-bottom: 5px;
}
.leaflet-control-scale-line {
  border: 2px solid #777;
  border-top: none;
  line-height: 1.1;
  padding: 2px 5px 1px;
  white-space: nowrap;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
  background: rgba(255, 255, 255, 0.8);
  text-shadow: 1px 1px #fff;
}
.leaflet-control-scale-line:not(:first-child) {
  border-top: 2px solid #777;
  border-bottom: none;
  margin-top: -2px;
}
.leaflet-control-scale-line:not(:first-child):not(:last-child) {
  border-bottom: 2px solid #777;
}
.leaflet-touch .leaflet-control-attribution, .leaflet-touch .leaflet-control-layers, .leaflet-touch .leaflet-bar {
  box-shadow: none;
}
.leaflet-touch .leaflet-control-layers, .leaflet-touch .leaflet-bar {
  border: 2px solid rgba(0,0,0,0.2);
  background-clip: padding-box;
}
.leaflet-popup {
  position: absolute;
  text-align: center;
  margin-bottom: 20px;
}
.leaflet-popup-content-wrapper {
  padding: 1px;
  text-align: left;
  border-radius: 12px;
}
.leaflet-popup-content {
  margin: 13px 24px 13px 20px;
  line-height: 1.3;
  font-size: 13px;
  font-size: 1.08333em;
  min-height: 1px;
}
.leaflet-popup-content p {
  margin: 17px 0;
  margin: 1.3em 0;
}
.leaflet-popup-tip-container {
  width: 40px;
  height: 20px;
  position: absolute;
  left: 50%;
  margin-top: -1px;
  margin-left: -20px;
  overflow: hidden;
  pointer-events: none;
}
.leaflet-popup-tip {
  width: 17px;
  height: 17px;
  padding: 1px;
  margin: -10px auto 0;
  pointer-events: auto;
  -webkit-transform: rotate(45deg);
  -moz-transform: rotate(45deg);
  -ms-transform: rotate(45deg);
  transform: rotate(45deg);
}
.leaflet-popup-content-wrapper, .leaflet-popup-tip {
  background: white;
  color: #333;
  box-shadow: 0 3px 14px rgba(0,0,0,0.4);
}
.leaflet-container a.leaflet-popup-close-button {
  position: absolute;
  top: 0;
  right: 0;
  border: none;
  text-align: center;
  width: 24px;
  height: 24px;
  font: 16px/24px Tahoma, Verdana, sans-serif;
  color: #757575;
  text-decoration: none;
  background: transparent;
}
.leaflet-container a.leaflet-popup-close-button:hover, .leaflet-container a.leaflet-popup-close-button:focus {
  color: #585858;
}
.leaflet-popup-scrolled {
  overflow: auto;
}
.leaflet-oldie .leaflet-popup-content-wrapper {
  -ms-zoom: 1;
}
.leaflet-oldie .leaflet-popup-tip {
  width: 24px;
  margin: 0 auto;
  -ms-filter: "progid:DXImageTransform.Microsoft.Matrix(M11=0.70710678, M12=0.70710678, M21=-0.70710678, M22=0.70710678)";
  filter: progid:DXImageTransform.Microsoft.Matrix(M11=0.70710678, M12=0.70710678, M21=-0.70710678, M22=0.70710678);
}
.leaflet-oldie .leaflet-control-zoom, .leaflet-oldie .leaflet-control-layers, .leaflet-oldie .leaflet-popup-content-wrapper, .leaflet-oldie .leaflet-popup-tip {
  border: 1px solid #999;
}
.leaflet-div-icon {
  background: #fff;
  border: 1px solid #666;
}
.leaflet-tooltip {
  position: absolute;
  padding: 6px;
  background-color: #fff;
  border: 1px solid #fff;
  border-radius: 3px;
  color: #222;
  white-space: nowrap;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
  pointer-events: none;
  box-shadow: 0 1px 3px rgba(0,0,0,0.4);
}
.leaflet-tooltip.leaflet-interactive {
  cursor: pointer;
  pointer-events: auto;
}
.leaflet-tooltip-top:before, .leaflet-tooltip-bottom:before, .leaflet-tooltip-left:before, .leaflet-tooltip-right:before {
  position: absolute;
  pointer-events: none;
  border: 6px solid transparent;
  background: transparent;
  content: "";
}
.leaflet-tooltip-bottom {
  margin-top: 6px;
}
.leaflet-tooltip-top {
  margin-top: -6px;
}
.leaflet-tooltip-bottom:before, .leaflet-tooltip-top:before {
  left: 50%;
  margin-left: -6px;
}
.leaflet-tooltip-top:before {
  bottom: 0;
  margin-bottom: -12px;
  border-top-color: #fff;
}
.leaflet-tooltip-bottom:before {
  top: 0;
  margin-top: -12px;
  margin-left: -6px;
  border-bottom-color: #fff;
}
.leaflet-tooltip-left {
  margin-left: -6px;
}
.leaflet-tooltip-right {
  margin-left: 6px;
}
.leaflet-tooltip-left:before, .leaflet-tooltip-right:before {
  top: 50%;
  margin-top: -6px;
}
.leaflet-tooltip-left:before {
  right: 0;
  margin-right: -12px;
  border-left-color: #fff;
}
.leaflet-tooltip-right:before {
  left: 0;
  margin-left: -12px;
  border-right-color: #fff;
}
@media print {
  .leaflet-control {
    -webkit-print-color-adjust: exact;
    print-color-adjust: exact;
  }
}
.leaflet-cluster-anim .leaflet-marker-icon, .leaflet-cluster-anim .leaflet-marker-shadow {
  -webkit-transition: -webkit-transform 0.3s ease-out, opacity 0.3s ease-in;
  -moz-transition: -moz-transform 0.3s ease-out, opacity 0.3s ease-in;
  -o-transition: -o-transform 0.3s ease-out, opacity 0.3s ease-in;
  transition: transform 0.3s ease-out, opacity 0.3s ease-in;
}
.leaflet-cluster-spider-leg {
  -webkit-transition: -webkit-stroke-dashoffset 0.3s ease-out, -webkit-stroke-opacity 0.3s ease-in;
  -moz-transition: -moz-stroke-dashoffset 0.3s ease-out, -moz-stroke-opacity 0.3s ease-in;
  -o-transition: -o-stroke-dashoffset 0.3s ease-out, -o-stroke-opacity 0.3s ease-in;
  transition: stroke-dashoffset 0.3s ease-out, stroke-opacity 0.3s ease-in;
}
.marker-cluster-small {
  background-color: rgba(181, 226, 140, 0.6);
}
.marker-cluster-small div {
  background-color: rgba(110, 204, 57, 0.6);
}
.marker-cluster-medium {
  background-color: rgba(241, 211, 87, 0.6);
}
.marker-cluster-medium div {
  background-color: rgba(240, 194, 12, 0.6);
}
.marker-cluster-large {
  background-color: rgba(253, 156, 115, 0.6);
}
.marker-cluster-large div {
  background-color: rgba(241, 128, 23, 0.6);
}
.leaflet-oldie .marker-cluster-small {
  background-color: rgb(181, 226, 140);
}
.leaflet-oldie .marker-cluster-small div {
  background-color: rgb(110, 204, 57);
}
.leaflet-oldie .marker-cluster-medium {
  background-color: rgb(241, 211, 87);
}
.leaflet-oldie .marker-cluster-medium div {
  background-color: rgb(240, 194, 12);
}
.leaflet-oldie .marker-cluster-large {
  background-color: rgb(253, 156, 115);
}
.leaflet-oldie .marker-cluster-large div {
  background-color: rgb(241, 128, 23);
}
.marker-cluster {
  background-clip: padding-box;
  border-radius: 20px;
}
.marker-cluster div {
  width: 30px;
  height: 30px;
  margin-left: 5px;
  margin-top: 5px;
  text-align: center;
  border-radius: 15px;
  font: 12px "Helvetica Neue", Arial, Helvetica, sans-serif;
}
.marker-cluster span {
  line-height: 30px;
}
@font-face {
  font-family: "Poppins";
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url("/fonts/poppins-latin-700-normal.woff2") format("woff2"), url("/fonts/poppins-latin-700-normal.woff") format("woff");
}
@font-face {
  font-family: "Poppins";
  font-style: normal;
  font-weight: 800;
  font-display: swap;
  src: url("/fonts/poppins-latin-800-normal.woff2") format("woff2"), url("/fonts/poppins-latin-800-normal.woff") format("woff");
}
@media (prefers-reduced-motion: no-preference) {
  html {
    scroll-behavior: smooth;
  }
}
:root {
  --pt-sidebar-width: 256px;
  --pt-sidebar-width-collapsed: 60px;
  --pt-platform-header-height: 44px;
  --pt-sidebar-bg: var(--color-surface-inverse);
  --pt-sidebar-text: oklch(80% 0 0);
  --pt-sidebar-text-muted: oklch(55% 0 0);
  --pt-sidebar-active-bg: oklch(100% 0 0 / 8%);
  --pt-sidebar-active-text: oklch(100% 0 0);
  --pt-sidebar-hover-bg: oklch(100% 0 0 / 5%);
  --pt-panel-bg: var(--color-surface-3);
}
.pt-app {
  display: flex;
  min-height: 100vh;
}
.pt-public-app {
  flex-direction: column;
  background: var(--color-surface);
}
.no-transition, .no-transition *, .no-transition ~ .pt-main-wrap {
  transition: none !important;
}
.pt-sidebar {
  position: fixed;
  top: 0;
  left: 0;
  bottom: 0;
  width: var(--pt-sidebar-width);
  background: var(--pt-sidebar-bg);
  color: var(--pt-sidebar-text);
  display: flex;
  flex-direction: column;
  transition: width 200ms ease;
  z-index: 40;
  overflow: hidden;
}
.pt-sidebar--collapsed {
  width: var(--pt-sidebar-width-collapsed);
}
.pt-sidebar__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0.875rem 0.875rem 0.625rem;
  flex-shrink: 0;
}
.pt-sidebar__logo {
  flex-shrink: 0;
  overflow: hidden;
  a {
    display: flex;
    align-items: center;
    text-decoration: none;
  }
}
.pt-sidebar__logo-img--full {
  height: 1.9rem;
  width: auto;
  display: block;
  .pt-sidebar--collapsed & {
    display: none;
  }
}
.pt-sidebar__logo-img--mark {
  height: 1.5rem;
  width: 1.5rem;
  object-fit: cover;
  object-position: left center;
  display: none;
  .pt-sidebar--collapsed & {
    display: block;
  }
}
.pt-sidebar__search {
  padding: 0.625rem 0.75rem 0.875rem;
  flex-shrink: 0;
}
.pt-sidebar__footer {
  flex-shrink: 0;
  padding: 0.375rem 0.625rem;
  border-top: 1px solid oklch(100% 0 0 / 8%);
}
.pt-sidebar__footer .pt-user-menu__trigger {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  width: 100%;
  padding: 0.375rem;
  border-radius: 0.375rem;
  background: none;
  border: none;
  cursor: pointer;
  color: var(--pt-sidebar-text);
  transition: background 120ms;
  &:hover {
    background: var(--pt-sidebar-hover-bg);
  }
}
.pt-user-menu__trigger-name {
  display: none;
}
.pt-sidebar__footer .pt-user-menu__trigger-name {
  display: block;
  flex: 1;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  text-align: left;
  font-size: 0.8125rem;
  color: var(--pt-sidebar-text);
}
.pt-sidebar--collapsed .pt-user-menu__trigger-name {
  display: none;
}
.pt-sidebar__nav {
  flex: 1;
  overflow-y: auto;
  overflow-x: hidden;
  padding: 0.25rem 0;
  display: flex;
  flex-direction: column;
}
.pt-sidebar__nav > * {
  flex-shrink: 0;
}
.pt-sidebar__nav > .pt-nav-section:last-child {
  margin-top: auto;
}
.pt-sidebar__nav > li {
  margin-bottom: 0.5rem;
}
.pt-nav-section {
  margin-bottom: 0.625rem;
}
.pt-nav-section__label {
  display: block;
  padding: 0.375rem 1rem 0.25rem;
  font-size: 0.6875rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: oklch(70% 0 0);
  white-space: nowrap;
  overflow: hidden;
  .pt-sidebar--collapsed & {
    opacity: 0;
  }
}
.pt-nav-section__list {
  list-style: none;
  margin: 0;
  padding: 0;
}
.pt-nav-link {
  display: flex;
  align-items: center;
  gap: 0.625rem;
  padding: 0.375rem 0.75rem;
  padding-right: 1.75rem;
  font-size: 0.8125rem;
  color: var(--pt-sidebar-text);
  text-decoration: none;
  border-radius: 0.375rem;
  margin: 0 0.375rem;
  white-space: nowrap;
  transition: background 120ms, color 120ms;
  position: relative;
  &:hover {
    background: var(--pt-sidebar-hover-bg);
    color: var(--color-surface);
  }
  &.active, &[aria-current="page"] {
    background: var(--pt-sidebar-active-bg);
    color: var(--pt-sidebar-active-text);
    font-weight: 500;
    &::before {
      content: "";
      position: absolute;
      left: 0;
      top: 0.25rem;
      bottom: 0.25rem;
      width: 3px;
      border-radius: 0 2px 2px 0;
      background: oklch(62% 0.17 250);
    }
  }
  .pt-nav-link__icon {
    flex-shrink: 0;
    width: 1.125rem;
    height: 1.125rem;
  }
}
.pt-nav-link__label {
  white-space: nowrap;
  overflow: hidden;
  .pt-sidebar--collapsed & {
    opacity: 0;
    width: 0;
  }
}
.pt-sidebar--collapsed .pt-nav-link {
  justify-content: center;
  gap: 0;
  padding: 0.5rem 0;
  margin: 0.125rem auto;
  width: calc(100% - 0.75rem);
  overflow: visible;
}
.pt-sidebar--collapsed .pt-sidebar__header {
  justify-content: center;
  padding-left: 0;
  padding-right: 0;
}
.pt-sidebar--collapsed .pt-nav-link::after {
  content: attr(aria-label);
  position: absolute;
  left: calc(100% + 0.75rem);
  top: 50%;
  transform: translateY(-50%);
  background: oklch(15% 0.01 250);
  color: var(--color-surface);
  padding: 0.375rem 0.75rem;
  border-radius: 0.375rem;
  font-size: 0.8125rem;
  font-weight: 500;
  white-space: nowrap;
  z-index: 100;
  pointer-events: none;
  box-shadow: 0 2px 8px oklch(0% 0 0 / 30%);
  visibility: hidden;
  opacity: 0;
}
.pt-sidebar--collapsed .pt-nav-link:hover::after, .pt-sidebar--collapsed .pt-nav-link:focus-visible::after {
  visibility: visible;
  opacity: 1;
}
.pt-nav-link-wrap {
  position: relative;
}
.pt-nav-link--alert {
  background: oklch(56% 0.14 250 / 16%);
  box-shadow: inset 0 0 0 1px oklch(56% 0.14 250 / 45%);
  color: var(--pt-sidebar-active-text);
  font-weight: 500;
}
.pt-nav-link--alert:hover {
  background: oklch(56% 0.14 250 / 24%);
  color: var(--pt-sidebar-active-text);
}
.pt-nav-link__count {
  position: absolute;
  top: 50%;
  right: 0.75rem;
  transform: translateY(-50%);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 1.125rem;
  height: 1.125rem;
  padding: 0 0.3125rem;
  border-radius: 9999px;
  background: oklch(65% 0.22 35);
  color: var(--pt-sidebar-active-text);
  font-size: 0.6875rem;
  font-weight: 700;
  line-height: 1.125rem;
  pointer-events: none;
  box-shadow: 0 0 0 2px var(--pt-sidebar-bg);
}
.pt-sidebar--collapsed .pt-nav-link__count {
  top: 0.25rem;
  right: 0.5rem;
  transform: none;
  min-width: 0.875rem;
  height: 0.875rem;
  padding: 0 0.1875rem;
  font-size: 0.5625rem;
  line-height: 0.875rem;
}
.pt-sidebar__bottom {
  flex-shrink: 0;
  padding: 0.75rem;
  border-top: 1px solid oklch(100% 0 0 / 8%);
  display: flex;
  align-items: center;
  gap: 0.5rem;
}
.pt-sidebar__icon-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 2rem;
  height: 2rem;
  border-radius: 0.375rem;
  color: var(--pt-sidebar-text);
  text-decoration: none;
  transition: background 120ms, color 120ms;
  &:hover {
    background: var(--pt-sidebar-hover-bg);
    color: var(--color-surface);
  }
  .pt-icon {
    width: 1rem;
    height: 1rem;
  }
}
.pt-sidebar__toggle {
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 1.75rem;
  height: 1.75rem;
  border: none;
  border-radius: 0.375rem;
  background: none;
  color: var(--pt-sidebar-text-muted);
  cursor: pointer;
  transition: background 120ms, color 120ms;
  &:hover {
    background: var(--pt-sidebar-hover-bg);
    color: var(--color-surface);
  }
  .pt-icon {
    width: 1rem;
    height: 1rem;
  }
}
.pt-sidebar--collapsed .pt-sidebar__header {
  position: relative;
}
.pt-sidebar--collapsed .pt-sidebar__logo {
  transition: opacity 120ms;
}
.pt-sidebar--collapsed .pt-sidebar__toggle {
  position: absolute;
  inset: 0;
  margin: auto;
  opacity: 0;
  pointer-events: none;
  transition: opacity 120ms;
}
.pt-sidebar--collapsed .pt-sidebar__header:hover .pt-sidebar__logo {
  opacity: 0;
}
.pt-sidebar--collapsed .pt-sidebar__header:hover .pt-sidebar__toggle, .pt-sidebar--collapsed .pt-sidebar__toggle:focus-visible {
  opacity: 1;
  pointer-events: auto;
}
.pt-sidebar__toggle .pt-sidebar__icon--collapsed {
  display: none;
}
.pt-sidebar--collapsed .pt-sidebar__toggle .pt-sidebar__icon--expanded {
  display: none;
}
.pt-sidebar--collapsed .pt-sidebar__toggle .pt-sidebar__icon--collapsed {
  display: inline-block;
}
.pt-main-wrap {
  margin-left: var(--pt-sidebar-width);
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: row;
  min-height: 100vh;
  transition: margin-left 200ms ease;
  .pt-sidebar--collapsed~& {
    margin-left: var(--pt-sidebar-width-collapsed);
  }
}
.pt-main-column {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
}
.pt-platform-topbar {
  position: sticky;
  top: 0;
  z-index: 30;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  min-height: var(--pt-platform-header-height);
  padding: 0.375rem 1.5rem;
  background: oklch(18% 0.02 250);
  border-bottom: 1px solid var(--color-border);
}
.pt-platform-topbar__search {
  flex: 1;
  min-width: 0;
  max-width: 42rem;
}
.pt-platform-topbar__search-form {
  width: 100%;
}
.pt-platform-topbar__actions {
  display: inline-flex;
  align-items: center;
  gap: 0.625rem;
  flex-shrink: 0;
}
.pt-platform-topbar__tasks {
  display: inline-flex;
  align-items: center;
  gap: 0.375rem;
  height: 2rem;
  padding: 0 0.625rem;
  border: 1px solid oklch(100% 0 0 / 22%);
  border-radius: 0.375rem;
  color: var(--color-surface);
  text-decoration: none;
  font-size: 0.8125rem;
  font-weight: 600;
}
.pt-platform-topbar__tasks:hover, .pt-platform-topbar__tasks:focus-visible {
  background: oklch(100% 0 0 / 10%);
}
.pt-platform-topbar__tasks-icon {
  width: 0.95rem;
  height: 0.95rem;
}
.pt-platform-topbar .pt-notif-btn {
  color: var(--color-surface);
  border-color: oklch(100% 0 0 / 22%);
}
.pt-platform-topbar .pt-user-menu__trigger {
  border: 1px solid oklch(100% 0 0 / 22%);
  border-radius: 9999px;
  background: oklch(100% 0 0 / 8%);
}
.pt-quick-search {
  position: relative;
}
.pt-quick-search__icon {
  position: absolute;
  left: 0.625rem;
  top: 50%;
  transform: translateY(-50%);
  width: 0.95rem;
  height: 0.95rem;
  color: var(--pt-sidebar-text-muted);
  pointer-events: none;
}
.pt-quick-search__input {
  width: 100%;
  height: 2.25rem;
  padding: 0 2.25rem 0 2.1rem;
  border-radius: 0.5rem;
  border: 1px solid oklch(100% 0 0 / 12%);
  background: oklch(100% 0 0 / 6%);
  color: var(--pt-sidebar-active-text);
  font-size: 0.8125rem;
  transition: background 120ms, border-color 120ms;
}
.pt-quick-search__input::placeholder {
  color: var(--pt-sidebar-text-muted);
}
.pt-quick-search__input:hover {
  background: oklch(100% 0 0 / 9%);
}
.pt-quick-search__input:focus-visible {
  outline: none;
  background: oklch(100% 0 0 / 10%);
  border-color: oklch(62% 0.17 250 / 80%);
  box-shadow: 0 0 0 2px oklch(62% 0.17 250 / 45%);
}
.pt-quick-search__hint {
  position: absolute;
  right: 0.5rem;
  top: 50%;
  transform: translateY(-50%);
  display: inline-flex;
  align-items: center;
  padding: 1px 5px;
  font-family: inherit;
  font-size: 0.6875rem;
  line-height: 1.4;
  color: var(--pt-sidebar-text-muted);
  background: transparent;
  border: 1px solid oklch(100% 0 0 / 18%);
  border-radius: 4px;
  pointer-events: none;
}
.pt-quick-search__clear:not([hidden]) ~ .pt-quick-search__hint, .pt-sidebar--collapsed .pt-quick-search__hint {
  display: none;
}
.pt-sidebar--collapsed .pt-sidebar__search {
  padding: 0.25rem 0.375rem 0.5rem;
}
.pt-sidebar--collapsed .pt-quick-search__input {
  padding: 0;
  color: transparent;
  cursor: pointer;
}
.pt-sidebar--collapsed .pt-quick-search__input::placeholder {
  color: transparent;
}
.pt-sidebar--collapsed .pt-quick-search__icon {
  left: 50%;
  transform: translate(-50%, -50%);
}
.pt-main {
  flex: 1;
  min-width: 0;
  padding: 1.5rem;
  overflow-y: visible;
  background: var(--pt-panel-bg);
  display: flex;
  flex-direction: column;
}
.pt-main--flush {
  padding: 0;
}
.pt-public-main {
  flex: 1;
  min-width: 0;
}
.pt-public-main--auth {
  padding: 0;
  background: var(--color-surface);
}
.pt-badge {
  display: inline-flex;
  align-items: center;
  border-radius: 9999px;
  font-weight: 500;
  line-height: 1;
}
.pt-badge--sm {
  padding: 0.2em 0.5em;
  font-size: 0.7rem;
}
.pt-badge--md {
  padding: 0.3em 0.65em;
  font-size: 0.75rem;
}
.pt-badge--lg {
  padding: 0.35em 0.8em;
  font-size: 0.8125rem;
}
.pt-badge--default {
  background: oklch(92% 0 0);
  color: oklch(30% 0 0);
}
.pt-badge--primary {
  background: var(--color-brand);
  color: var(--color-surface);
}
.pt-badge--success {
  background: oklch(88% 0.1 145);
  color: oklch(25% 0.1 145);
}
.pt-badge--warning {
  background: oklch(92% 0.12 85);
  color: oklch(30% 0.12 85);
}
.pt-badge--danger {
  background: oklch(90% 0.1 25);
  color: oklch(30% 0.12 25);
}
.pt-badge--info {
  background: oklch(88% 0.1 250);
  color: oklch(25% 0.12 250);
}
.pt-avatar {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 9999px;
  background: oklch(88% 0.08 250);
  overflow: hidden;
  flex-shrink: 0;
  img {
    width: 100%;
    height: 100%;
    object-fit: cover;
  }
}
.pt-avatar--sm {
  width: 2rem;
  height: 2rem;
}
.pt-avatar--md {
  width: 2.5rem;
  height: 2.5rem;
}
.pt-avatar--lg {
  width: 3.5rem;
  height: 3.5rem;
}
.pt-avatar__initials {
  font-size: 0.75em;
  font-weight: 600;
  color: var(--color-brand);
  letter-spacing: 0.02em;
}
.pt-avatar-group {
  display: inline-flex;
  align-items: center;
  & > * {
    margin-right: -0.5rem;
    border: 2px solid var(--color-surface);
    box-sizing: content-box;
    position: relative;
    &:last-child {
      margin-right: 0;
    }
  }
  & > *:nth-child(1) {
    z-index: 5;
  }
  & > *:nth-child(2) {
    z-index: 4;
  }
  & > *:nth-child(3) {
    z-index: 3;
  }
  & > *:nth-child(4) {
    z-index: 2;
  }
  & > *:nth-child(5) {
    z-index: 1;
  }
}
.pt-avatar-group__overflow {
  background: oklch(92% 0.04 250);
  cursor: default;
}
.pt-avatar__overflow-label {
  font-size: 0.75em;
  font-weight: 600;
  color: oklch(35% 0.1 250);
  letter-spacing: -0.02em;
}
.pt-image {
  display: block;
  max-width: 100%;
  height: auto;
}
.pt-image__placeholder {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  aspect-ratio: 1 / 1;
  background: var(--pt-color-surface-muted, #f3f4f6);
  color: var(--pt-color-text-muted, #9ca3af);
}
.pt-image__placeholder-icon {
  width: 2.5rem;
  height: 2.5rem;
}
.pt-notif-btn {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 2rem;
  height: 2rem;
  border-radius: 0.375rem;
  color: var(--pt-sidebar-text);
  text-decoration: none;
  transition: background 120ms;
  &:hover {
    background: var(--pt-sidebar-hover-bg);
    color: var(--color-surface);
  }
  i {
    font-size: 1rem;
  }
}
.pt-notif-btn__count {
  position: absolute;
  top: -0.25rem;
  right: -0.25rem;
  min-width: 1rem;
  height: 1rem;
  padding: 0 0.25rem;
  border-radius: 9999px;
  font-size: 0.625rem;
  font-weight: 700;
  line-height: 1rem;
  text-align: center;
  background: oklch(65% 0.22 35);
  color: var(--color-surface);
}
.pt-empty-state {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 1rem;
  padding: 4rem 2rem;
  text-align: center;
  color: oklch(50% 0 0);
}
.pt-empty-state__icon {
  font-size: 3rem;
  opacity: 0.35;
}
.pt-empty-state__heading {
  font-size: 1.25rem;
  font-weight: 600;
  color: oklch(20% 0 0);
  margin: 0;
}
.pt-empty-state__body {
  font-size: 0.9375rem;
  max-width: 36ch;
  margin: 0;
}
.pt-empty-state__action {
  margin-top: 0.5rem;
}
.pt-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  border: none;
  border-radius: var(--radius-sm);
  font-size: 0.875rem;
  font-weight: 500;
  text-decoration: none;
  cursor: pointer;
  transition: background 120ms ease, color 120ms ease, opacity 120ms ease;
  white-space: nowrap;
  position: relative;
}
.pt-btn--sm {
  padding: 0.3125rem 0.75rem;
  font-size: 0.8125rem;
}
.pt-btn--md {
  padding: 0.5rem 1.25rem;
  font-size: 0.875rem;
}
.pt-btn--lg {
  padding: 0.6875rem 1.75rem;
  font-size: 1rem;
}
.pt-btn--primary {
  background: var(--color-success);
  color: var(--color-surface);
  &:hover {
    background: var(--color-success-hover);
    color: var(--color-surface);
  }
  &:active {
    background: var(--color-success-hover);
    filter: brightness(0.92);
  }
}
.pt-btn--secondary {
  background: oklch(94% 0 0);
  color: oklch(20% 0 0);
  &:hover {
    background: oklch(88% 0 0);
  }
  &:active {
    background: oklch(82% 0 0);
  }
}
.pt-btn--danger {
  background: oklch(55% 0.22 25);
  color: var(--color-surface);
  &:hover {
    background: oklch(48% 0.22 25);
    color: var(--color-surface);
  }
  &:active {
    background: oklch(40% 0.22 25);
  }
}
.pt-btn--warning {
  background: oklch(78% 0.18 72);
  color: oklch(25% 0.08 72);
  &:hover {
    background: oklch(72% 0.18 72);
  }
  &:active {
    background: oklch(66% 0.18 72);
  }
}
.pt-btn--ghost {
  background: transparent;
  color: oklch(45% 0.18 255);
  &:hover {
    background: oklch(95% 0.04 255);
  }
  &:active {
    background: oklch(90% 0.06 255);
  }
}
.pt-btn--disabled, .pt-btn[disabled] {
  opacity: 0.45;
  cursor: not-allowed;
}
.pt-btn--disabled:not([disabled]) {
  pointer-events: none;
}
.pt-btn--loading {
  cursor: wait;
  .pt-btn__label {
    opacity: 0;
  }
  .pt-btn__spinner {
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
  }
}
.pt-chip-filter {
  display: inline-flex;
  align-items: center;
  gap: 0.375rem;
  padding: 0.25rem 0.75rem;
  border: 1px solid var(--color-border);
  border-radius: 9999px;
  background: var(--color-surface);
  font-size: var(--text-sm);
  font-weight: 500;
  color: var(--color-text-secondary);
  text-decoration: none;
  transition: background 120ms ease, border-color 120ms ease, color 120ms ease;
}
.pt-chip-filter:hover {
  border-color: var(--color-border-strong);
  background: var(--color-surface-2);
}
.pt-chip-filter--active {
  border-color: var(--color-brand);
  background: var(--color-brand);
  color: var(--color-on-brand);
}
.pt-chip-filter--active:hover {
  border-color: var(--color-brand-hover);
  background: var(--color-brand-hover);
}
.pt-chip-filter__count {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 1.25rem;
  padding: 0 0.375rem;
  border-radius: 9999px;
  background: var(--color-surface-3);
  font-size: var(--text-xs);
  color: var(--color-text-secondary);
}
.pt-chip-filter--active .pt-chip-filter__count {
  background: rgba(255, 255, 255, 0.25);
  color: var(--color-on-brand);
}
.pt-divider {
  display: block;
  border: none;
  border-top: 1px solid oklch(90% 0 0);
  margin: 0;
}
.pt-divider--labeled {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  color: oklch(60% 0 0);
  font-size: 0.8125rem;
  font-weight: 400;
  border-top: none;
}
.pt-divider__line {
  flex: 1;
  height: 1px;
  background: oklch(90% 0 0);
}
.pt-divider__label {
  flex-shrink: 0;
  white-space: nowrap;
}
.pt-divider--vertical {
  display: inline-block;
  width: 1px;
  height: 1em;
  background: oklch(85% 0 0);
  vertical-align: middle;
  margin: 0 0.25rem;
  border-top: none;
}
.pt-input {
  display: block;
  width: 100%;
  font-family: var(--font-sans);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  background: var(--color-surface);
  color: var(--color-text);
  outline: none;
  transition: border-color 150ms ease, box-shadow 150ms ease;
}
.pt-input::placeholder {
  color: var(--color-muted);
}
.pt-input:focus {
  border-color: var(--color-brand);
  box-shadow: 0 0 0 3px oklch(45% 0.18 250 / 12%);
}
.pt-input:disabled {
  opacity: 0.5;
  cursor: not-allowed;
  background: var(--color-surface-alt);
}
.pt-input[readonly] {
  background: var(--color-surface-alt);
}
.pt-input--sm {
  padding: 0.375rem 0.625rem;
  font-size: 0.8125rem;
  line-height: 1.25rem;
}
.pt-input--md {
  padding: 0.5rem 0.75rem;
  font-size: 0.875rem;
  line-height: 1.375rem;
}
.pt-input--lg {
  padding: 0.625rem 1rem;
  font-size: 1rem;
  line-height: 1.5rem;
}
.pt-input--error {
  border-color: var(--color-danger);
}
.pt-input--error:focus {
  border-color: var(--color-danger);
  box-shadow: 0 0 0 3px oklch(55% 0.22 25 / 12%);
}
.pt-textarea {
  display: block;
  width: 100%;
  font-family: var(--font-sans);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  background: var(--color-surface);
  color: var(--color-text);
  outline: none;
  resize: vertical;
  transition: border-color 150ms ease, box-shadow 150ms ease;
}
.pt-textarea::placeholder {
  color: var(--color-muted);
}
.pt-textarea:focus {
  border-color: var(--color-brand);
  box-shadow: 0 0 0 3px oklch(45% 0.18 250 / 12%);
}
.pt-textarea:disabled {
  opacity: 0.5;
  cursor: not-allowed;
  background: var(--color-surface-alt);
}
.pt-textarea--sm {
  padding: 0.375rem 0.625rem;
  font-size: 0.8125rem;
}
.pt-textarea--md {
  padding: 0.5rem 0.75rem;
  font-size: 0.875rem;
}
.pt-textarea--lg {
  padding: 0.625rem 1rem;
  font-size: 1rem;
}
.pt-textarea--error {
  border-color: var(--color-danger);
}
.pt-textarea--error:focus {
  border-color: var(--color-danger);
  box-shadow: 0 0 0 3px oklch(55% 0.22 25 / 12%);
}
.pt-label {
  display: inline-flex;
  align-items: baseline;
  gap: 0.25rem;
  font-family: var(--font-sans);
  font-size: 0.875rem;
  font-weight: 500;
  color: var(--color-text);
  line-height: 1.375rem;
}
.pt-label--error {
  color: var(--color-danger);
}
.pt-label__required {
  color: var(--color-danger);
  font-weight: 600;
}
.pt-label__hint {
  font-weight: 400;
  font-size: 0.8125rem;
  color: var(--color-muted);
}
.pt-checkbox {
  display: inline-flex;
  align-items: flex-start;
  gap: 0.5rem;
  cursor: pointer;
  font-family: var(--font-sans);
  font-size: 0.875rem;
  color: var(--color-text);
  line-height: 1.375rem;
  position: relative;
}
.pt-checkbox__input {
  position: absolute;
  opacity: 0;
  width: 0;
  height: 0;
}
.pt-checkbox__indicator {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1.125rem;
  height: 1.125rem;
  flex-shrink: 0;
  margin-top: 0.125rem;
  border: 1.5px solid var(--color-border);
  border-radius: var(--radius-sm);
  background: var(--color-surface);
  transition: background 150ms ease, border-color 150ms ease;
}
.pt-checkbox__input:checked + .pt-checkbox__indicator {
  background: var(--color-brand);
  border-color: var(--color-brand);
}
.pt-checkbox__input:checked + .pt-checkbox__indicator::after {
  content: "";
  display: block;
  width: 0.375rem;
  height: 0.625rem;
  border: solid white;
  border-width: 0 2px 2px 0;
  transform: rotate(45deg) translate(-1px, -1px);
}
.pt-checkbox__input:focus-visible + .pt-checkbox__indicator {
  box-shadow: 0 0 0 3px oklch(45% 0.18 250 / 12%);
}
.pt-checkbox__label {
  user-select: none;
}
.pt-checkbox__input:checked ~ .pt-checkbox__label {
  color: var(--color-brand);
  text-shadow: 0.4px 0 0 currentColor;
}
.pt-checkbox__hint {
  display: block;
  font-size: 0.8125rem;
  color: var(--color-muted);
  margin-top: 0.125rem;
}
.pt-checkbox--disabled {
  opacity: 0.5;
  cursor: not-allowed;
}
.pt-checkbox--error .pt-checkbox__indicator {
  border-color: var(--color-danger);
}
.pt-radio {
  display: inline-flex;
  align-items: flex-start;
  gap: 0.5rem;
  cursor: pointer;
  font-family: var(--font-sans);
  font-size: 0.875rem;
  color: var(--color-text);
  line-height: 1.375rem;
  position: relative;
}
.pt-radio__input {
  position: absolute;
  opacity: 0;
  width: 0;
  height: 0;
}
.pt-radio__indicator {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1.125rem;
  height: 1.125rem;
  flex-shrink: 0;
  margin-top: 0.125rem;
  border: 1.5px solid var(--color-border);
  border-radius: var(--radius-full);
  background: var(--color-surface);
  transition: background 150ms ease, border-color 150ms ease;
}
.pt-radio__input:checked + .pt-radio__indicator {
  border-color: var(--color-brand);
}
.pt-radio__input:checked + .pt-radio__indicator::after {
  content: "";
  display: block;
  width: 0.5rem;
  height: 0.5rem;
  border-radius: var(--radius-full);
  background: var(--color-brand);
}
.pt-radio__input:focus-visible + .pt-radio__indicator {
  box-shadow: 0 0 0 3px oklch(45% 0.18 250 / 12%);
}
.pt-radio__label {
  user-select: none;
}
.pt-radio__hint {
  display: block;
  font-size: 0.8125rem;
  color: var(--color-muted);
  margin-top: 0.125rem;
}
.pt-radio--disabled {
  opacity: 0.5;
  cursor: not-allowed;
}
.pt-radio--error .pt-radio__indicator {
  border-color: var(--color-danger);
}
.pt-toggle {
  display: inline-flex;
  align-items: center;
  gap: 0.625rem;
  cursor: pointer;
  font-family: var(--font-sans);
  font-size: 0.875rem;
  color: var(--color-text);
  line-height: 1.375rem;
  position: relative;
}
.pt-toggle__input {
  position: absolute;
  opacity: 0;
  width: 0;
  height: 0;
}
.pt-toggle__track {
  position: relative;
  display: inline-block;
  width: 2.5rem;
  height: 1.375rem;
  flex-shrink: 0;
  border-radius: var(--radius-full);
  background: oklch(80% 0 0);
  transition: background 200ms ease;
}
.pt-toggle__input:checked ~ .pt-toggle__track {
  background: var(--color-brand);
}
.pt-toggle__thumb {
  position: absolute;
  top: 0.125rem;
  left: 0.125rem;
  width: 1.125rem;
  height: 1.125rem;
  border-radius: var(--radius-full);
  background: white;
  box-shadow: 0 1px 3px oklch(0% 0 0 / 15%);
  transition: left 200ms ease;
}
.pt-toggle__input:checked ~ .pt-toggle__track .pt-toggle__thumb {
  left: 1.25rem;
}
.pt-toggle__input:focus-visible ~ .pt-toggle__track {
  box-shadow: 0 0 0 3px oklch(45% 0.18 250 / 12%);
}
.pt-toggle__label {
  user-select: none;
}
.pt-toggle__hint {
  display: block;
  font-size: 0.8125rem;
  color: var(--color-muted);
}
.pt-toggle--disabled {
  opacity: 0.5;
  cursor: not-allowed;
}
.pt-icon {
  display: inline-block;
  width: 1em;
  height: 1em;
  vertical-align: -0.15em;
  flex-shrink: 0;
}
.pt-icon--inline {
  vertical-align: -0.2em;
}
.pt-icon-missing {
  display: inline-block;
  width: 1em;
  height: 1em;
  color: var(--color-danger);
  font-size: 0.75em;
  font-weight: 700;
}
.pt-filter-section__lock-icon {
  width: 0.85rem;
  height: 0.85rem;
  flex-shrink: 0;
  color: oklch(60% 0 0);
  vertical-align: middle;
}
.pt-link {
  display: inline-flex;
  align-items: center;
  gap: 0.3125rem;
  color: oklch(45% 0.18 255);
  text-decoration: underline;
  text-decoration-color: transparent;
  text-underline-offset: 0.2em;
  transition: color 120ms ease, text-decoration-color 120ms ease;
  cursor: pointer;
  &:hover {
    color: oklch(38% 0.2 255);
    text-decoration-color: currentColor;
  }
  &:focus-visible {
    outline: 2px solid oklch(55% 0.2 255);
    outline-offset: 2px;
    border-radius: 2px;
    text-decoration: none;
  }
}
.pt-link--underline {
  text-decoration-color: currentColor;
}
.pt-link--quiet {
  color: oklch(45% 0 0);
  text-decoration: none;
  &:hover {
    color: oklch(20% 0 0);
    text-decoration-color: currentColor;
    text-decoration: underline;
  }
}
.pt-link--danger {
  color: oklch(52% 0.22 25);
  &:hover {
    color: oklch(42% 0.22 25);
    text-decoration-color: currentColor;
  }
}
.pt-link__icon {
  flex-shrink: 0;
  display: inline-flex;
  align-items: center;
}
.pt-link__icon--left {
  order: -1;
}
.pt-link__icon--right {
  order: 1;
}
.pt-save-status {
  display: inline-flex;
  align-items: center;
  gap: 0.375rem;
  font-size: var(--text-xs);
  color: var(--color-text-muted);
  min-height: 1.25rem;
}
.pt-save-status[data-state="saving"] {
  color: var(--color-warning-hover);
}
.pt-save-status[data-state="saved"] {
  color: var(--color-success);
}
.pt-save-status[data-state="error"] {
  color: var(--color-danger);
}
.pt-tag {
  display: inline-flex;
  align-items: center;
  gap: 0.25rem;
  padding: 0.1875rem 0.5rem;
  border-radius: 9999px;
  font-size: 0.75rem;
  font-weight: 500;
  line-height: 1.4;
  white-space: nowrap;
  cursor: default;
  text-decoration: none;
  transition: background 120ms ease, color 120ms ease;
}
a.pt-tag:hover {
  text-decoration: none;
  filter: brightness(0.92);
}
.pt-tag--default {
  background: oklch(93% 0 0);
  color: oklch(30% 0 0);
}
.pt-tag--primary {
  background: oklch(92% 0.06 255);
  color: oklch(40% 0.18 255);
}
.pt-tag--success {
  background: oklch(92% 0.07 155);
  color: oklch(38% 0.14 155);
}
.pt-tag--warning {
  background: oklch(94% 0.09 75);
  color: oklch(42% 0.14 60);
}
.pt-tag--danger {
  background: oklch(94% 0.06 20);
  color: oklch(45% 0.18 25);
}
.pt-tag--info {
  background: oklch(92% 0.06 255);
  color: oklch(40% 0.18 255);
}
.pt-tag__label {
  flex: 1;
}
.pt-tag__remove {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1rem;
  height: 1rem;
  border: none;
  background: transparent;
  color: inherit;
  opacity: 0.6;
  cursor: pointer;
  padding: 0;
  border-radius: 9999px;
  transition: opacity 120ms ease, background 120ms ease;
  flex-shrink: 0;
  &:hover {
    opacity: 1;
    background: rgba(0, 0, 0, 0.1);
  }
  & .pt-icon {
    width: 0.75rem;
    height: 0.75rem;
  }
}
.pt-tooltip {
  position: relative;
  display: inline-flex;
  align-items: center;
}
.pt-tooltip__text {
  position: absolute;
  z-index: 100;
  background: oklch(15% 0 0);
  color: var(--color-surface);
  font-size: 0.75rem;
  line-height: 1.4;
  padding: 0.3125rem 0.5rem;
  border-radius: 0.3125rem;
  white-space: nowrap;
  max-width: 18rem;
  pointer-events: none;
  opacity: 0;
  transition: opacity 150ms ease;
}
.pt-tooltip__text:not([hidden]) {
  opacity: 1;
}
.pt-tooltip__text[hidden] {
  display: block !important;
  opacity: 0;
}
.pt-tooltip__text::after {
  content: "";
  position: absolute;
  border: 5px solid transparent;
}
.pt-tooltip--top .pt-tooltip__text {
  bottom: calc(100% + 8px);
  left: 50%;
  transform: translateX(-50%);
}
.pt-tooltip--top .pt-tooltip__text::after {
  top: 100%;
  left: 50%;
  transform: translateX(-50%);
  border-top-color: oklch(15% 0 0);
}
.pt-tooltip--bottom .pt-tooltip__text {
  top: calc(100% + 8px);
  left: 50%;
  transform: translateX(-50%);
}
.pt-tooltip--bottom .pt-tooltip__text::after {
  bottom: 100%;
  left: 50%;
  transform: translateX(-50%);
  border-bottom-color: oklch(15% 0 0);
}
.pt-tooltip--left .pt-tooltip__text {
  right: calc(100% + 8px);
  top: 50%;
  transform: translateY(-50%);
}
.pt-tooltip--left .pt-tooltip__text::after {
  left: 100%;
  top: 50%;
  transform: translateY(-50%);
  border-left-color: oklch(15% 0 0);
}
.pt-tooltip--right .pt-tooltip__text {
  left: calc(100% + 8px);
  top: 50%;
  transform: translateY(-50%);
}
.pt-tooltip--right .pt-tooltip__text::after {
  right: 100%;
  top: 50%;
  transform: translateY(-50%);
  border-right-color: oklch(15% 0 0);
}
.pt-action-card__form {
  margin: 0;
  display: flex;
}
.pt-action-card {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: flex-start;
  gap: 0.625rem;
  width: 100%;
  min-height: 11.5rem;
  padding: 2rem 1.5rem;
  border: 1px solid var(--color-surface-3);
  border-radius: var(--radius-md, 0.5rem);
  background: var(--color-surface-2);
  color: var(--color-text-primary);
  text-align: center;
  cursor: pointer;
  transition: border-color 120ms ease, box-shadow 120ms ease, background-color 120ms ease;
  font: inherit;
  appearance: none;
  -webkit-appearance: none;
}
.pt-action-card:hover, .pt-action-card:focus-visible {
  border-color: var(--color-brand);
  background: var(--color-surface);
  box-shadow: 0 2px 10px rgb(15 23 42 / 8%);
  outline: none;
}
.pt-action-card__icon-wrap {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--color-text-secondary);
}
.pt-action-card__icon {
  width: 2.75rem;
  height: 2.75rem;
}
.pt-action-card__title {
  color: var(--color-text-primary);
  font-size: 1rem;
  font-weight: 700;
  line-height: 1.3;
}
.pt-action-card__description {
  max-width: 18rem;
  color: var(--color-text-secondary);
  font-size: 0.8125rem;
  font-weight: 500;
  line-height: 1.4;
}
.pt-alert {
  display: flex;
  align-items: flex-start;
  gap: 0.75rem;
  padding: 0.875rem 1rem;
  border-radius: 0.5rem;
  border-left: 4px solid transparent;
  font-size: 0.875rem;
  margin-bottom: 1rem;
  transition: opacity 300ms ease, transform 300ms ease;
}
.pt-alert__icon {
  flex-shrink: 0;
  margin-top: 0.125rem;
}
.pt-alert__content {
  flex: 1;
  min-width: 0;
}
.pt-alert__title {
  font-weight: 600;
  margin: 0 0 0.25rem;
}
.pt-alert__message {
  margin: 0;
}
.pt-alert__dismiss {
  flex-shrink: 0;
  background: none;
  border: none;
  cursor: pointer;
  color: inherit;
  opacity: 0.6;
  padding: 0.125rem;
  &:hover {
    opacity: 1;
  }
}
.pt-alert--notice {
  background: oklch(96% 0.05 150);
  border-color: oklch(60% 0.18 150);
  color: oklch(30% 0.12 150);
}
.pt-alert--error {
  background: oklch(96% 0.05 25);
  border-color: oklch(55% 0.22 25);
  color: oklch(30% 0.15 25);
}
.pt-alert--warning {
  background: oklch(97% 0.06 80);
  border-color: oklch(70% 0.18 80);
  color: oklch(35% 0.12 80);
}
.pt-alert--info {
  background: oklch(96% 0.04 240);
  border-color: oklch(55% 0.18 255);
  color: oklch(30% 0.12 240);
}
.ts-control {
  border: 1px solid #d0d0d0;
  padding: 8px 8px;
  width: 100%;
  overflow: hidden;
  position: relative;
  z-index: 1;
  box-sizing: border-box;
  box-shadow: none;
  border-radius: 3px;
  display: flex;
  flex-wrap: wrap;
}
.ts-wrapper.multi.has-items .ts-control {
  padding: calc(8px - 2px - 0px) 8px calc(8px - 2px - 3px - 0px);
}
.full .ts-control {
  background-color: #fff;
}
.disabled .ts-control, .disabled .ts-control * {
  cursor: default !important;
}
.focus .ts-control {
  box-shadow: none;
}
.ts-control > * {
  vertical-align: baseline;
  display: inline-block;
}
.ts-wrapper.multi .ts-control > div {
  cursor: pointer;
  margin: 0 3px 3px 0;
  padding: 2px 6px;
  background: #f2f2f2;
  color: #303030;
  border: 0px solid #d0d0d0;
  overflow: auto;
}
.ts-wrapper.multi .ts-control > div.active {
  background: #e8e8e8;
  color: #303030;
  border: 0px solid #cacaca;
}
.ts-wrapper.multi.disabled .ts-control > div, .ts-wrapper.multi.disabled .ts-control > div.active {
  color: rgb(124.5, 124.5, 124.5);
  background: hsl(0, 0%, 124.9019607843%);
  border: 0px solid hsl(0, 0%, 111.568627451%);
}
.ts-control > input {
  flex: 1 1 auto;
  min-width: 7rem;
  display: inline-block !important;
  padding: 0 !important;
  min-height: 0 !important;
  max-height: none !important;
  max-width: 100% !important;
  margin: 0 !important;
  text-indent: 0 !important;
  border: 0 none !important;
  background: none !important;
  line-height: inherit !important;
  -webkit-user-select: auto !important;
  -moz-user-select: auto !important;
  -ms-user-select: auto !important;
  user-select: auto !important;
  box-shadow: none !important;
}
.ts-control > input::-ms-clear {
  display: none;
}
.ts-control > input:focus {
  outline: none !important;
}
.has-items .ts-control > input {
  margin: 0px 4px !important;
}
.ts-control.rtl {
  text-align: right;
}
.ts-control.rtl.single .ts-control:after {
  left: 15px;
  right: auto;
}
.ts-control.rtl .ts-control > input {
  margin: 0px 4px 0px -2px !important;
}
.disabled .ts-control {
  opacity: 0.5;
  background-color: #fafafa;
}
.input-hidden .ts-control > input {
  opacity: 0;
  position: absolute;
  left: -10000px;
}
.ts-dropdown {
  position: absolute;
  top: 100%;
  left: 0;
  width: 100%;
  z-index: 10;
  border: 1px solid #d0d0d0;
  background: #fff;
  margin: 0.25rem 0 0;
  border-top: 0 none;
  box-sizing: border-box;
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
  border-radius: 0 0 3px 3px;
}
.ts-dropdown [data-selectable] {
  cursor: pointer;
  overflow: hidden;
}
.ts-dropdown [data-selectable] .highlight {
  background: rgba(125, 168, 208, 0.2);
  border-radius: 1px;
}
.ts-dropdown .option, .ts-dropdown .optgroup-header, .ts-dropdown .no-results, .ts-dropdown .create {
  padding: 5px 8px;
}
.ts-dropdown .option, .ts-dropdown [data-disabled], .ts-dropdown [data-disabled] [data-selectable].option {
  cursor: inherit;
  opacity: 0.5;
}
.ts-dropdown [data-selectable].option {
  opacity: 1;
  cursor: pointer;
}
.ts-dropdown .optgroup:first-child .optgroup-header {
  border-top: 0 none;
}
.ts-dropdown .optgroup-header {
  color: #303030;
  background: #fff;
  cursor: default;
}
.ts-dropdown .active {
  background-color: #f5fafd;
  color: #495c68;
}
.ts-dropdown .active.create {
  color: #495c68;
}
.ts-dropdown .create {
  color: rgba(48, 48, 48, 0.5);
}
.ts-dropdown .spinner {
  display: inline-block;
  width: 30px;
  height: 30px;
  margin: 5px 8px;
}
.ts-dropdown .spinner::after {
  content: " ";
  display: block;
  width: 24px;
  height: 24px;
  margin: 3px;
  border-radius: 50%;
  border: 5px solid #d0d0d0;
  border-color: #d0d0d0 transparent #d0d0d0 transparent;
  animation: lds-dual-ring 1.2s linear infinite;
}
@keyframes lds-dual-ring {
  0% {
    transform: rotate(0deg);
  }
  100% {
    transform: rotate(360deg);
  }
}
.ts-dropdown-content {
  overflow: hidden auto;
  max-height: 200px;
  scroll-behavior: smooth;
}
.ts-wrapper.plugin-drag_drop .ts-dragging {
  color: transparent !important;
}
.ts-wrapper.plugin-drag_drop .ts-dragging > * {
  visibility: hidden !important;
}
.plugin-checkbox_options:not(.rtl) .option input {
  margin-right: 0.5rem;
}
.plugin-checkbox_options.rtl .option input {
  margin-left: 0.5rem;
}
.plugin-clear_button {
  --ts-pr-clear-button: 1em;
}
.plugin-clear_button .clear-button {
  opacity: 0;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  right: calc(8px - 6px);
  margin-right: 0 !important;
  background: transparent !important;
  transition: opacity 0.5s;
  cursor: pointer;
}
.plugin-clear_button.form-select .clear-button, .plugin-clear_button.single .clear-button {
  right: max(var(--ts-pr-caret), 8px);
}
.plugin-clear_button.focus.has-items .clear-button, .plugin-clear_button:not(.disabled):hover.has-items .clear-button {
  opacity: 1;
}
.ts-wrapper .dropdown-header {
  position: relative;
  padding: 10px 8px;
  border-bottom: 1px solid #d0d0d0;
  background: color-mix(#fff, #d0d0d0, 85%);
  border-radius: 3px 3px 0 0;
}
.ts-wrapper .dropdown-header-close {
  position: absolute;
  right: 8px;
  top: 50%;
  color: #303030;
  opacity: 0.4;
  margin-top: -12px;
  line-height: 20px;
  font-size: 20px !important;
}
.ts-wrapper .dropdown-header-close:hover {
  color: hsl(0, 0%, -6.1764705882%);
}
.plugin-dropdown_input.focus.dropdown-active .ts-control {
  box-shadow: none;
  border: 1px solid #d0d0d0;
}
.plugin-dropdown_input .dropdown-input {
  border: 1px solid #d0d0d0;
  border-width: 0 0 1px;
  display: block;
  padding: 8px 8px;
  box-shadow: none;
  width: 100%;
  background: transparent;
}
.plugin-dropdown_input .items-placeholder {
  border: 0 none !important;
  box-shadow: none !important;
  width: 100%;
}
.plugin-dropdown_input.has-items .items-placeholder, .plugin-dropdown_input.dropdown-active .items-placeholder {
  display: none !important;
}
.ts-wrapper.plugin-input_autogrow.has-items .ts-control > input {
  min-width: 0;
}
.ts-wrapper.plugin-input_autogrow.has-items.focus .ts-control > input {
  flex: none;
  min-width: 4px;
}
.ts-wrapper.plugin-input_autogrow.has-items.focus .ts-control > input::-ms-input-placeholder {
  color: transparent;
}
.ts-wrapper.plugin-input_autogrow.has-items.focus .ts-control > input::placeholder {
  color: transparent;
}
.ts-dropdown.plugin-optgroup_columns .ts-dropdown-content {
  display: flex;
}
.ts-dropdown.plugin-optgroup_columns .optgroup {
  border-right: 1px solid #f2f2f2;
  border-top: 0 none;
  flex-grow: 1;
  flex-basis: 0;
  min-width: 0;
}
.ts-dropdown.plugin-optgroup_columns .optgroup:last-child {
  border-right: 0 none;
}
.ts-dropdown.plugin-optgroup_columns .optgroup::before {
  display: none;
}
.ts-dropdown.plugin-optgroup_columns .optgroup-header {
  border-top: 0 none;
}
.ts-wrapper.plugin-remove_button .item {
  display: inline-flex;
  align-items: center;
}
.ts-wrapper.plugin-remove_button .item .remove {
  color: inherit;
  text-decoration: none;
  vertical-align: middle;
  display: inline-block;
  padding: 0 6px;
  border-radius: 0 2px 2px 0;
  box-sizing: border-box;
}
.ts-wrapper.plugin-remove_button .item .remove:hover {
  background: rgba(0, 0, 0, 0.05);
}
.ts-wrapper.plugin-remove_button.disabled .item .remove:hover {
  background: none;
}
.ts-wrapper.plugin-remove_button .remove-single {
  position: absolute;
  right: 0;
  top: 0;
  font-size: 23px;
}
.ts-wrapper.plugin-remove_button:not(.rtl) .item {
  padding-right: 0 !important;
}
.ts-wrapper.plugin-remove_button:not(.rtl) .item .remove {
  border-left: 1px solid #d0d0d0;
  margin-left: 6px;
}
.ts-wrapper.plugin-remove_button:not(.rtl) .item.active .remove {
  border-left-color: #cacaca;
}
.ts-wrapper.plugin-remove_button:not(.rtl).disabled .item .remove {
  border-left-color: hsl(0, 0%, 111.568627451%);
}
.ts-wrapper.plugin-remove_button.rtl .item {
  padding-left: 0 !important;
}
.ts-wrapper.plugin-remove_button.rtl .item .remove {
  border-right: 1px solid #d0d0d0;
  margin-right: 6px;
}
.ts-wrapper.plugin-remove_button.rtl .item.active .remove {
  border-right-color: #cacaca;
}
.ts-wrapper.plugin-remove_button.rtl.disabled .item .remove {
  border-right-color: hsl(0, 0%, 111.568627451%);
}
:root {
  --ts-pr-clear-button: 0px;
  --ts-pr-caret: 0px;
  --ts-pr-min: .75rem;
}
.ts-wrapper.single .ts-control, .ts-wrapper.single .ts-control input {
  cursor: pointer;
}
.ts-control:not(.rtl) {
  padding-right: max(var(--ts-pr-min), var(--ts-pr-clear-button) + var(--ts-pr-caret)) !important;
}
.ts-control.rtl {
  padding-left: max(var(--ts-pr-min), var(--ts-pr-clear-button) + var(--ts-pr-caret)) !important;
}
.ts-wrapper {
  position: relative;
}
.ts-dropdown, .ts-control, .ts-control input {
  color: #303030;
  font-family: inherit;
  font-size: 13px;
  line-height: 18px;
}
.ts-control, .ts-wrapper.single.input-active .ts-control {
  background: #fff;
  cursor: text;
}
.ts-hidden-accessible {
  border: 0 !important;
  clip: rect(0 0 0 0) !important;
  -webkit-clip-path: inset(50%) !important;
  clip-path: inset(50%) !important;
  overflow: hidden !important;
  padding: 0 !important;
  position: absolute !important;
  width: 1px !important;
  white-space: nowrap !important;
}
.pt-autocomplete {
  position: relative;
  width: 100%;
}
.pt-autocomplete > select, .pt-autocomplete > input {
  opacity: 0;
  height: 0;
  overflow: hidden;
  position: absolute;
}
.pt-autocomplete .ts-wrapper .ts-control {
  font-family: var(--font-sans);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  background: var(--color-surface);
  color: var(--color-text);
  box-shadow: none;
  transition: border-color 150ms ease, box-shadow 150ms ease;
}
.pt-autocomplete .ts-wrapper .ts-control > input::placeholder {
  color: var(--color-muted);
}
.pt-autocomplete .ts-wrapper.focus .ts-control {
  border-color: var(--color-brand);
  box-shadow: 0 0 0 3px oklch(45% 0.18 250 / 12%);
}
.pt-autocomplete--sm .ts-control {
  padding: 0.25rem 0.5rem;
  font-size: 0.8125rem;
  min-height: 1.875rem;
}
.pt-autocomplete--md .ts-control {
  padding: 0.375rem 0.625rem;
  font-size: 0.875rem;
  min-height: 2.25rem;
}
.pt-autocomplete--lg .ts-control {
  padding: 0.5rem 0.75rem;
  font-size: 1rem;
  min-height: 2.625rem;
}
.pt-autocomplete .ts-dropdown {
  font-family: var(--font-sans);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  border-top: none;
  border-top-left-radius: 0;
  border-top-right-radius: 0;
  background: var(--color-surface);
  box-shadow: 0 4px 12px oklch(0% 0 0 / 8%);
  z-index: 50;
}
.pt-autocomplete .ts-dropdown .option {
  font-size: 0.875rem;
  padding: 0.5rem 0.75rem;
  color: var(--color-text);
  cursor: pointer;
  transition: background 100ms ease;
}
.pt-autocomplete .ts-dropdown .option.active, .pt-autocomplete .ts-dropdown .option:hover {
  background: var(--color-surface-alt);
  color: var(--color-text);
}
.pt-autocomplete .ts-dropdown .option.selected {
  background: oklch(45% 0.18 250 / 8%);
  color: var(--color-brand);
  font-weight: 500;
}
.pt-autocomplete .ts-dropdown .no-results {
  font-size: 0.8125rem;
  color: var(--color-muted);
  padding: 0.75rem;
  text-align: center;
}
.pt-autocomplete .ts-control .item {
  display: inline-flex;
  align-items: center;
  gap: 0.25rem;
  padding: 0.125rem 0.5rem;
  font-size: 0.8125rem;
  font-weight: 500;
  background: oklch(45% 0.18 250 / 10%);
  color: var(--color-brand);
  border: 1px solid oklch(45% 0.18 250 / 20%);
  border-radius: var(--radius-sm);
  line-height: 1.375rem;
}
.pt-autocomplete .ts-control .item .remove {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1rem;
  height: 1rem;
  color: var(--color-brand);
  opacity: 0.6;
  cursor: pointer;
  font-size: 0.875rem;
  line-height: 1;
  border: none;
  background: none;
  padding: 0;
  margin: 0;
  flex-shrink: 0;
}
.pt-autocomplete .ts-control .item .remove:hover {
  opacity: 1;
}
.pt-autocomplete--single .ts-control {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.25rem;
}
.pt-autocomplete--single .ts-control .item {
  background: var(--color-brand-subtle);
  color: var(--color-brand);
  border: 1px solid transparent;
  border-radius: 0.25rem;
  padding: 0.125rem 0.375rem 0.125rem 0.5rem;
  font-size: var(--text-xs, 0.8125rem);
  font-weight: 500;
  line-height: 1.25rem;
}
.pt-autocomplete--single .ts-control .item .remove {
  color: inherit;
  border-radius: 0.25rem;
  transition: background 120ms ease;
}
.pt-autocomplete--single .ts-control .item .remove:hover {
  background: oklch(0% 0 0 / 8%);
  opacity: 1;
}
.pt-autocomplete--single .ts-wrapper.single .ts-control::after {
  content: "";
  flex-shrink: 0;
  margin-left: auto;
  width: 0.5rem;
  height: 0.5rem;
  border-right: 1.5px solid var(--color-text-secondary);
  border-bottom: 1.5px solid var(--color-text-secondary);
  transform: rotate(45deg) translateY(-2px);
  pointer-events: none;
}
.pt-autocomplete--single .ts-wrapper.single.dropdown-active .ts-control::after {
  transform: rotate(-135deg) translateY(-1px);
}
.pt-autocomplete--error .ts-control {
  border-color: var(--color-danger);
}
.pt-autocomplete--error .ts-wrapper.focus .ts-control {
  border-color: var(--color-danger);
  box-shadow: 0 0 0 3px oklch(55% 0.22 25 / 12%);
}
.pt-autocomplete--disabled .ts-control {
  opacity: 0.5;
  cursor: not-allowed;
  background: var(--color-surface-alt);
}
.pt-autocomplete .ts-wrapper.loading .ts-control::after {
  content: "";
  position: absolute;
  right: 0.625rem;
  top: 50%;
  width: 0.875rem;
  height: 0.875rem;
  margin-top: -0.4375rem;
  border: 2px solid var(--color-border);
  border-top-color: var(--color-brand);
  border-radius: 50%;
  animation: pt-autocomplete-spin 600ms linear infinite;
}
@keyframes pt-autocomplete-spin {
  to {
    transform: rotate(360deg);
  }
}
.pt-checkbox-dropdown {
  position: relative;
  display: inline-block;
}
.pt-checkbox-dropdown__trigger {
  display: inline-flex;
  align-items: center;
  gap: var(--spacing-sm, 0.5rem);
}
.pt-checkbox-dropdown__caret {
  flex: 0 0 auto;
}
.pt-dropdown__menu.pt-checkbox-dropdown__panel {
  min-width: 14rem;
  max-height: 18rem;
  overflow-y: auto;
  overscroll-behavior: contain;
  padding: var(--spacing-xs, 0.25rem);
}
.pt-checkbox-dropdown__list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: var(--spacing-2xs, 0.125rem);
}
.pt-checkbox-dropdown__item {
  padding: var(--spacing-xs, 0.25rem) var(--spacing-sm, 0.5rem);
  border-radius: var(--radius-sm, 0.25rem);
}
.pt-checkbox-dropdown__item:hover {
  background: var(--color-surface-2, oklch(97% 0.005 250));
}
.pt-checkbox-dropdown__item .pt-checkbox {
  width: 100%;
}
.pt-data-table {
  overflow-x: auto;
}
.pt-data-table__table {
  width: 100%;
  border-collapse: collapse;
  font-family: var(--font-sans);
  font-size: 0.875rem;
}
.pt-data-table__th {
  text-align: left;
  padding: 0.625rem 0.75rem;
  font-weight: 600;
  color: var(--color-text);
  border-bottom: 2px solid var(--color-border);
  white-space: nowrap;
}
.pt-data-table__td {
  padding: 0.625rem 0.75rem;
  color: var(--color-text);
  border-bottom: 1px solid var(--color-border);
}
.pt-data-table__table--striped .pt-data-table__row:nth-child(even) {
  background: var(--color-surface-alt);
}
.pt-data-table__table--hoverable .pt-data-table__row:hover {
  background: oklch(45% 0.18 250 / 4%);
}
.pt-data-table__empty {
  padding: 2rem;
  text-align: center;
  color: var(--color-muted);
  font-family: var(--font-sans);
  font-size: 0.875rem;
}
.pt-stat-card {
  display: flex;
  align-items: flex-start;
  gap: 0.75rem;
  padding: 1.25rem;
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  font-family: var(--font-sans);
}
.pt-stat-card__icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 2.5rem;
  height: 2.5rem;
  border-radius: var(--radius-md);
  background: oklch(45% 0.18 250 / 8%);
  color: var(--color-brand);
  flex-shrink: 0;
}
.pt-stat-card__body {
  flex: 1;
  min-width: 0;
}
.pt-stat-card__value {
  font-size: 1.5rem;
  font-weight: 700;
  color: var(--color-text);
  line-height: 1.2;
}
.pt-stat-card__label {
  font-size: 0.8125rem;
  color: var(--color-muted);
  margin-top: 0.125rem;
}
.pt-stat-card__trend {
  font-size: 0.8125rem;
  font-weight: 600;
  padding: 0.125rem 0.375rem;
  border-radius: var(--radius-sm);
  align-self: flex-start;
}
.pt-stat-card__trend--up {
  color: var(--color-success);
  background: oklch(55% 0.18 145 / 10%);
}
.pt-stat-card__trend--down {
  color: var(--color-danger);
  background: oklch(55% 0.22 25 / 10%);
}
.pt-stat-card__trend--flat {
  color: var(--color-muted);
  background: var(--color-surface-alt);
}
.pt-timeline {
  display: flex;
  flex-direction: column;
  gap: 0;
  position: relative;
  font-family: var(--font-sans);
}
.pt-timeline__entry {
  display: flex;
  gap: 0.75rem;
  padding-bottom: 1.25rem;
  position: relative;
}
.pt-timeline__entry:not(:last-child)::before {
  content: "";
  position: absolute;
  left: 0.375rem;
  top: 1.25rem;
  bottom: 0;
  width: 2px;
  background: var(--color-border);
}
.pt-timeline__marker {
  width: 0.75rem;
  height: 0.75rem;
  border-radius: var(--radius-full);
  background: var(--color-brand);
  flex-shrink: 0;
  margin-top: 0.25rem;
}
.pt-timeline__body {
  flex: 1;
  min-width: 0;
}
.pt-timeline__time {
  display: block;
  font-size: 0.75rem;
  color: var(--color-muted);
  margin-bottom: 0.125rem;
}
.pt-timeline__content {
  font-size: 0.875rem;
  color: var(--color-text);
  line-height: 1.5;
}
.pt-timeline--compact .pt-timeline__entry {
  padding-bottom: 0.75rem;
}
.pt-timeline--compact .pt-timeline__marker {
  width: 0.5rem;
  height: 0.5rem;
}
.pt-description-list {
  margin: 0;
  font-family: var(--font-sans);
}
.pt-description-list--stacked .pt-description-list__item {
  padding: 0.5rem 0;
  border-bottom: 1px solid var(--color-border);
}
.pt-description-list--stacked .pt-description-list__item:last-child {
  border-bottom: none;
}
.pt-description-list--horizontal .pt-description-list__item {
  display: flex;
  gap: 1rem;
  padding: 0.5rem 0;
  border-bottom: 1px solid var(--color-border);
}
.pt-description-list--horizontal .pt-description-list__item:last-child {
  border-bottom: none;
}
.pt-description-list__term {
  font-size: 0.8125rem;
  font-weight: 500;
  color: var(--color-muted);
  margin: 0;
}
.pt-description-list--horizontal .pt-description-list__term {
  flex-shrink: 0;
  min-width: 8rem;
}
.pt-description-list__detail {
  font-size: 0.875rem;
  color: var(--color-text);
  margin: 0.125rem 0 0;
}
.pt-description-list--horizontal .pt-description-list__detail {
  margin: 0;
  flex: 1;
}
.pt-date-picker {
  display: flex;
  flex-direction: column;
  gap: 0.375rem;
}
.pt-date-picker__label {
  font-family: var(--font-sans);
  font-size: 0.875rem;
  font-weight: 500;
  color: var(--color-text);
}
.pt-date-picker__required {
  color: var(--color-danger);
  margin-left: 0.125rem;
}
.pt-date-picker__control {
  position: relative;
  display: flex;
  align-items: center;
}
.pt-date-picker__icon {
  position: absolute;
  left: 0.625rem;
  color: var(--color-muted);
  pointer-events: none;
  display: flex;
  width: 1rem;
  height: 1rem;
  flex-shrink: 0;
  z-index: 1;
}
.pt-date-picker__placeholder {
  position: absolute;
  left: 2.25rem;
  top: 50%;
  transform: translateY(-50%);
  color: var(--color-muted);
  font-family: inherit;
  font-size: 0.875rem;
  pointer-events: none;
  z-index: 1;
  max-width: calc(100% - 3.5rem);
  overflow: hidden;
  white-space: nowrap;
  text-overflow: ellipsis;
}
.pt-date-picker--has-value .pt-date-picker__placeholder, .pt-date-picker__input:focus ~ .pt-date-picker__placeholder {
  display: none;
}
.pt-date-picker--with-placeholder:not(.pt-date-picker--has-value) .pt-date-picker__input:not(:focus)::-webkit-datetime-edit {
  color: transparent;
}
.pt-date-picker--sm .pt-date-picker__placeholder {
  left: 2rem;
}
.pt-filter-date-range .pt-date-picker__placeholder {
  left: 1.75rem;
}
.pt-date-picker__input {
  display: block;
  width: 100%;
  font-family: var(--font-sans);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  background: var(--color-surface);
  color: var(--color-text);
  outline: none;
  transition: border-color 150ms ease, box-shadow 150ms ease;
  position: relative;
}
.pt-date-picker__input::-webkit-calendar-picker-indicator {
  opacity: 0;
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  cursor: pointer;
}
.pt-date-picker__input:focus {
  border-color: var(--color-brand);
  box-shadow: 0 0 0 3px oklch(45% 0.18 250 / 12%);
}
.pt-date-picker__input:disabled {
  opacity: 0.5;
  cursor: not-allowed;
  background: var(--color-surface-alt);
}
.pt-date-picker:not(.pt-date-picker--has-value) .pt-date-picker__input:invalid {
  color: var(--color-muted);
}
.pt-date-picker--sm .pt-date-picker__input {
  padding: 0.375rem 2rem 0.375rem 2rem;
  font-size: 0.8125rem;
}
.pt-date-picker--md .pt-date-picker__input {
  padding: 0.5rem 2rem 0.5rem 2.25rem;
  font-size: 0.875rem;
}
.pt-date-picker--lg .pt-date-picker__input {
  padding: 0.625rem 2rem 0.625rem 2.25rem;
  font-size: 1rem;
}
.pt-date-picker--no-icon .pt-date-picker__input {
  padding-left: 0.75rem;
}
.pt-date-picker__clear {
  position: absolute;
  right: 0.5rem;
  background: none;
  border: none;
  color: var(--color-muted);
  cursor: pointer;
  padding: 0.25rem;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: var(--radius-sm);
  z-index: 1;
  transition: color 100ms ease, background 100ms ease;
}
.pt-date-picker__clear:hover {
  color: var(--color-text);
  background: var(--color-surface-alt);
}
.pt-date-picker__clear[hidden] {
  display: none;
}
.pt-date-picker__clear svg {
  width: 0.875rem;
  height: 0.875rem;
}
.pt-date-picker__presets {
  display: flex;
  flex-wrap: wrap;
  gap: 0.375rem;
  margin-top: 0.125rem;
}
.pt-date-picker__preset {
  font-family: var(--font-sans);
  font-size: 0.75rem;
  font-weight: 500;
  color: var(--color-brand);
  background: oklch(45% 0.18 250 / 6%);
  border: 1px solid oklch(45% 0.18 250 / 15%);
  border-radius: var(--radius-full);
  padding: 0.1875rem 0.625rem;
  cursor: pointer;
  transition: background 100ms ease, border-color 100ms ease;
  line-height: 1.25rem;
  white-space: nowrap;
}
.pt-date-picker__preset:hover {
  background: oklch(45% 0.18 250 / 12%);
  border-color: oklch(45% 0.18 250 / 25%);
}
.pt-date-picker__preset:active {
  background: oklch(45% 0.18 250 / 18%);
}
.pt-date-picker__hint {
  margin: 0;
  font-family: var(--font-sans);
  font-size: 0.8125rem;
  color: var(--color-muted);
  line-height: 1.25rem;
}
.pt-date-picker__error {
  margin: 0;
  font-family: var(--font-sans);
  font-size: 0.8125rem;
  color: var(--color-danger);
  line-height: 1.25rem;
  font-weight: 500;
}
.pt-date-picker--error .pt-date-picker__input {
  border-color: var(--color-danger);
}
.pt-date-picker--error .pt-date-picker__input:focus {
  border-color: var(--color-danger);
  box-shadow: 0 0 0 3px oklch(55% 0.22 25 / 12%);
}
.pt-date-picker--disabled .pt-date-picker__icon {
  opacity: 0.5;
}
.pt-date-picker--disabled .pt-date-picker__clear {
  display: none;
}
.pt-date-picker--disabled .pt-date-picker__preset {
  opacity: 0.5;
  cursor: not-allowed;
  pointer-events: none;
}
.pt-date-range {
  display: flex;
  align-items: flex-start;
  gap: 0.375rem;
  flex-direction: column;
}
.pt-date-range__subtitle {
  margin: 0;
  font-family: inherit;
  font-size: 0.8125rem;
  font-weight: 400;
  color: oklch(45% 0 0);
}
.pt-date-range__inputs {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  width: 100%;
}
.pt-date-range__inputs > .pt-date-picker {
  flex: 1;
  min-width: 0;
}
.pt-date-range__separator {
  display: flex;
  align-items: center;
  font-family: var(--font-sans);
  font-size: 0.875rem;
  color: var(--color-muted);
  flex-shrink: 0;
}
.pt-date-range:not(:has(.pt-date-range__subtitle)) .pt-date-range__separator {
  padding-top: 1.75rem;
}
.pt-filter-date-range + .pt-filter-date-range {
  margin-top: 0.875rem;
}
.pt-filter-date-range .pt-date-picker__input {
  font-size: 0.6875rem;
  padding-left: 1.75rem;
  padding-right: 1.75rem;
}
.pt-filter-date-range .pt-date-picker__icon {
  width: 0.875rem;
  height: 0.875rem;
  left: 0.5rem;
}
.pt-pagination-info {
  font-family: var(--font-sans);
  font-size: 0.8125rem;
  color: var(--color-muted);
}
.pt-pagination-info strong {
  font-weight: 600;
  color: var(--color-text);
}
.pt-action-bar {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  padding: 0.75rem 0;
  border-bottom: 1px solid var(--color-border);
}
.pt-action-bar--sticky {
  position: sticky;
  top: 0;
  z-index: 10;
  background: var(--color-surface);
}
.pt-action-bar__left {
  flex: 1;
  min-width: 0;
}
.pt-action-bar__center {
  flex-shrink: 0;
}
.pt-action-bar__right {
  flex-shrink: 0;
  display: flex;
  align-items: center;
  gap: 0.5rem;
}
.pt-card {
  display: block;
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  overflow: hidden;
  font-family: var(--font-sans);
}
.pt-card--elevated {
  box-shadow: 0 1px 3px oklch(0% 0 0 / 8%), 0 1px 2px oklch(0% 0 0 / 4%);
  transition: box-shadow 0.15s, transform 0.15s, border-color 0.15s;
}
.pt-card--clickable {
  cursor: pointer;
  text-decoration: none;
  color: inherit;
  &:hover {
    box-shadow: 0 4px 16px oklch(0% 0 0 / 10%), 0 2px 6px oklch(0% 0 0 / 6%);
    transform: translateY(-2px);
    border-color: oklch(70% 0.15 250);
  }
  &:active {
    transform: translateY(0);
    box-shadow: 0 1px 4px oklch(0% 0 0 / 8%);
  }
}
.pt-card__header {
  font-size: 0.9375rem;
  font-weight: 600;
  color: var(--color-text);
  border-bottom: 1px solid var(--color-border);
}
.pt-card__footer {
  border-top: 1px solid var(--color-border);
  display: flex;
  justify-content: flex-end;
  gap: 0.5rem;
}
.pt-card--padding-none .pt-card__body, .pt-card--padding-none .pt-card__header, .pt-card--padding-none .pt-card__footer {
  padding: 0;
}
.pt-card--padding-sm .pt-card__body, .pt-card--padding-sm .pt-card__header, .pt-card--padding-sm .pt-card__footer {
  padding: 0.625rem 0.75rem;
}
.pt-card--padding-md .pt-card__body, .pt-card--padding-md .pt-card__header, .pt-card--padding-md .pt-card__footer {
  padding: 1rem 1.25rem;
}
.pt-card--padding-lg .pt-card__body, .pt-card--padding-lg .pt-card__header, .pt-card--padding-lg .pt-card__footer {
  padding: 1.5rem 2rem;
}
.pt-empty-state {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: 3rem 1.5rem;
  gap: 0.75rem;
}
.pt-empty-state__icon {
  color: var(--color-muted);
  margin-bottom: 0.5rem;
  .pt-icon {
    width: 2.5rem;
    height: 2.5rem;
  }
}
.pt-empty-state__heading {
  font-family: var(--font-sans);
  font-size: 1.125rem;
  font-weight: 600;
  color: var(--color-text);
  margin: 0;
}
.pt-empty-state__body {
  font-family: var(--font-sans);
  font-size: 0.875rem;
  color: var(--color-muted);
  margin: 0;
  max-width: 25rem;
}
.pt-empty-state__action {
  margin-top: 0.5rem;
}
.pt-dropdown {
  position: relative;
  display: inline-block;
}
.pt-dropdown__trigger {
  cursor: pointer;
}
.pt-dropdown__menu {
  display: none;
  position: absolute;
  top: calc(100% + 0.375rem);
  right: 0;
  min-width: 11rem;
  background: var(--color-surface);
  border: 1px solid oklch(88% 0 0);
  border-radius: var(--radius-md);
  box-shadow: 0 8px 24px oklch(0% 0 0 / 12%);
  z-index: 200;
  overflow: hidden;
  &.pt-dropdown__menu--open {
    display: block;
  }
}
.pt-dropdown__item {
  display: block;
  width: 100%;
  padding: 0.5rem 0.875rem;
  font-size: 0.8125rem;
  text-align: left;
  color: var(--color-text-primary);
  background: transparent;
  border: 0;
  cursor: pointer;
}
.pt-dropdown__item:hover, .pt-dropdown__item:focus {
  background: var(--color-surface-2, oklch(96% 0 0));
}
.pt-evaluation-section {
  padding: var(--pt-space-4, 1rem) 0;
  border-top: 1px solid var(--pt-color-border, #e5e7eb);
}
.pt-evaluation-section:first-child {
  border-top: 0;
  padding-top: 0;
}
.pt-evaluation-section__header {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: var(--pt-space-2, 0.5rem);
  margin-bottom: var(--pt-space-3, 0.75rem);
}
.pt-evaluation-section__title {
  font-size: var(--pt-font-size-sm, 0.875rem);
  font-weight: 600;
  color: var(--pt-color-text, #111827);
  margin: 0;
}
.pt-evaluation-section__weight {
  font-size: var(--pt-font-size-xs, 0.75rem);
  color: var(--pt-color-text-muted, #6b7280);
  white-space: nowrap;
}
.pt-evaluation-section__empty {
  font-size: var(--pt-font-size-sm, 0.875rem);
  color: var(--pt-color-text-muted, #6b7280);
  margin: 0;
}
.pt-evaluation-section__items {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: var(--pt-space-2, 0.5rem);
}
.pt-evaluation-section__item {
  display: flex;
  flex-direction: column;
  gap: var(--pt-space-1, 0.25rem);
}
.pt-evaluation-section__item-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--pt-space-3, 0.75rem);
}
.pt-evaluation-section__item-title {
  font-size: var(--pt-font-size-sm, 0.875rem);
  color: var(--pt-color-text, #111827);
}
.pt-evaluation-section__score {
  font-size: var(--pt-font-size-sm, 0.875rem);
  font-weight: 600;
  color: var(--pt-color-text, #111827);
  font-variant-numeric: tabular-nums;
}
.pt-evaluation-section__score-input {
  flex: 0 0 auto;
  min-width: 5rem;
}
.pt-form-group {
  display: flex;
  flex-direction: column;
  gap: 0.375rem;
}
.pt-form-group--inline {
  flex-direction: row;
  align-items: flex-start;
  gap: 1rem;
}
.pt-form-group--inline > .pt-label {
  flex-shrink: 0;
  min-width: 8rem;
  padding-top: 0.5rem;
}
.pt-form-group__control {
  flex: 1;
}
.pt-form-group__hint {
  margin: 0;
  font-size: 0.8125rem;
  color: var(--color-muted);
  line-height: 1.25rem;
}
.pt-form-group__error {
  margin: 0;
  font-size: 0.8125rem;
  color: var(--color-danger);
  line-height: 1.25rem;
  font-weight: 500;
}
.pt-select {
  position: relative;
}
.pt-select::after {
  content: "";
  position: absolute;
  right: 0.75rem;
  top: 50%;
  transform: translateY(-50%);
  border-left: 4px solid transparent;
  border-right: 4px solid transparent;
  border-top: 5px solid var(--color-muted);
  pointer-events: none;
}
.pt-select__input {
  display: block;
  width: 100%;
  font-family: var(--font-sans);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  background: var(--color-surface);
  color: var(--color-text);
  outline: none;
  appearance: none;
  cursor: pointer;
  padding-right: 2rem;
  transition: border-color 150ms ease, box-shadow 150ms ease;
}
.pt-select__input:focus {
  border-color: var(--color-brand);
  box-shadow: 0 0 0 3px oklch(45% 0.18 250 / 12%);
}
.pt-select__input:disabled {
  opacity: 0.5;
  cursor: not-allowed;
  background: var(--color-surface-alt);
}
.pt-select__input--sm {
  padding: 0.375rem 2rem 0.375rem 0.625rem;
  font-size: 0.8125rem;
}
.pt-select__input--md {
  padding: 0.5rem 2rem 0.5rem 0.75rem;
  font-size: 0.875rem;
}
.pt-select__input--lg {
  padding: 0.625rem 2rem 0.625rem 1rem;
  font-size: 1rem;
}
.pt-select__input--error {
  border-color: var(--color-danger);
}
.pt-select__input--error:focus {
  border-color: var(--color-danger);
  box-shadow: 0 0 0 3px oklch(55% 0.22 25 / 12%);
}
.pt-radio-group, .pt-checkbox-group {
  border: none;
  padding: 0;
  margin: 0;
}
.pt-radio-group__legend, .pt-checkbox-group__legend {
  font-family: var(--font-sans);
  font-size: 0.875rem;
  font-weight: 500;
  color: var(--color-text);
  margin-bottom: 0.5rem;
  padding: 0;
}
.pt-radio-group--stacked .pt-radio-group__options, .pt-checkbox-group--stacked .pt-checkbox-group__options {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}
.pt-radio-group--inline .pt-radio-group__options, .pt-checkbox-group--inline .pt-checkbox-group__options {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  gap: 1rem;
}
.pt-radio-group--error .pt-radio__indicator, .pt-checkbox-group--error .pt-checkbox__indicator {
  border-color: var(--color-danger);
}
.pt-file-upload__input {
  position: absolute;
  opacity: 0;
  width: 0;
  height: 0;
}
.pt-file-upload__dropzone {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 0.75rem;
  padding: 2rem;
  border: 2px dashed var(--color-border);
  border-radius: var(--radius-lg);
  background: var(--color-surface-alt);
  cursor: pointer;
  transition: border-color 150ms ease, background 150ms ease;
  text-align: center;
}
.pt-file-upload__dropzone:hover, .pt-file-upload__dropzone--active {
  border-color: var(--color-brand);
  background: oklch(45% 0.18 250 / 4%);
}
.pt-file-upload__icon {
  color: var(--color-muted);
}
.pt-file-upload__icon-svg {
  width: 48px;
  height: 48px;
}
.pt-file-upload__prompt {
  font-family: var(--font-sans);
  font-size: 0.875rem;
  color: var(--color-muted);
}
.pt-file-upload__browse {
  color: var(--color-text);
  cursor: pointer;
  font-weight: 600;
  font-family: var(--font-sans);
  font-size: 0.875rem;
  text-decoration: none;
}
.pt-file-upload__hint {
  margin: 0;
  font-size: 0.8125rem;
  color: var(--color-muted);
}
.pt-file-upload__files {
  display: flex;
  flex-direction: column;
  gap: 0.375rem;
  margin-top: 0.5rem;
}
.pt-file-upload__file-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.5rem;
  font-family: var(--font-sans);
  font-size: 0.8125rem;
  color: var(--color-text);
  padding: 0.375rem 0.625rem;
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
}
.pt-file-upload__file-remove {
  background: none;
  border: none;
  color: var(--color-muted);
  cursor: pointer;
  padding: 0.25rem;
  display: flex;
  border-radius: var(--radius-sm);
}
.pt-file-upload__file-remove:hover {
  color: var(--color-danger);
  background: var(--color-surface-alt);
}
.pt-file-upload--disabled .pt-file-upload__dropzone {
  opacity: 0.5;
  cursor: not-allowed;
}
.pt-file-upload--error .pt-file-upload__dropzone {
  border-color: var(--color-danger);
}
.pt-search-input {
  position: relative;
  display: inline-flex;
  align-items: center;
  width: 100%;
}
.pt-search-input__icon {
  position: absolute;
  left: 0.625rem;
  color: var(--color-muted);
  pointer-events: none;
  display: flex;
}
.pt-search-input__field {
  display: block;
  width: 100%;
  font-family: var(--font-sans);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  background: var(--color-surface);
  color: var(--color-text);
  outline: none;
  transition: border-color 150ms ease, box-shadow 150ms ease;
}
.pt-search-input__field:focus {
  border-color: var(--color-brand);
  box-shadow: 0 0 0 3px oklch(45% 0.18 250 / 12%);
}
.pt-search-input__field--sm {
  padding: 0.375rem 2rem 0.375rem 2rem;
  font-size: 0.8125rem;
}
.pt-search-input__field--md {
  padding: 0.5rem 2rem 0.5rem 2.25rem;
  font-size: 0.875rem;
}
.pt-search-input__field:disabled {
  opacity: 0.5;
  cursor: not-allowed;
  background: var(--color-surface-alt);
}
.pt-search-input__clear {
  position: absolute;
  right: 0.5rem;
  background: none;
  border: none;
  color: var(--color-muted);
  cursor: pointer;
  padding: 0.25rem;
  display: flex;
  border-radius: var(--radius-sm);
}
.pt-search-input__clear:hover {
  color: var(--color-text);
  background: var(--color-surface-alt);
}
.pt-search-input__clear[hidden] {
  display: none;
}
.pt-tabs__list {
  display: flex;
  gap: 0;
  border-bottom: 1px solid var(--color-border);
  margin-bottom: 1rem;
}
.pt-tabs__btn {
  display: inline-flex;
  align-items: center;
  font-family: var(--font-sans);
  font-size: 0.875rem;
  font-weight: 500;
  color: var(--color-muted);
  background: none;
  border: none;
  padding: 0.625rem 1rem;
  cursor: pointer;
  position: relative;
  transition: color 150ms ease;
}
.pt-tabs__btn:hover {
  color: var(--color-text);
}
.pt-tabs__count {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 1.25rem;
  height: 1.25rem;
  margin-left: 0.375rem;
  padding: 0 0.375rem;
  border-radius: 9999px;
  background: var(--color-surface-alt, #f1f5f9);
  color: var(--color-muted);
  font-size: 0.6875rem;
  font-weight: 600;
  line-height: 1;
}
.pt-tabs__btn--active .pt-tabs__count {
  background: var(--color-brand);
  color: #fff;
}
.pt-tabs__btn--active {
  color: var(--color-brand);
}
.pt-tabs--default .pt-tabs__btn--active::after, .pt-tabs--underline .pt-tabs__btn--active::after {
  content: "";
  position: absolute;
  bottom: -1px;
  left: 0;
  right: 0;
  height: 2px;
  background: var(--color-brand);
  border-radius: 1px 1px 0 0;
}
.pt-tabs--pills .pt-tabs__list {
  border-bottom: none;
  gap: 0.25rem;
}
.pt-tabs--pills .pt-tabs__btn {
  border-radius: var(--radius-md);
  padding: 0.375rem 0.875rem;
}
.pt-tabs--pills .pt-tabs__btn--active {
  background: var(--color-brand);
  color: white;
}
.pt-tabs__panel {
  padding: 0.5rem 0;
}
.pt-accordion {
  display: flex;
  flex-direction: column;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  overflow: hidden;
}
.pt-accordion__section {
  border-bottom: 1px solid var(--color-border);
}
.pt-accordion__section:last-child {
  border-bottom: none;
}
.pt-accordion__trigger {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  padding: 0.75rem 1rem;
  font-family: var(--font-sans);
  font-size: 0.875rem;
  font-weight: 500;
  color: var(--color-text);
  background: var(--color-surface);
  border: none;
  cursor: pointer;
  text-align: left;
  transition: background 150ms ease;
}
.pt-accordion__trigger:hover {
  background: var(--color-surface-alt);
}
.pt-accordion__chevron {
  display: inline-block;
  width: 0.5rem;
  height: 0.5rem;
  border-right: 2px solid var(--color-muted);
  border-bottom: 2px solid var(--color-muted);
  transform: rotate(45deg);
  transition: transform 200ms ease;
  flex-shrink: 0;
}
.pt-accordion__section--open .pt-accordion__chevron {
  transform: rotate(-135deg);
}
.pt-accordion__content {
  padding: 0.75rem 1rem;
  font-family: var(--font-sans);
  font-size: 0.875rem;
  color: var(--color-text);
  line-height: 1.5;
  background: var(--color-surface);
}
.pt-breadcrumb__list {
  display: flex;
  align-items: center;
  list-style: none;
  padding: 0;
  margin: 0;
  gap: 0;
  font-family: var(--font-sans);
  font-size: 0.8125rem;
}
.pt-breadcrumb__item {
  display: flex;
  align-items: center;
}
.pt-breadcrumb__item a {
  color: var(--color-brand);
  text-decoration: none;
}
.pt-breadcrumb__item a:hover {
  text-decoration: underline;
}
.pt-breadcrumb__item--current {
  color: var(--color-muted);
}
.pt-breadcrumb__separator {
  margin: 0 0.375rem;
  color: var(--color-muted);
}
.pt-progress__track {
  width: 100%;
  background: var(--color-surface-alt);
  border-radius: var(--radius-full);
  overflow: hidden;
}
.pt-progress__bar {
  height: 100%;
  border-radius: var(--radius-full);
  transition: width 300ms ease;
}
.pt-progress--sm .pt-progress__track {
  height: 0.25rem;
}
.pt-progress--md .pt-progress__track {
  height: 0.5rem;
}
.pt-progress--lg .pt-progress__track {
  height: 0.75rem;
}
.pt-progress--brand .pt-progress__bar {
  background: var(--color-brand);
}
.pt-progress--success .pt-progress__bar {
  background: var(--color-success);
}
.pt-progress--warning .pt-progress__bar {
  background: var(--color-warning);
}
.pt-progress--danger .pt-progress__bar {
  background: var(--color-danger);
}
.pt-progress__label {
  display: block;
  margin-top: 0.25rem;
  font-family: var(--font-sans);
  font-size: 0.8125rem;
  color: var(--color-muted);
}
.pt-stepper__list {
  display: flex;
  list-style: none;
  padding: 0;
  margin: 0;
}
.pt-stepper--horizontal .pt-stepper__list {
  flex-direction: row;
  align-items: center;
}
.pt-stepper--vertical .pt-stepper__list {
  flex-direction: column;
}
.pt-stepper__step {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  font-family: var(--font-sans);
  font-size: 0.8125rem;
  color: var(--color-muted);
}
.pt-stepper--horizontal .pt-stepper__step:not(:last-child)::after {
  content: "";
  flex: 1;
  height: 2px;
  background: var(--color-border);
  margin: 0 0.5rem;
  min-width: 1.5rem;
}
.pt-stepper--vertical .pt-stepper__step {
  padding-bottom: 1.5rem;
  position: relative;
}
.pt-stepper--vertical .pt-stepper__step:not(:last-child)::after {
  content: "";
  position: absolute;
  left: 0.5rem;
  top: 1.5rem;
  bottom: 0;
  width: 2px;
  background: var(--color-border);
}
.pt-stepper__indicator {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1.25rem;
  height: 1.25rem;
  border-radius: var(--radius-full);
  border: 2px solid var(--color-border);
  background: var(--color-surface);
  flex-shrink: 0;
  transition: background 150ms ease, border-color 150ms ease;
}
.pt-stepper__step--completed .pt-stepper__indicator {
  background: var(--color-brand);
  border-color: var(--color-brand);
}
.pt-stepper__step--completed .pt-stepper__indicator::after {
  content: "";
  display: block;
  width: 0.3rem;
  height: 0.5rem;
  border: solid white;
  border-width: 0 2px 2px 0;
  transform: rotate(45deg) translate(-1px, -1px);
}
.pt-stepper__step--current .pt-stepper__indicator {
  border-color: var(--color-brand);
  box-shadow: 0 0 0 3px oklch(45% 0.18 250 / 12%);
}
.pt-stepper__step--completed .pt-stepper__label, .pt-stepper__step--current .pt-stepper__label {
  color: var(--color-text);
  font-weight: 500;
}
.pt-markdown-field {
  display: flex;
  flex-direction: column;
  border: 1px solid var(--color-surface-3);
  border-radius: var(--radius-md, 0.5rem);
  background: var(--color-surface);
  overflow: hidden;
}
.pt-markdown-field--error {
  border-color: var(--color-danger, #dc2626);
}
.pt-markdown-field__tabs {
  display: flex;
  gap: 1.25rem;
  padding: 0 0.75rem;
  border-bottom: 1px solid var(--color-surface-3);
  background: var(--color-surface);
}
.pt-markdown-field__tab {
  appearance: none;
  border: 0;
  background: transparent;
  padding: 0.5rem 0;
  font-size: 0.75rem;
  font-weight: 600;
  color: var(--color-text-secondary);
  cursor: pointer;
  border-bottom: 2px solid transparent;
  margin-bottom: -1px;
  transition: color 0.12s ease, border-color 0.12s ease;
}
.pt-markdown-field__tab:hover {
  color: var(--color-text-primary);
}
.pt-markdown-field__tab--active {
  color: var(--color-primary, #2563eb);
  border-bottom-color: var(--color-primary, #2563eb);
}
.pt-markdown-field__toolbar {
  display: flex;
  align-items: center;
  gap: 0.25rem;
  padding: 0.375rem 0.5rem;
  border-bottom: 1px solid var(--color-surface-3);
}
.pt-markdown-field__toolbar-divider {
  width: 1px;
  align-self: stretch;
  margin: 0.125rem 0.25rem;
  background: var(--color-surface-3);
}
.pt-markdown-field__tool {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  appearance: none;
  min-width: 1.75rem;
  height: 1.75rem;
  padding: 0;
  border: 1px solid transparent;
  border-radius: var(--radius-sm, 0.25rem);
  background: transparent;
  color: var(--color-text-secondary);
  line-height: 1;
  cursor: pointer;
}
.pt-markdown-field__tool:hover {
  background: var(--color-surface-2, #f1f5f9);
  color: var(--color-text-primary);
  border-color: var(--color-surface-3);
}
.pt-markdown-field__tool-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.pt-markdown-field__headings {
  position: relative;
  display: inline-flex;
}
.pt-markdown-field__tool--heading {
  gap: 0.0625rem;
  min-width: auto;
  padding: 0 0.375rem;
  font-size: 0.8125rem;
  font-weight: 700;
}
.pt-markdown-field__heading-caret {
  display: inline-flex;
  align-items: center;
  opacity: 0.7;
}
.pt-markdown-field__heading-menu {
  position: absolute;
  top: calc(100% + 0.25rem);
  left: 0;
  z-index: 20;
  display: none;
  flex-direction: column;
  min-width: 7rem;
  padding: 0.25rem;
  background: var(--color-surface);
  border: 1px solid var(--color-surface-3);
  border-radius: var(--radius-md, 0.5rem);
  box-shadow: var(--shadow-card, 0 4px 12px oklch(0% 0 0 / 8%));
}
.pt-markdown-field__heading-menu.pt-dropdown__menu--open {
  display: flex;
}
.pt-markdown-field__heading-item {
  appearance: none;
  display: flex;
  align-items: baseline;
  width: 100%;
  padding: 0.3125rem 0.5rem;
  border: 0;
  border-radius: var(--radius-sm, 0.25rem);
  background: transparent;
  color: var(--color-text-primary);
  text-align: left;
  cursor: pointer;
}
.pt-markdown-field__heading-item:hover {
  background: var(--color-surface-2, #f1f5f9);
}
.pt-markdown-field__heading-item-label {
  font-weight: 700;
  line-height: 1.2;
}
.pt-markdown-field__heading-item-label--h1 {
  font-size: 1.125rem;
}
.pt-markdown-field__heading-item-label--h2 {
  font-size: 1rem;
}
.pt-markdown-field__heading-item-label--h3 {
  font-size: 0.9375rem;
}
.pt-markdown-field__heading-item-label--h4 {
  font-size: 0.875rem;
}
.pt-markdown-field__heading-item-label--h5 {
  font-size: 0.8125rem;
}
.pt-markdown-field__textarea {
  width: 100%;
  border: 0;
  border-radius: 0;
  resize: vertical;
  font-family: var(--font-mono, ui-monospace, monospace);
  font-size: 0.8125rem;
}
.pt-markdown-field__textarea:focus {
  outline: none;
  box-shadow: none;
}
.pt-markdown-field__preview {
  padding: 0.75rem;
  min-height: 6rem;
}
.pt-markdown-field__preview-body {
  font-size: 0.8125rem;
  line-height: 1.5;
  color: var(--color-text-primary);
}
.pt-markdown-field__preview-empty {
  font-size: 0.8125rem;
  color: var(--color-text-secondary);
  font-style: italic;
}
.pt-modal {
  border: none;
  border-radius: var(--radius-lg, 0.75rem);
  box-shadow: var(--shadow-modal);
  padding: 0;
  max-height: 85vh;
  overflow: hidden;
  margin: auto;
}
.pt-modal[open] {
  display: flex;
  flex-direction: column;
}
.pt-modal::backdrop {
  background: oklch(0% 0 0 / 50%);
}
.pt-modal--sm {
  width: min(24rem, 90vw);
}
.pt-modal--md {
  width: min(32rem, 90vw);
}
.pt-modal--lg {
  width: min(48rem, 90vw);
}
.pt-modal__container {
  display: flex;
  flex-direction: column;
  flex: 1;
  min-height: 0;
  overflow: hidden;
}
.pt-modal__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 1rem 1.5rem;
  border-bottom: 1px solid oklch(90% 0 0);
}
.pt-modal__title {
  font-size: 1.125rem;
  font-weight: 600;
  margin: 0;
}
.pt-modal__title-row {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  flex: 1;
  min-width: 0;
}
.pt-modal__title-icon {
  flex-shrink: 0;
  display: flex;
  align-items: center;
  .pt-icon {
    width: 1.25rem;
    height: 1.25rem;
  }
}
.pt-modal__close {
  background: none;
  border: none;
  cursor: pointer;
  padding: 0.25rem 0.5rem;
  font-size: 1.125rem;
  line-height: 1;
  opacity: 0.5;
  transition: opacity 150ms ease;
  margin-left: auto;
}
.pt-modal__close:hover {
  opacity: 1;
}
.pt-modal__body {
  padding: 1.5rem;
  overflow-y: auto;
  flex: 1;
}
.pt-modal__footer {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 0.5rem;
  padding: 1rem 1.5rem;
  border-top: 1px solid oklch(90% 0 0);
}
.pt-confirm-dialog {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}
.pt-confirm-dialog__icon {
  .pt-icon {
    width: 2rem;
    height: 2rem;
  }
}
.pt-confirm-dialog__message {
  margin: 0;
  font-size: 0.9375rem;
  line-height: 1.6;
  color: oklch(35% 0 0);
}
.pt-confirm-dialog__actions {
  display: flex;
  justify-content: flex-end;
  gap: 0.5rem;
  padding-top: 0.5rem;
}
.pt-money-input {
  display: flex;
  align-items: stretch;
  gap: 0.5rem;
  width: 100%;
}
.pt-money-input .pt-input {
  flex: 1 1 auto;
  min-width: 0;
}
.pt-money-input .pt-select {
  flex: 0 0 5rem;
}
.pt-multi-select {
  position: relative;
  width: 100%;
  font-family: var(--font-sans);
}
.pt-multi-select__native {
  position: absolute;
  opacity: 0;
  pointer-events: none;
  width: 1px;
  height: 1px;
  margin: 0;
  padding: 0;
  border: 0;
  bottom: 0;
  left: 1rem;
}
.pt-multi-select__trigger {
  display: flex;
  align-items: stretch;
  gap: 0.5rem;
  width: 100%;
  min-height: 2.25rem;
  padding: 0.25rem 0.5rem 0.25rem 0.625rem;
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: 0.25rem;
  font-family: inherit;
  font-size: var(--text-sm);
  color: var(--color-text-primary);
  text-align: left;
  cursor: pointer;
  transition: border-color 120ms ease, box-shadow 120ms ease;
}
.pt-multi-select__trigger:hover {
  border-color: var(--color-border-strong);
}
.pt-multi-select__trigger[aria-expanded="true"], .pt-multi-select__trigger:focus-visible {
  border-color: var(--color-brand);
  outline: none;
  box-shadow: 0 0 0 3px oklch(45% 0.18 250 / 12%);
}
.pt-multi-select--error .pt-multi-select__trigger {
  border-color: var(--color-danger);
}
.pt-multi-select--sm .pt-multi-select__trigger {
  min-height: 1.875rem;
  font-size: var(--text-xs);
}
.pt-multi-select--lg .pt-multi-select__trigger {
  min-height: 2.625rem;
  font-size: var(--text-base);
}
.pt-multi-select__chips {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.25rem;
  flex: 1 1 auto;
  min-width: 0;
}
.pt-multi-select__placeholder {
  color: var(--color-text-secondary);
}
.pt-multi-select__chip {
  display: inline-flex;
  align-items: center;
  gap: 0.25rem;
  padding: 0.125rem 0.375rem 0.125rem 0.5rem;
  background: var(--color-brand-subtle);
  color: var(--color-brand);
  border-radius: 0.25rem;
  font-size: var(--text-xs);
  line-height: 1.25rem;
  max-width: 100%;
}
.pt-multi-select__chip-label {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.pt-multi-select__chip-remove {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1rem;
  height: 1rem;
  padding: 0;
  border: 0;
  background: transparent;
  color: inherit;
  cursor: pointer;
  border-radius: 0.25rem;
  transition: background 120ms ease;
}
.pt-multi-select__chip-remove:hover {
  background: oklch(0% 0 0 / 8%);
}
.pt-multi-select__caret {
  display: inline-flex;
  align-items: center;
  color: var(--color-text-secondary);
  flex-shrink: 0;
}
.pt-multi-select__popover {
  position: absolute;
  top: calc(100% + 0.25rem);
  left: 0;
  right: 0;
  z-index: 1010;
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: 0.25rem;
  box-shadow: var(--shadow-card);
  overflow: hidden;
}
.pt-multi-select__popover[hidden] {
  display: none;
}
.pt-multi-select__search-wrap {
  padding: 0.5rem;
  border-bottom: 1px solid var(--color-border);
}
.pt-multi-select__search {
  width: 100%;
  padding: 0.375rem 0.5rem;
  border: 1px solid var(--color-border);
  border-radius: 0.25rem;
  font-size: var(--text-sm);
  color: var(--color-text-primary);
  font-family: inherit;
}
.pt-multi-select__search:focus-visible {
  border-color: var(--color-brand);
  outline: none;
}
.pt-multi-select__options {
  list-style: none;
  margin: 0;
  padding: 0.25rem 0;
  max-height: 16rem;
  overflow-y: auto;
}
.pt-multi-select__option {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.375rem 0.625rem;
  font-size: var(--text-sm);
  color: var(--color-text-primary);
  cursor: pointer;
  user-select: none;
}
.pt-multi-select__option[hidden] {
  display: none;
}
.pt-multi-select__option:hover, .pt-multi-select__option:focus-visible {
  background: var(--color-surface-2);
  outline: none;
}
.pt-multi-select__option-check {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1rem;
  height: 1rem;
  border: 1px solid var(--color-border);
  border-radius: 0.25rem;
  color: transparent;
  background: var(--color-surface);
  flex-shrink: 0;
  transition: background 120ms ease, border-color 120ms ease, color 120ms ease;
}
.pt-multi-select__option--selected .pt-multi-select__option-check {
  background: var(--color-brand);
  border-color: var(--color-brand);
  color: var(--color-on-brand);
}
.pt-multi-select__option-label {
  flex: 1 1 auto;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.pt-multi-select__add-new {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.375rem 0.625rem;
  font-size: var(--text-sm);
  color: var(--color-brand);
  cursor: pointer;
  user-select: none;
  border-bottom: 1px solid var(--color-border);
}
.pt-multi-select__add-new[hidden] {
  display: none;
}
.pt-multi-select__add-new:hover, .pt-multi-select__add-new:focus-visible {
  background: var(--color-brand-subtle);
  outline: none;
}
.pt-multi-select__add-new-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.pt-multi-select__add-new-label {
  flex: 1 1 auto;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.pt-multi-select__add-new-query {
  font-weight: 500;
  color: var(--color-text-primary);
}
.pt-multi-select__chip--new {
  background: var(--color-surface-2);
  color: var(--color-text-primary);
}
.pt-notif-bell {
  display: block;
}
.pt-notif-bell__trigger {
  border: none;
  background: transparent;
  font-family: inherit;
  text-align: left;
  cursor: pointer;
  width: calc(100% - 0.75rem);
}
.pt-notif-bell__count {
  margin-left: auto;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 1.125rem;
  height: 1.125rem;
  padding: 0 0.3125rem;
  border-radius: var(--radius-full);
  background: var(--color-accent);
  color: var(--color-text-inverse);
  font-size: 0.6875rem;
  font-weight: 700;
  line-height: 1.125rem;
}
.pt-notif-bell__count[hidden] {
  display: none;
}
.pt-sidebar--collapsed .pt-notif-bell__count {
  position: absolute;
  top: 0.125rem;
  right: 0.1875rem;
  margin: 0;
  min-width: 0.875rem;
  height: 0.875rem;
  padding: 0 0.1875rem;
  font-size: 0.5625rem;
  line-height: 0.875rem;
  box-shadow: 0 0 0 2px var(--pt-sidebar-bg);
}
.pt-notif-bell__menu {
  position: fixed;
  top: auto;
  right: auto;
  width: 22rem;
  max-width: calc(100vw - 1.5rem);
  z-index: var(--z-overlay);
}
.pt-notif-dropdown {
  display: flex;
  flex-direction: column;
  max-height: 28rem;
}
.pt-notif-dropdown__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.5rem;
  padding: 0.75rem 0.875rem;
  border-bottom: 1px solid var(--color-surface-3);
}
.pt-notif-dropdown__title {
  font-size: 0.875rem;
  font-weight: 700;
  color: var(--color-text-primary);
}
.pt-notif-dropdown__view-all {
  display: inline-flex;
  align-items: center;
  gap: 0.25rem;
  font-size: 0.75rem;
  font-weight: 600;
  color: var(--color-brand);
  text-decoration: none;
}
.pt-notif-dropdown__view-all:hover {
  text-decoration: underline;
}
.pt-notif-dropdown__view-all-icon {
  width: 0.875rem;
  height: 0.875rem;
}
.pt-notif-dropdown turbo-frame {
  display: block;
  overflow-y: auto;
  min-height: 3rem;
  max-height: 24rem;
}
.pt-notif-dropdown__loading, .pt-notif-dropdown__empty {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  padding: 1rem 0.875rem;
  color: var(--color-text-secondary);
  font-size: 0.8125rem;
}
.pt-notif-dropdown__loading-icon, .pt-notif-dropdown__empty-icon {
  width: 1rem;
  height: 1rem;
}
.pt-notif-feed {
  list-style: none;
  margin: 0;
  padding: 0;
}
.pt-notif-feed__item {
  position: relative;
  padding: 0.625rem 0.875rem;
  border-bottom: 1px solid var(--color-surface-3);
  cursor: pointer;
}
.pt-notif-feed__item:hover {
  background: var(--color-surface-2);
}
.pt-notif-feed__item:last-child {
  border-bottom: none;
}
.pt-notif-feed__item--unread {
  background: color-mix(in srgb, oklch(65% 0.22 35) 6%, transparent);
  @supports (color: color-mix(in lab, red, red)) {
    background: color-mix(in oklch, var(--color-accent) 6%, transparent);
  }
}
.pt-notif-feed__dot {
  position: absolute;
  top: 0.75rem;
  right: 0.75rem;
  width: 0.5rem;
  height: 0.5rem;
  border-radius: var(--radius-full);
  background: var(--color-accent);
}
.pt-notif-feed__date {
  display: block;
  margin-bottom: 0.25rem;
  font-size: 0.6875rem;
  font-weight: 600;
  letter-spacing: 0.03em;
  text-transform: uppercase;
  color: var(--color-text-secondary);
}
.pt-notif-feed__text {
  font-size: 0.8125rem;
  line-height: 1.45;
  color: var(--color-text-primary);
}
.pt-notif-feed__text a {
  color: var(--color-brand);
  text-decoration: none;
}
.pt-notif-feed__text a:hover {
  text-decoration: underline;
}
.pt-prose {
  color: var(--color-text-primary);
  font-size: 0.8125rem;
  line-height: 1.6;
  overflow-wrap: anywhere;
}
.pt-prose h1, .pt-prose h2, .pt-prose h3, .pt-prose h4, .pt-prose h5, .pt-prose h6 {
  color: var(--color-text-primary);
  font-weight: 700;
  line-height: 1.25;
  margin: 1em 0 0.4em;
}
.pt-prose > :first-child {
  margin-top: 0;
}
.pt-prose h1 {
  font-size: 1.5rem;
}
.pt-prose h2 {
  font-size: 1.25rem;
}
.pt-prose h3 {
  font-size: 1.125rem;
}
.pt-prose h4 {
  font-size: 1rem;
}
.pt-prose h5 {
  font-size: 0.9375rem;
  font-weight: 600;
}
.pt-prose h6 {
  font-size: 0.8125rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.03em;
  color: var(--color-text-secondary);
}
.pt-prose p {
  margin: 0 0 0.75em;
}
.pt-prose p:last-child {
  margin-bottom: 0;
}
.pt-prose ul, .pt-prose ol {
  margin: 0 0 0.75em;
  padding-left: 1.5rem;
}
.pt-prose ul {
  list-style: disc;
}
.pt-prose ol {
  list-style: decimal;
}
.pt-prose li {
  margin: 0.25em 0;
}
.pt-prose li > ul, .pt-prose li > ol {
  margin: 0.25em 0;
}
.pt-prose strong, .pt-prose b {
  font-weight: 700;
}
.pt-prose em, .pt-prose i {
  font-style: italic;
}
.pt-prose a {
  color: var(--color-primary, #2563eb);
  text-decoration: underline;
  text-underline-offset: 2px;
}
.pt-prose a:hover {
  text-decoration: none;
}
.pt-prose blockquote {
  margin: 0 0 0.75em;
  padding: 0.25rem 0 0.25rem 0.875rem;
  border-left: 3px solid var(--color-surface-3);
  color: var(--color-text-secondary);
  font-style: italic;
}
.pt-prose code {
  font-family: var(--font-mono, ui-monospace, monospace);
  font-size: 0.8125em;
  padding: 0.125em 0.3125em;
  border-radius: var(--radius-sm, 0.25rem);
  background: var(--color-surface-2, #f1f5f9);
  color: var(--color-text-primary);
}
.pt-prose pre {
  margin: 0 0 0.75em;
  padding: 0.75rem;
  border-radius: var(--radius-md, 0.5rem);
  background: var(--color-surface-2, #f1f5f9);
  overflow-x: auto;
}
.pt-prose pre code {
  padding: 0;
  background: transparent;
  font-size: 0.8125rem;
}
.pt-prose hr {
  margin: 1em 0;
  border: 0;
  border-top: 1px solid var(--color-surface-3);
}
.pt-page-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 1rem;
  margin: -1.5rem -1.5rem 1.5rem;
  padding: 1.25rem 1.5rem 1rem;
  background: var(--color-surface);
  border-bottom: 1px solid var(--color-border);
}
.pt-page-header:has(.pt-page-header__nav) {
  flex-wrap: wrap;
  padding-bottom: 0;
  border-bottom: none;
}
.pt-page-header__nav {
  flex-basis: 100%;
}
.pt-page-header__text {
  flex: 1;
  min-width: 0;
}
.pt-page-header__title {
  font-size: 1.375rem;
  font-weight: 700;
  color: oklch(15% 0 0);
  margin: 0;
  line-height: 1.25;
  display: flex;
  align-items: center;
  gap: 0.5rem;
}
.pt-page-header__icon {
  flex-shrink: 0;
  color: oklch(45% 0 0);
  width: 1.375rem;
  height: 1.375rem;
}
.pt-page-header__subtitle {
  font-size: 0.875rem;
  color: oklch(50% 0 0);
  margin: 0.25rem 0 0;
}
.pt-page-header__actions {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  flex-shrink: 0;
}
.pt-page-tabs {
  display: flex;
  align-items: stretch;
  gap: 1.5rem;
  border-bottom: 1px solid var(--color-border);
}
.pt-page-tabs__tab {
  margin-bottom: -1px;
  padding: 0.25rem 0 0.75rem;
  border-bottom: 2px solid transparent;
  color: var(--color-text-secondary);
  font-size: 0.875rem;
  font-weight: 500;
  text-decoration: none;
  white-space: nowrap;
  transition: color 0.15s ease, border-color 0.15s ease;
}
.pt-page-tabs__tab:hover, .pt-page-tabs__tab:focus-visible {
  color: var(--color-text-primary);
  outline: none;
}
.pt-page-tabs__tab--active {
  color: var(--color-brand);
  border-bottom-color: var(--color-brand);
}
.pt-pagination {
  display: flex;
  justify-content: center;
  padding: 1.5rem 0;
}
.pt-pagination__list {
  display: flex;
  align-items: center;
  gap: 0.25rem;
}
.pt-pagination__link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 2rem;
  height: 2rem;
  padding: 0 0.5rem;
  border-radius: var(--radius-sm);
  font-size: 0.875rem;
  color: var(--color-text-secondary);
  text-decoration: none;
  transition: background 120ms ease, color 120ms ease;
  cursor: pointer;
  &:hover {
    background: var(--color-brand-subtle);
    color: var(--color-brand);
  }
}
.pt-pagination__link--current, .pt-pagination__item--current > .pt-pagination__link {
  background: var(--color-brand);
  color: var(--color-on-brand);
  font-weight: 600;
  &:hover {
    background: var(--color-brand-hover);
    color: var(--color-on-brand);
  }
}
.pt-pagination__link--disabled, .pt-pagination__item--disabled > .pt-pagination__link {
  opacity: 0.35;
  cursor: not-allowed;
  pointer-events: none;
}
.pt-spinner {
  display: inline-flex;
  align-items: center;
}
.pt-spinner__svg {
  animation: pt-spin 0.8s linear infinite;
}
@keyframes pt-spin {
  to {
    transform: rotate(360deg);
  }
}
.pt-spinner__track {
  opacity: 0.2;
}
.pt-spinner__arc {
  opacity: 0.85;
}
.pt-spinner--sm .pt-spinner__svg {
  width: 1rem;
  height: 1rem;
}
.pt-spinner--md .pt-spinner__svg {
  width: 1.5rem;
  height: 1.5rem;
}
.pt-spinner--lg .pt-spinner__svg {
  width: 2.25rem;
  height: 2.25rem;
}
.pt-spinner--dark {
  color: oklch(40% 0 0);
}
.pt-spinner--light {
  color: var(--color-surface);
}
.pt-currency-input {
  display: flex;
  align-items: stretch;
  gap: var(--spacing-xs);
}
.pt-currency-input__prefix {
  display: inline-flex;
  align-items: center;
  padding: 0 var(--spacing-sm);
  font-size: var(--text-sm);
  color: var(--color-text-secondary);
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
}
.pt-currency-input .pt-input {
  flex: 1 1 auto;
}
.pt-address-input {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: var(--spacing-sm);
}
.pt-address-input__field {
  grid-column: 1 / -1;
  display: flex;
  flex-direction: column;
  gap: var(--spacing-xs);
}
.pt-address-input__field--half {
  grid-column: span 1;
}
.pt-address-input__label, .pt-range-input__label {
  font-size: var(--text-xs);
  color: var(--color-text-muted);
}
.pt-range-input {
  display: flex;
  align-items: flex-end;
  gap: var(--spacing-sm);
}
.pt-range-input__field {
  flex: 1 1 0;
  display: flex;
  flex-direction: column;
  gap: var(--spacing-xs);
}
.pt-range-input__separator {
  padding-bottom: 0.5rem;
  color: var(--color-text-muted);
}
.pt-checkbox-group {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-xs);
  border: 0;
  padding: 0;
  margin: 0;
}
.pt-checkbox-group__option {
  display: inline-flex;
  align-items: center;
  gap: var(--spacing-sm);
  font-size: var(--text-sm);
  color: var(--color-text-primary);
  cursor: pointer;
}
.pt-checkbox-group[disabled] .pt-checkbox-group__option {
  cursor: not-allowed;
  color: var(--color-text-muted);
}
.pt-scoring-guide {
  margin-top: var(--pt-space-2, 0.5rem);
  font-size: var(--pt-font-size-xs, 0.75rem);
}
.pt-scoring-guide__summary {
  display: inline-flex;
  align-items: center;
  gap: var(--pt-space-1, 0.25rem);
  cursor: pointer;
  color: var(--pt-color-text-muted, #6b7280);
  user-select: none;
}
.pt-scoring-guide__summary:hover {
  color: var(--pt-color-text, #111827);
}
.pt-scoring-guide__bands {
  list-style: none;
  margin: var(--pt-space-2, 0.5rem) 0 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: var(--pt-space-1, 0.25rem);
}
.pt-scoring-guide__band {
  display: grid;
  grid-template-columns: 1.5rem 1fr;
  gap: var(--pt-space-2, 0.5rem);
  align-items: baseline;
}
.pt-scoring-guide__score {
  font-weight: 600;
  color: var(--pt-color-text, #111827);
  font-variant-numeric: tabular-nums;
}
.pt-scoring-guide__text {
  color: var(--pt-color-text-muted, #6b7280);
}
.pt-segmented-filter {
  display: inline-flex;
  align-items: stretch;
  margin: 0;
  padding: 0;
  border: 1px solid var(--color-border, oklch(83% 0 0));
  border-radius: 0.5rem;
  overflow: hidden;
  background: var(--color-surface);
}
.pt-segmented-filter__segment {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.375rem 0.75rem;
  background: var(--color-surface);
  border: none;
  border-right: 1px solid var(--color-border, oklch(83% 0 0));
  cursor: pointer;
  color: var(--color-text-secondary, oklch(55% 0 0));
  font-size: 0.75rem;
  font-weight: 500;
  white-space: nowrap;
  transition: background 0.12s, color 0.12s;
}
.pt-segmented-filter__segment:last-child {
  border-right: none;
}
.pt-segmented-filter__segment:hover {
  background: var(--color-surface-2, oklch(96% 0 0));
  color: var(--color-text-primary, oklch(30% 0 0));
}
.pt-segmented-filter__segment--active, .pt-segmented-filter__segment--active:hover {
  background: var(--color-brand, oklch(45% 0.18 250));
  color: var(--color-on-brand, var(--color-surface));
}
.pt-toast-container {
  position: fixed;
  top: 1rem;
  right: 1rem;
  z-index: 60;
  display: flex;
  flex-direction: column;
  gap: 0.625rem;
  width: max-content;
  max-width: 400px;
  pointer-events: none;
}
.pt-toast-container .pt-toast {
  pointer-events: auto;
}
@media (max-width: 480px) {
  .pt-toast-container {
    left: 1rem;
    right: 1rem;
    max-width: none;
    width: auto;
  }
}
.pt-toast {
  display: flex;
  align-items: flex-start;
  gap: 0.75rem;
  padding: 0.875rem 1rem;
  border-radius: 0.625rem;
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.12), 0 1px 4px rgba(0, 0, 0, 0.08);
  background: var(--color-surface);
  border: 1px solid oklch(92% 0 0);
  min-width: 280px;
  max-width: 400px;
  position: relative;
  opacity: 0;
  transform: translateY(-0.375rem) scale(0.98);
  transition: opacity 200ms ease, transform 200ms ease;
}
.pt-toast--visible {
  opacity: 1;
  transform: none;
}
.pt-toast--exiting {
  opacity: 0;
  transform: translateX(0.5rem);
}
@media (prefers-reduced-motion: reduce) {
  .pt-toast {
    transition: opacity 200ms ease;
    transform: none;
  }
}
.pt-toast--success {
  border-left: 3px solid oklch(60% 0.18 155);
}
.pt-toast--error {
  border-left: 3px solid oklch(55% 0.22 25);
}
.pt-toast--warning {
  border-left: 3px solid oklch(70% 0.16 75);
}
.pt-toast--info {
  border-left: 3px solid oklch(55% 0.18 255);
}
.pt-toast--success .pt-toast__icon {
  color: oklch(55% 0.18 155);
}
.pt-toast--error .pt-toast__icon {
  color: oklch(52% 0.22 25);
}
.pt-toast--warning .pt-toast__icon {
  color: oklch(65% 0.16 75);
}
.pt-toast--info .pt-toast__icon {
  color: oklch(52% 0.18 255);
}
.pt-toast__icon {
  flex-shrink: 0;
  margin-top: 0.0625rem;
}
.pt-toast__body {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 0.1875rem;
}
.pt-toast__title {
  font-size: 0.875rem;
  font-weight: 600;
  color: oklch(20% 0 0);
  margin: 0;
}
.pt-toast__message {
  font-size: 0.875rem;
  color: oklch(40% 0 0);
  margin: 0;
  line-height: 1.45;
}
.pt-toast__dismiss {
  flex-shrink: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1.5rem;
  height: 1.5rem;
  border: none;
  background: transparent;
  color: oklch(60% 0 0);
  cursor: pointer;
  border-radius: 0.375rem;
  padding: 0;
  transition: background 120ms ease, color 120ms ease;
  &:hover {
    background: oklch(94% 0 0);
    color: oklch(25% 0 0);
  }
}
.pt-user-menu {
  position: relative;
  margin-left: auto;
}
.pt-user-menu__trigger {
  background: none;
  border: none;
  padding: 0;
  cursor: pointer;
  border-radius: 9999px;
}
.pt-user-menu__trigger:focus-visible {
  outline: none;
  box-shadow: 0 0 0 3px oklch(45% 0.18 250 / 18%);
}
.pt-user-menu__dropdown {
  position: absolute;
  top: calc(100% + 0.5rem);
  right: 0;
  left: auto;
  width: 260px;
  background: var(--color-surface);
  border: 1px solid oklch(88% 0 0);
  border-radius: 0.75rem;
  box-shadow: var(--shadow-modal);
  z-index: 50;
  overflow: hidden;
}
.pt-user-menu__dropdown--floating {
  position: fixed;
  top: auto;
  right: auto;
  left: auto;
  margin: 0;
  z-index: var(--z-overlay);
}
.pt-user-menu__company {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  padding: 1rem;
  border-bottom: 1px solid oklch(93% 0 0);
}
.pt-user-menu__details {
  display: flex;
  flex-direction: column;
  min-width: 0;
}
.pt-user-menu__company-name {
  font-weight: 600;
  font-size: 0.875rem;
  color: oklch(15% 0 0);
  text-decoration: none;
  &:hover {
    color: var(--color-brand);
  }
}
.pt-user-menu__details {
  min-width: 0;
}
.pt-user-menu__user-name {
  display: block;
  font-size: 0.75rem;
  color: oklch(55% 0 0);
}
.pt-user-menu__user-role {
  display: block;
  margin-top: 0.125rem;
  font-size: 0.6875rem;
  line-height: 1rem;
  color: var(--color-muted);
}
.pt-user-menu__switcher {
  padding: 0.5rem;
  border-bottom: 1px solid oklch(93% 0 0);
}
.pt-user-menu__other-company {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.375rem 0.5rem;
  border-radius: 0.375rem;
  &:hover {
    background: oklch(96% 0 0);
  }
}
.pt-user-menu__switch-link {
  font-size: 0.8125rem;
  color: oklch(30% 0 0);
  text-decoration: none;
  &:hover {
    color: var(--color-brand);
  }
}
.pt-user-menu__links {
  list-style: none;
  margin: 0;
  padding: 0.375rem;
  li {
    margin: 0;
  }
  a, button {
    display: flex;
    align-items: center;
    gap: 0.625rem;
    width: 100%;
    padding: 0.5rem 0.75rem;
    border-radius: 0.375rem;
    font-size: 0.8125rem;
    color: oklch(25% 0 0);
    text-decoration: none;
    background: none;
    border: none;
    cursor: pointer;
    text-align: left;
    &:hover {
      background: oklch(96% 0 0);
    }
    i {
      width: 1rem;
      text-align: center;
      color: oklch(55% 0 0);
    }
  }
}
.pt-user-menu__logout {
  color: oklch(45% 0.15 25) !important;
  i {
    color: oklch(45% 0.15 25) !important;
  }
}
.pt-tag-popup {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  box-shadow: 0 8px 24px oklch(0% 0 0 / 12%), 0 2px 6px oklch(0% 0 0 / 6%);
  z-index: 500;
  padding: 0.5rem;
  display: flex;
  flex-direction: column;
  gap: 0.375rem;
  overflow: visible;
}
.pt-tag-popup__footer {
  display: block;
  padding: 0.375rem 0.5rem;
  font-size: 0.8125rem;
  color: var(--color-brand);
  text-align: center;
  border-top: 1px solid var(--color-border);
  text-decoration: none;
  border-radius: 0 0 var(--radius-md) var(--radius-md);
  transition: background 100ms ease;
}
.pt-tag-popup__footer:hover {
  background: var(--color-surface-alt);
}
.pt-tag-popup .ts-dropdown {
  z-index: 10;
}
.pt-ag-donut-chart, .pt-ag-chart--donut {
  position: relative;
  width: 100%;
  min-width: 0;
  overflow: visible;
}
.pt-ag-donut-chart__header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 1rem;
  margin-bottom: 0.75rem;
}
.pt-ag-donut-chart__header--menu-only {
  position: absolute;
  top: 0.35rem;
  right: 0.35rem;
  z-index: 4;
  justify-content: flex-end;
  margin-bottom: 0;
  pointer-events: none;
}
.pt-ag-donut-chart__header--menu-only .pt-ag-donut-chart__menu-shell {
  pointer-events: auto;
}
.pt-ag-donut-chart__menu-shell {
  position: relative;
  flex: 0 0 auto;
}
.pt-ag-donut-chart__menu-button {
  display: inline-flex;
  width: 1.75rem;
  height: 1.75rem;
  align-items: center;
  justify-content: center;
  border: 1px solid var(--pt-color-border, #d1d5db);
  border-radius: 0.25rem;
  background: #ffffff;
  color: var(--pt-color-text, #111827);
  cursor: pointer;
  line-height: 1;
  box-shadow: 0 1px 2px rgba(15, 23, 42, 0.06);
  transition: background-color 0.15s ease, border-color 0.15s ease, color 0.15s ease, box-shadow 0.15s ease;
}
.pt-ag-donut-chart__menu-button:hover, .pt-ag-donut-chart__menu-button:focus-visible {
  border-color: var(--pt-color-border, #d1d5db);
  background: var(--pt-color-surface-subtle, #f3f4f6);
  color: var(--pt-color-text, #111827);
  outline: none;
  box-shadow: 0 0 0 3px rgb(49 150 209 / 14%);
}
.pt-ag-donut-chart__menu-icon {
  display: block;
  width: auto;
  height: auto;
  font-size: 1rem;
  font-weight: 700;
  line-height: 1;
}
.pt-ag-donut-chart__menu {
  position: fixed;
  z-index: 950;
  min-width: 13rem;
  border: 1px solid var(--pt-color-border, #d1d5db);
  border-radius: 0.55rem;
  background: #ffffff;
  padding: 0.35rem;
  box-shadow: 0 18px 44px rgb(15 23 42 / 18%);
}
.pt-ag-donut-chart__menu[hidden] {
  display: none;
}
.pt-ag-donut-chart__menu-item {
  display: block;
  width: 100%;
  border: 0;
  border-radius: 0.38rem;
  background: transparent;
  color: var(--pt-color-text, #111827);
  padding: 0.48rem 0.65rem;
  text-align: left;
  font-size: 0.8125rem;
  line-height: 1.25;
  cursor: pointer;
}
.pt-ag-donut-chart__menu-item:hover, .pt-ag-donut-chart__menu-item:focus-visible {
  background: var(--pt-color-surface-subtle, #f3f4f6);
  outline: none;
}
.pt-ag-donut-chart__menu-separator {
  height: 1px;
  margin: 0.35rem 0;
  background: var(--pt-color-border-subtle, #e5e7eb);
}
.pt-ag-donut-chart__canvas {
  width: 100%;
  min-height: 16rem;
}
.pt-ag-donut-chart__empty {
  display: flex;
  min-height: 16rem;
  align-items: center;
  justify-content: center;
}
.pt-ag-donut-chart__table {
  margin-top: 0.75rem;
  max-height: 18rem;
  overflow: auto;
  border: 1px solid var(--pt-color-border, #d1d5db);
  border-radius: 0.5rem;
  background: #ffffff;
}
.pt-ag-donut-chart__table[hidden] {
  display: none;
}
.pt-ag-donut-chart__table table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.78rem;
}
.pt-ag-donut-chart__table th, .pt-ag-donut-chart__table td {
  border-bottom: 1px solid var(--pt-color-border-subtle, #e5e7eb);
  padding: 0.45rem 0.55rem;
  text-align: left;
  white-space: nowrap;
}
.pt-ag-donut-chart__table th {
  background: var(--pt-color-surface-subtle, #f3f4f6);
  color: var(--pt-color-text, #111827);
  font-weight: 700;
}
.pt-ag-donut-chart__table tr:last-child td {
  border-bottom: 0;
}
@media (max-width: 768px) {
  .pt-ag-donut-chart__header {
    align-items: center;
  }
  .pt-ag-donut-chart__canvas {
    min-height: 14rem;
  }
}
.pt-ag-grid-container {
  width: 100%;
  min-width: 0;
  height: clamp(40rem, calc(100vh - 14rem), 64rem);
  border: 1px solid oklch(87% 0 0);
  border-radius: 0.75rem;
  overflow: hidden;
  background: var(--color-surface);
  box-shadow: 0 0.25rem 0.75rem oklch(20% 0 0 / 5%);
  --ag-font-family: inherit;
  --ag-font-size: 0.8125rem;
  --ag-background-color: var(--color-surface);
  --ag-foreground-color: oklch(20% 0 0);
  --ag-border-color: oklch(86% 0 0);
  --ag-header-background-color: oklch(97% 0 0);
  --ag-header-foreground-color: oklch(24% 0 0);
  --ag-row-hover-color: oklch(97% 0.01 250);
  --ag-selected-row-background-color: oklch(94% 0.03 250);
  --ag-odd-row-background-color: oklch(99% 0 0);
  --ag-wrapper-border-radius: 0.75rem;
  --ag-row-border-color: oklch(90% 0 0);
  --ag-control-panel-background-color: var(--color-surface);
  --ag-cell-horizontal-padding: 0.75rem;
  --ag-header-column-separator-display: block;
  --ag-header-column-separator-color: oklch(88% 0 0);
}
.pt-ag-grid-container[hidden] {
  display: none !important;
}
.pt-ag-grid-container .ag-root-wrapper {
  border: none;
  border-radius: 0.75rem;
}
.pt-ag-grid-container .ag-header {
  border-bottom: 1px solid oklch(86% 0 0);
  background: oklch(97% 0 0);
}
.pt-ag-grid-container .ag-header-row, .pt-ag-grid-container .ag-header-group-cell, .pt-ag-grid-container .ag-header-cell {
  background: oklch(97% 0 0);
}
.pt-ag-grid-container .ag-header-group-cell, .pt-ag-grid-container .ag-header-cell {
  border-right: 1px solid oklch(88% 0 0);
}
.pt-ag-grid-container .ag-header-group-cell:last-child, .pt-ag-grid-container .ag-header-cell:last-child {
  border-right: none;
}
.pt-ag-grid-container .ag-row {
  cursor: pointer;
}
.pt-ag-grid-container .ag-row-odd {
  background: oklch(99% 0 0);
}
.pt-ag-grid-container .ag-row-even {
  background: var(--color-surface);
}
.pt-ag-grid-container .ag-paging-panel {
  min-height: 3rem;
  border-top: 1px solid oklch(88% 0 0);
  color: oklch(38% 0 0);
  font-size: 0.8125rem;
  background: var(--color-surface);
}
.pt-ag-grid-container .ag-paging-page-size {
  margin-left: 0.75rem;
}
.pt-ag-grid-container .ag-paging-row-summary-panel, .pt-ag-grid-container .ag-paging-page-summary-panel {
  font-variant-numeric: tabular-nums;
}
.pt-ag-grid-container .ag-overlay-no-rows-center {
  color: oklch(45% 0 0);
  font-size: 0.9rem;
}
.pt-ag-grid__cell {
  display: flex;
  align-items: center;
  width: 100%;
  min-width: 0;
  height: 100%;
}
.pt-ag-grid__empty-overlay {
  color: var(--color-text-secondary);
  font-size: 0.875rem;
  font-weight: 600;
}
.pt-ag-logo {
  width: 2.25rem;
  height: 2.25rem;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 0.25rem;
  overflow: hidden;
  background: oklch(95% 0 0);
  img {
    max-width: 100%;
    max-height: 100%;
    object-fit: contain;
  }
}
.pt-ag-logo--placeholder {
  font-weight: 700;
  font-size: 1rem;
  color: var(--color-surface);
  background: oklch(45% 0.18 250);
}
.pt-ag-name-link {
  color: oklch(25% 0 0);
  font-weight: 500;
  text-decoration: none;
  &:hover {
    color: oklch(45% 0.18 250);
    text-decoration: underline;
  }
}
@media (max-width: 900px) {
  .pt-ag-grid-container {
    height: 42rem;
    overflow-x: auto;
  }
  .pt-ag-grid-container .ag-paging-panel {
    justify-content: flex-start;
    overflow-x: auto;
    padding-inline: 0.75rem;
  }
}
.pt-attachment-list {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-sm, 0.5rem);
}
.pt-attachment-list__items {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-xs, 0.25rem);
  margin: 0;
  padding: 0;
  list-style: none;
}
.pt-attachment-list__item {
  display: flex;
  align-items: center;
  gap: var(--spacing-sm, 0.5rem);
  padding: var(--spacing-xs, 0.25rem) var(--spacing-sm, 0.5rem);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  background: var(--color-surface-2);
}
.pt-attachment-list__name {
  flex: 1 1 auto;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.pt-attachment-list__size, .pt-attachment-list__counter, .pt-attachment-list__uploads-disabled {
  color: var(--color-text-muted);
  font-size: var(--text-sm);
}
.pt-attachment-list__size {
  flex: 0 0 auto;
}
.pt-bid-questionnaire {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-lg);
}
.pt-questionnaire-runner {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-lg);
}
.pt-questionnaire-runner__progress {
  max-width: 28rem;
}
.pt-questionnaire-runner__deadline {
  display: inline-flex;
  align-items: baseline;
  gap: var(--spacing-sm);
  padding: var(--spacing-sm) var(--spacing-md);
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  font-size: var(--text-sm);
}
.pt-questionnaire-runner__deadline-label {
  color: var(--color-text-secondary);
}
.pt-questionnaire-runner__deadline-time {
  font-variant-numeric: tabular-nums;
  font-weight: 600;
  color: var(--color-text-primary);
}
.pt-active-section {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-md);
}
.pt-active-section__heading {
  display: flex;
  align-items: baseline;
  flex-wrap: wrap;
  gap: var(--spacing-sm);
}
.pt-active-section__title {
  margin: 0;
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--color-text-secondary);
  text-transform: uppercase;
  letter-spacing: 0.04em;
}
.pt-active-section__number {
  margin-right: var(--spacing-xs);
  color: var(--color-text-muted);
  font-variant-numeric: tabular-nums;
}
.pt-active-section__ref {
  font-size: var(--text-xs);
  font-weight: 500;
  text-transform: none;
  letter-spacing: normal;
  color: var(--color-text-muted);
  padding: 0 var(--spacing-xs);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
}
.pt-active-section__questions {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-md);
}
.pt-active-section__subsections {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-md);
}
.pt-active-section--nested {
  margin-left: var(--spacing-md);
  padding-left: var(--spacing-md);
  border-left: 2px solid var(--color-border);
}
.pt-active-section--nested .pt-active-section__title {
  text-transform: none;
  letter-spacing: normal;
  color: var(--color-text-muted);
}
.pt-question-answer {
  padding: var(--spacing-md);
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
}
.pt-question-answer__header {
  display: flex;
  align-items: center;
  gap: var(--spacing-sm);
  margin-bottom: var(--spacing-sm);
}
.pt-question-answer__header .pt-label {
  flex: 1 1 auto;
  min-width: 0;
  margin-bottom: 0;
}
.pt-question-answer__number {
  flex: 0 0 auto;
  font-size: var(--text-xs);
  font-weight: 600;
  color: var(--color-text-muted);
  font-variant-numeric: tabular-nums;
}
.pt-question-answer__ref {
  flex: 0 0 auto;
  font-size: var(--text-xs);
  color: var(--color-text-muted);
  padding: 0 var(--spacing-xs);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
}
.pt-question-answer__current-file {
  margin-bottom: var(--spacing-xs);
  font-size: var(--text-xs);
  color: var(--color-text-muted);
}
.pt-questionnaire-runner__submit {
  display: flex;
  justify-content: flex-end;
  padding-top: var(--spacing-md);
  border-top: 1px solid var(--color-border);
}
.pt-bidding-period {
  background: var(--color-surface, #fff);
  border: 1px solid oklch(91% 0 0);
  border-radius: 0.5rem;
  padding: 1.5rem 1.75rem;
}
.pt-bidding-period__bar {
  position: relative;
  padding-top: 3.375rem;
}
.pt-bidding-period__marker {
  position: absolute;
  top: 0;
  width: 0;
}
.pt-bidding-period__status {
  position: absolute;
  top: 0;
  left: 0;
  white-space: nowrap;
  background: #343c48;
  color: #fff;
  font-size: 0.8125rem;
  font-weight: 600;
  padding: 0.5rem 0.75rem;
  border-radius: 0.375rem;
  border-bottom-left-radius: 0;
}
.pt-bidding-period__marker--right .pt-bidding-period__status {
  left: auto;
  right: 0;
  border-bottom-left-radius: 0.375rem;
  border-bottom-right-radius: 0;
}
.pt-bidding-period__status::after {
  content: "";
  position: absolute;
  top: 100%;
  left: 0;
  width: 0;
  height: 0;
  border-top: 8px solid #343c48;
  border-right: 10px solid transparent;
}
.pt-bidding-period__marker--right .pt-bidding-period__status::after {
  left: auto;
  right: 0;
  border-right: 0;
  border-left: 10px solid transparent;
}
.pt-bidding-period__track {
  height: 1.25rem;
  background: oklch(94% 0 0);
  border-radius: 0.375rem;
  overflow: hidden;
}
.pt-bidding-period__fill {
  height: 100%;
  background: oklch(64% 0.21 25);
  border-radius: inherit;
  transition: width 0.3s ease;
}
.pt-bidding-period__ruler {
  position: relative;
  height: 1.25rem;
  margin-top: 0.375rem;
}
.pt-bidding-period__tick {
  position: absolute;
  top: 0;
  transform: translateX(-50%);
  font-size: 0.75rem;
  color: oklch(45% 0 0);
  white-space: nowrap;
}
.pt-bidding-period__tick:first-child {
  transform: translateX(0);
}
.pt-bidding-period__tick:last-child {
  transform: translateX(-100%);
}
.pt-bidding-period__dates {
  display: flex;
  justify-content: space-between;
  gap: 0.75rem;
  margin-top: 1rem;
}
.pt-bidding-period__date {
  position: relative;
  display: flex;
  align-items: center;
  gap: 0.375rem;
  font-size: 0.8125rem;
  padding: 0.5rem 0.75rem;
  border-radius: 0.375rem;
}
.pt-bidding-period__date::before {
  content: "";
  position: absolute;
  top: -8px;
  width: 0;
  height: 0;
  border-bottom: 8px solid;
  border-bottom-color: inherit;
}
.pt-bidding-period__date--start {
  background: oklch(95% 0.05 155);
  border-bottom-color: oklch(95% 0.05 155);
  border-top-left-radius: 0;
}
.pt-bidding-period__date--start::before {
  left: 0;
  border-right: 10px solid transparent;
}
.pt-bidding-period__date--end {
  background: oklch(95% 0.04 25);
  border-bottom-color: oklch(95% 0.04 25);
  border-top-right-radius: 0;
}
.pt-bidding-period__date--end::before {
  right: 0;
  border-left: 10px solid transparent;
}
.pt-bidding-period__date-label {
  color: oklch(45% 0 0);
}
.pt-bidding-period__date-value {
  color: oklch(25% 0 0);
}
.pt-bidding-period__empty {
  color: oklch(55% 0 0);
  font-size: 0.875rem;
  padding: 1rem 0;
}
.bids-comparison-component {
  position: relative;
  font-family: var(--font-sans, "Inter", system-ui, sans-serif);
}
.bids-comparison-chart-scroll {
  width: 100%;
  max-height: 600px;
  overflow-y: auto;
}
.bids-comparison-canvas {
  width: 100%;
  min-height: 600px;
  overflow: hidden;
}
.bids-comparison-legend {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(max(10rem, (100% - 1.5rem) / 3), 1fr));
  gap: 0.125rem 0.75rem;
  align-items: start;
  padding: 0.75rem 0.5rem 0.25rem;
  margin-top: 0.5rem;
  border-top: 1px solid var(--color-border, #e5e7eb);
}
.bids-comparison-legend__item {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  min-width: 0;
  padding: 0.25rem 0.375rem;
  border: 0;
  border-radius: var(--radius-sm, 0.25rem);
  background: none;
  color: var(--color-text, #1f2937);
  font-size: 0.8125rem;
  line-height: 1.3;
  text-align: left;
  cursor: pointer;
  transition: background-color 0.12s ease, opacity 0.12s ease;
}
.bids-comparison-legend__item:hover {
  background: var(--color-surface-hover, rgba(0, 0, 0, 0.04));
}
.bids-comparison-legend__swatch {
  flex: none;
  width: 0.75rem;
  height: 0.75rem;
  border-radius: 3px;
}
.bids-comparison-legend__label {
  overflow: hidden;
  white-space: nowrap;
  text-overflow: ellipsis;
}
.bids-comparison-legend__item.is-hidden {
  opacity: 0.45;
}
.bids-comparison-legend__item.is-hidden .bids-comparison-legend__label {
  text-decoration: line-through;
}
.bids-comparison-toolbar {
  display: flex;
  align-items: center;
  gap: 1rem;
  padding: 0.5rem 0;
  flex-wrap: wrap;
}
.bids-comparison-toggle {
  display: inline-flex;
  border: 1px solid var(--color-border, var(--color-border));
  border-radius: var(--radius-md, 0.375rem);
  overflow: hidden;
}
.bids-comparison-toggle__btn {
  display: inline-flex;
  align-items: center;
  gap: 0.375rem;
  padding: 0.375rem 0.75rem;
  border: none;
  background: var(--color-surface, var(--color-surface));
  color: var(--color-text, var(--color-text-primary));
  font-size: 0.8125rem;
  font-weight: 500;
  cursor: pointer;
  transition: background 0.15s, color 0.15s;
  line-height: 1.4;
  font-family: inherit;
}
.bids-comparison-toggle__btn:hover {
  background: var(--color-surface-alt, var(--color-surface-2));
}
.bids-comparison-toggle__btn.is-active {
  background: var(--color-brand, var(--color-brand));
  color: var(--color-surface);
}
.bids-comparison-toggle__btn + .bids-comparison-toggle__btn {
  border-left: 1px solid var(--color-border, var(--color-border));
}
.bids-comparison-toolbar__right {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  flex-wrap: wrap;
  margin-left: auto;
}
.bids-comparison-controls {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  flex-wrap: wrap;
}
.bids-comparison-controls__label {
  font-size: 0.75rem;
  color: var(--color-muted, var(--color-text-muted));
  text-transform: uppercase;
  letter-spacing: 0.04em;
  font-weight: 600;
  white-space: nowrap;
}
.bids-comparison-sort-wrap {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
}
.bids-comparison-sort-wrap::before {
  content: "";
  display: inline-block;
  width: 1px;
  height: 1.25rem;
  background: var(--color-border, var(--color-border));
  margin-right: 0.25rem;
}
.bids-comparison-values-toggle, .bids-comparison-variance-toggle {
  display: inline-flex;
  align-items: center;
  gap: 0.375rem;
  padding: 0.375rem 0.625rem;
  border: 1px solid var(--color-border, var(--color-border));
  border-radius: var(--radius-md, 0.375rem);
  background: var(--color-surface, var(--color-surface));
  color: var(--color-text-muted, var(--color-text-muted));
  font-size: 0.8125rem;
  font-weight: 500;
  cursor: pointer;
  transition: border-color 0.15s, background 0.15s, color 0.15s;
  font-family: inherit;
  line-height: 1.4;
  white-space: nowrap;
}
.bids-comparison-values-toggle .pt-icon, .bids-comparison-variance-toggle .pt-icon {
  font-size: 0.85rem;
  opacity: 0.7;
}
.bids-comparison-values-toggle:hover {
  border-color: var(--color-brand, var(--color-brand));
  color: var(--color-brand, var(--color-brand));
}
.bids-comparison-values-toggle.is-active {
  background: var(--color-brand, var(--color-brand));
  border-color: var(--color-brand, var(--color-brand));
  color: var(--color-surface);
}
.bids-comparison-values-toggle.is-active .pt-icon {
  opacity: 1;
}
.bids-comparison-variance-toggle:hover {
  border-color: var(--color-info);
  color: var(--color-info);
}
.bids-comparison-variance-toggle.is-active {
  background: var(--color-info);
  border-color: var(--color-info);
  color: var(--color-surface);
}
.bids-comparison-variance-toggle.is-active .pt-icon {
  opacity: 1;
}
.bids-comparison-variance-toggle.is-unavailable, .bids-comparison-variance-toggle:disabled {
  opacity: 0.35;
  cursor: not-allowed;
  pointer-events: none;
}
.bids-comparison-dropdown-wrap {
  position: relative;
}
.bids-comparison-dropdown-trigger {
  display: inline-flex;
  align-items: center;
  gap: 0.375rem;
  padding: 0.375rem 0.625rem;
  border: 1px solid var(--color-border, var(--color-border));
  border-radius: var(--radius-md, 0.375rem);
  background: var(--color-surface, var(--color-surface));
  color: var(--color-text, var(--color-text-primary));
  font-size: 0.8125rem;
  font-weight: 500;
  cursor: pointer;
  transition: border-color 0.15s, box-shadow 0.15s;
  font-family: inherit;
  line-height: 1.4;
}
.bids-comparison-dropdown-trigger:hover, .bids-comparison-dropdown-trigger.is-active {
  border-color: var(--color-brand, var(--color-brand));
  box-shadow: 0 0 0 1px var(--color-brand, var(--color-brand));
}
.bids-comparison-dropdown-trigger > span {
  overflow: hidden;
  white-space: nowrap;
  text-overflow: ellipsis;
}
.bids-comparison-dropdown-trigger [data-bids-comparison-target="referenceLabel"], .bids-comparison-dropdown-trigger .bc-view-mode-label {
  max-width: 8rem;
}
.bids-comparison-dropdown-trigger .pt-icon:not(:first-child) {
  font-size: 0.75rem;
  opacity: 0.5;
  transition: transform 0.2s;
}
.bids-comparison-dropdown-trigger.is-active .pt-icon:not(:first-child) {
  transform: rotate(180deg);
}
.bids-comparison-dropdown {
  display: none;
  position: absolute;
  top: calc(100% + 4px);
  left: 0;
  min-width: 10rem;
  padding: 0.25rem 0;
  margin: 0;
  list-style: none;
  background: var(--color-surface, var(--color-surface));
  border: 1px solid var(--color-border, var(--color-border));
  border-radius: var(--radius-md, 0.375rem);
  box-shadow: var(--shadow-card, 0 4px 12px rgba(0, 0, 0, 0.1));
  z-index: 100;
}
.bids-comparison-dropdown.is-open {
  display: block;
}
.bids-comparison-dropdown li {
  list-style: none;
}
.bids-comparison-dropdown button {
  display: block;
  width: 100%;
  padding: 0.375rem 0.75rem;
  border: none;
  background: none;
  color: var(--color-text, var(--color-text-primary));
  font-size: 0.8125rem;
  text-align: left;
  cursor: pointer;
  font-family: inherit;
  transition: background 0.1s;
}
.bids-comparison-dropdown button:hover {
  background: var(--color-surface-alt, var(--color-surface-2));
}
.bids-comparison-search {
  display: inline-flex;
  align-items: center;
  gap: 0.25rem;
  padding: 0 0.5rem;
  border: 1px solid var(--color-border, var(--color-border));
  border-radius: var(--radius-md, 0.375rem);
  background: var(--color-surface, var(--color-surface));
  transition: border-color 0.15s, box-shadow 0.15s;
  flex: 0 1 11rem;
  min-width: 7rem;
}
.bids-comparison-search:focus-within {
  border-color: var(--color-brand, var(--color-brand));
  box-shadow: 0 0 0 1px var(--color-brand, var(--color-brand));
}
.bids-comparison-search__input {
  border: none;
  outline: none;
  background: transparent;
  font-size: 0.8125rem;
  font-family: inherit;
  font-weight: 500;
  color: var(--color-text, var(--color-text-primary));
  padding: 0.375rem 0;
  line-height: 1.4;
  width: 100%;
  min-width: 0;
}
.bids-comparison-search__input::placeholder {
  color: var(--color-text-muted, #9ca3af);
  font-weight: 400;
}
.bids-comparison-search__input::-webkit-search-cancel-button, .bids-comparison-search__input::-webkit-search-decoration {
  -webkit-appearance: none;
}
.bids-comparison-search__icon {
  display: flex;
  align-items: center;
  color: var(--color-text-muted, #9ca3af);
  flex-shrink: 0;
  pointer-events: none;
}
.bids-comparison-export__btn {
  display: inline-flex;
  align-items: center;
  padding: 0.375rem 0.625rem;
  background: none;
  border: 1px solid var(--color-border, var(--color-border));
  border-radius: var(--radius-md, 0.375rem);
  cursor: pointer;
}
.bids-comparison-breadcrumb {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.5rem;
  padding: 0.5rem 0;
}
.bids-comparison-breadcrumb__list {
  display: flex;
  align-items: center;
  gap: 0.25rem;
  list-style: none;
  padding: 0;
  margin: 0;
  font-size: 0.8125rem;
}
.bids-comparison-breadcrumb__list li {
  cursor: pointer;
  color: var(--color-brand, var(--color-brand));
  font-weight: 500;
  transition: color 0.15s;
}
.bids-comparison-breadcrumb__list li:hover {
  text-decoration: underline;
}
.bids-comparison-breadcrumb__list li + li::before {
  content: "›";
  margin-right: 0.375rem;
  color: var(--color-muted, var(--color-text-muted));
  cursor: default;
}
.bids-comparison-breadcrumb__list li.current {
  color: var(--color-text, var(--color-text-primary));
  cursor: default;
  font-weight: 600;
}
.bids-comparison-breadcrumb__list li.current:hover {
  text-decoration: none;
}
.bids-comparison-canvas {
  border-radius: var(--radius-md, 0.375rem);
}
.hidden {
  display: none !important;
}
.ag-charts-tooltip {
  background: rgba(255, 255, 255, 0.82) !important;
  backdrop-filter: blur(10px) !important;
  -webkit-backdrop-filter: blur(10px) !important;
  border: 1px solid rgba(0, 0, 0, 0.07) !important;
  box-shadow: 0 6px 24px rgba(0, 0, 0, 0.10) !important;
}
.ag-charts-tooltip > div {
  background: transparent !important;
}
.ag-charts-tooltip.bids-comparison-tooltip--panel {
  position: fixed !important;
  top: 80px !important;
  right: 16px !important;
  left: auto !important;
  translate: none !important;
  transform: none !important;
  max-width: 480px;
  background: rgba(255, 255, 255, 0.97) !important;
}
.bids-comparison-table-wrap.pt-ag-grid-container {
  height: clamp(20rem, calc(100vh - 26rem), 60rem);
}
.bids-comparison-table__category-cell {
  display: flex;
  align-items: center;
  gap: 0.25rem;
  width: 100%;
  height: 100%;
}
.bids-comparison-table__expand-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1.125rem;
  height: 1.125rem;
  padding: 0;
  border: 1px solid var(--color-border, #d1d5db);
  border-radius: 0.1875rem;
  background: var(--color-surface, #fff);
  color: var(--color-text, #111827);
  font-size: 0.875rem;
  line-height: 1;
  font-weight: 600;
  cursor: pointer;
  flex-shrink: 0;
  transition: background 0.1s, color 0.1s;
}
.bids-comparison-table__expand-btn:hover {
  background: var(--color-surface-2, #f3f4f6);
}
.bids-comparison-table__expand-spacer {
  display: inline-block;
  width: 1.125rem;
  flex-shrink: 0;
}
.bids-comparison-table__overall-row {
  font-weight: 600;
  background: oklch(96% 0.01 250) !important;
}
.bids-comparison-table__price-cell, .bids-comparison-table__pct-cell, .bids-comparison-table__cov-cell {
  text-align: right;
  font-variant-numeric: tabular-nums;
  font-size: 0.8125rem;
}
.bids-comparison-table-wrap .ag-cell {
  display: flex;
  align-items: center;
}
.bids-comparison-table-wrap .ag-header-cell-text, .bids-comparison-table-wrap .ag-header-group-cell-label {
  font-size: 0.6875rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}
.bids-comparison-table-wrap .ag-center-cols-container .ag-cell, .bids-comparison-table-wrap .ag-pinned-right-cols-container .ag-cell {
  justify-content: flex-end;
  text-align: right;
}
.bids-comparison-table-wrap .ag-pinned-left-cols-container .ag-cell {
  justify-content: flex-start;
  text-align: left;
}
.bc-chart-export-menu {
  display: flex;
  flex: none;
  align-items: center;
  position: relative;
  z-index: 20;
}
.bc-chart-export-menu__inner {
  position: relative;
}
.bc-chart-export-menu__btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
  padding: 0;
  border: 1px solid var(--color-border, #e2e8f0);
  border-radius: var(--radius-sm, 4px);
  background: var(--color-surface, #fff);
  color: var(--color-text-muted, #64748b);
  cursor: pointer;
  transition: background 0.15s, color 0.15s, border-color 0.15s;
  font-family: inherit;
}
.bc-chart-export-menu__btn:hover {
  background: var(--color-surface-alt, #f8fafc);
  color: var(--color-text, #1e293b);
  border-color: var(--color-brand, #3b82f6);
}
.bc-chart-export-menu__dropdown {
  display: none;
  position: fixed;
  min-width: 196px;
  padding: 4px 0;
  margin: 0;
  list-style: none;
  background: var(--color-surface, #fff);
  border: 1px solid var(--color-border, #e2e8f0);
  border-radius: var(--radius-md, 6px);
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.12);
  z-index: 1000;
}
.bc-chart-export-menu__dropdown.is-open {
  display: block;
}
.bc-chart-export-menu__dropdown li {
  list-style: none;
}
.bc-chart-export-menu__dropdown button {
  display: block;
  width: 100%;
  padding: 8px 16px;
  border: none;
  background: none;
  color: var(--color-text, #1e293b);
  font-size: 0.8125rem;
  text-align: left;
  cursor: pointer;
  font-family: inherit;
  transition: background 0.1s;
  line-height: 1.4;
}
.bc-chart-export-menu__dropdown button:hover {
  background: var(--color-surface-alt, #f8fafc);
}
.bc-chart-export-menu__sep {
  height: 1px;
  background: var(--color-border, #e2e8f0);
  margin: 4px 0;
}
.bids-comparison-status {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  padding: 2.5rem 1rem;
  color: var(--color-text-muted, #64748b);
  font-size: 0.875rem;
}
.bids-comparison-status__spinner {
  width: 1.25rem;
  height: 1.25rem;
  border: 2px solid var(--color-border, #e2e8f0);
  border-top-color: var(--color-primary, #2563eb);
  border-radius: 50%;
  animation: pt-spin 0.8s linear infinite;
}
.bids-comparison-status__retry {
  border: 1px solid var(--color-border, #e2e8f0);
  background: var(--color-surface, #fff);
  color: var(--color-text, #1e293b);
  border-radius: 0.375rem;
  padding: 0.25rem 0.75rem;
  font: inherit;
  font-size: 0.8125rem;
  cursor: pointer;
}
.bids-comparison-status__retry:hover {
  background: var(--color-surface-alt, #f8fafc);
}
.bc-ranking {
  font-family: var(--font-sans, "Inter", system-ui, sans-serif);
  padding: 0;
}
.bc-ranking__empty {
  padding: 2rem;
  text-align: center;
  color: var(--color-muted, var(--color-text-muted));
  font-size: 0.875rem;
}
.bc-ranking__scroll {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}
.bc-ranking__table {
  width: 100%;
  border-collapse: separate;
  border-spacing: 0;
  font-size: 0.8125rem;
  border: 1px solid oklch(91% 0 0);
  border-radius: 0.5rem;
  overflow: hidden;
}
.bc-ranking__header-row {
  background: oklch(97% 0.008 250);
}
.bc-ranking__corner {
  padding: 0.625rem 1rem;
  text-align: left;
  font-weight: 600;
  color: oklch(35% 0 0);
  font-size: 0.75rem;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  border-bottom: 2px solid oklch(88% 0.04 250);
  white-space: nowrap;
  min-width: 140px;
}
.bc-ranking__rank-header {
  padding: 0.625rem 0.75rem;
  text-align: center;
  border-bottom: 2px solid oklch(88% 0.04 250);
  min-width: 120px;
}
.bc-ranking__rank-header--sm {
  min-width: 56px;
}
.bc-ranking__rank-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
  border-radius: 50%;
  font-weight: 700;
  font-size: 0.8125rem;
  background: oklch(93% 0.06 250);
  color: oklch(35% 0.15 250);
}
.bc-ranking__rank-header:nth-child(2) .bc-ranking__rank-badge {
  background: oklch(88% 0.12 85);
  color: oklch(30% 0.14 85);
}
.bc-ranking__rank-header:nth-child(3) .bc-ranking__rank-badge {
  background: oklch(92% 0.02 250);
  color: oklch(35% 0.05 250);
}
.bc-ranking__rank-header:nth-child(4) .bc-ranking__rank-badge {
  background: oklch(88% 0.08 55);
  color: oklch(32% 0.10 55);
}
.bc-ranking__rank-badge--sm {
  width: 22px;
  height: 22px;
  font-size: 0.6875rem;
}
.bc-ranking__section-row {
  transition: background 0.12s ease;
}
.bc-ranking__section-row:hover {
  background: oklch(98% 0.01 250);
}
.bc-ranking__section-name {
  padding: 0.75rem 1rem;
  font-weight: 600;
  color: oklch(25% 0 0);
  white-space: nowrap;
  border-bottom: 1px solid oklch(95% 0 0);
  border-right: 1px solid oklch(91% 0 0);
}
.bc-ranking__section-name--total {
  font-weight: 700;
  text-transform: uppercase;
  font-size: 0.75rem;
  letter-spacing: 0.05em;
  color: oklch(30% 0.08 250);
  background: oklch(97% 0.015 250);
}
.bc-ranking__cell {
  padding: 0.625rem 0.75rem;
  text-align: center;
  border-bottom: 1px solid oklch(95% 0 0);
  vertical-align: middle;
}
.bc-ranking__price {
  display: block;
  font-weight: 600;
  font-size: 0.875rem;
  color: oklch(25% 0 0);
  line-height: 1.4;
}
.bc-ranking__bidder {
  display: block;
  font-size: 0.6875rem;
  color: oklch(50% 0.04 250);
  font-weight: 500;
  margin-top: 1px;
  line-height: 1.3;
}
.bc-ranking__cell--best {
  background: oklch(96% 0.06 145);
}
.bc-ranking__cell--best .bc-ranking__price {
  color: oklch(28% 0.12 145);
}
.bc-ranking__cell--best .bc-ranking__bidder {
  color: oklch(38% 0.10 145);
}
.bc-ranking__cell--winner {
  box-shadow: inset 3px 0 0 oklch(72% 0.16 85);
}
.bc-ranking__cell--empty {
  opacity: 0.4;
}
.bc-ranking__cell--total {
  background: oklch(97% 0.015 250);
  border-bottom: 2px solid oklch(88% 0.04 250);
  border-top: 2px solid oklch(88% 0.04 250);
}
.bc-ranking__cell--total .bc-ranking__price {
  font-weight: 700;
  color: oklch(30% 0.08 250);
}
.bc-ranking__frequency {
  margin-top: 1.5rem;
  padding-top: 1.25rem;
  border-top: 1px solid oklch(91% 0 0);
}
.bc-ranking__frequency-title {
  font-size: 0.9375rem;
  font-weight: 700;
  color: oklch(25% 0 0);
  margin: 0 0 0.25rem;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
}
.bc-ranking__frequency-icon {
  font-size: 1rem;
}
.bc-ranking__frequency-desc {
  font-size: 0.75rem;
  color: oklch(55% 0.03 250);
  margin: 0 0 0.75rem;
  text-align: center;
}
.bc-ranking__freq-block {
  width: fit-content;
  max-width: 100%;
  margin-inline: auto;
  overflow-x: auto;
}
.bc-ranking__table--frequency {
  max-width: 600px;
}
.bc-ranking__freq-row {
  transition: background 0.12s ease;
}
.bc-ranking__freq-row:hover {
  background: oklch(98% 0.01 250);
}
.bc-ranking__freq-row--winner {
  background: oklch(97% 0.03 85);
}
.bc-ranking__freq-row--winner:hover {
  background: oklch(96% 0.05 85);
}
.bc-ranking__freq-bidder {
  padding: 0.5rem 1rem;
  font-weight: 600;
  font-size: 0.8125rem;
  color: oklch(25% 0 0);
  white-space: nowrap;
  border-bottom: 1px solid oklch(95% 0 0);
  border-right: 1px solid oklch(91% 0 0);
}
.bc-ranking__freq-cell {
  padding: 0.5rem 0.625rem;
  text-align: center;
  border-bottom: 1px solid oklch(95% 0 0);
  vertical-align: middle;
}
.bc-ranking__freq-count {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
  border-radius: 6px;
  font-weight: 600;
  font-size: 0.8125rem;
  background: oklch(95% 0.02 250);
  color: oklch(30% 0.05 250);
}
.bc-ranking__freq-count--zero {
  background: transparent;
  color: oklch(78% 0.02 250);
  font-weight: 400;
}
.bc-ranking__freq-cell--top .bc-ranking__freq-count {
  background: oklch(88% 0.12 85);
  color: oklch(25% 0.14 85);
  font-weight: 700;
}
.bc-ranking__freq-cell--score {
  border-left: 1px solid oklch(91% 0 0);
}
.bc-ranking__freq-score {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 32px;
  height: 28px;
  padding: 0 8px;
  border-radius: 6px;
  font-weight: 700;
  font-size: 0.8125rem;
  background: oklch(93% 0.06 250);
  color: oklch(30% 0.15 250);
}
.bc-ranking__disclaimer {
  margin: 0.75rem 0 1.5rem;
  padding: 0.5rem 0.75rem;
  font-size: 0.6875rem;
  color: oklch(55% 0.03 250);
  background: oklch(98% 0.005 250);
  border-radius: 0.375rem;
  border: 1px solid oklch(93% 0.01 250);
  line-height: 1.5;
  width: 100%;
  max-width: none;
  box-sizing: border-box;
}
.bids-comparison-table-wrap.pt-ag-grid-container.bids-comparison-table-wrap--ranking {
  height: auto;
}
.bc-ranking__grid {
  width: 100%;
  height: clamp(360px, 60vh, 760px);
  font-family: var(--font-sans, "Inter", system-ui, sans-serif);
}
.bc-ranking__grid .ag-cell {
  line-height: 1.4;
}
.bc-ranking__grid .ag-cell.bc-ranking__cell {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 0.5rem 0.75rem;
  border: none;
  text-align: center;
}
.bc-ranking__cell-content {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 1px;
  width: 100%;
}
.bc-ranking__grid .ag-cell.bc-ranking__cell--best {
  background: oklch(96% 0.06 145);
}
.bc-ranking__grid .ag-cell.bc-ranking__cell--total {
  background: oklch(97% 0.015 250);
}
.bc-ranking__grid .ag-cell.bc-ranking__cell--empty {
  opacity: 0.4;
}
.bc-ranking__grid .ag-cell.bc-ranking__cell--winner {
  box-shadow: inset 3px 0 0 oklch(72% 0.16 85);
}
.bc-ranking__grid .bc-ranking__bidder {
  white-space: normal;
  overflow-wrap: anywhere;
}
.bc-ranking__grid .bc-ranking__section-name {
  display: flex;
  align-items: center;
  white-space: normal;
  overflow-wrap: anywhere;
  line-height: 1.35;
}
.bc-ranking__rank-col-header {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
}
.bc-ranking__rank-badge--gold {
  background: oklch(88% 0.12 85);
  color: oklch(30% 0.14 85);
}
.bc-ranking__rank-badge--silver {
  background: oklch(92% 0.02 250);
  color: oklch(35% 0.05 250);
}
.bc-ranking__rank-badge--bronze {
  background: oklch(88% 0.08 55);
  color: oklch(32% 0.10 55);
}
.pt-owner-actions {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: flex-end;
  gap: 0.5rem;
}
.pt-owner-actions .pt-btn--secondary {
  background: oklch(88% 0 0);
}
.pt-owner-actions .pt-btn--secondary:hover {
  background: oklch(82% 0 0);
}
.pt-owner-action__footer {
  display: flex;
  justify-content: flex-end;
  gap: 0.5rem;
  margin-top: 1.5rem;
}
.pt-owner-action__warning, .pt-repost-tender__warning {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.75rem;
  border-radius: 0.375rem;
  background: var(--color-warning-50, #fff7ed);
  color: var(--color-warning-700, #b45309);
  margin-bottom: 1rem;
}
.pt-repost-tender__heading {
  margin: 1rem 0 0.5rem;
  font-weight: 600;
}
.pt-owner-action__intro {
  margin: 0 0 1.25rem;
  font-size: 0.875rem;
  line-height: 1.55;
  color: var(--pt-text-secondary, var(--color-text-secondary));
}
.pt-repost-tender__list {
  list-style: none;
  margin: 0 0 1.25rem;
  padding: 0;
  color: var(--pt-text-secondary, var(--color-text-secondary));
  font-size: 0.875rem;
  line-height: 1.65;
}
.pt-repost-tender__list li + li {
  margin-top: 0.25rem;
}
.pt-owner-action__errors:not(:empty) {
  margin-bottom: 1.25rem;
}
.pt-owner-action__error-list {
  margin: 0;
  padding-left: 1.125rem;
  font-size: 0.875rem;
  line-height: 1.55;
}
.pt-field-error {
  margin: 0.25rem 0 0;
  font-size: 0.75rem;
  line-height: 1.4;
  color: var(--color-danger, #dc2626);
}
.pt-post-tender .pt-alert {
  margin-bottom: 1.5rem;
}
.pt-post-tender .pt-tender-section {
  margin-bottom: 1.5rem;
}
.pt-review {
  list-style: none;
  margin: 0;
  padding: 0;
  border: 1px solid var(--pt-border, var(--color-border));
  border-radius: 0.375rem;
}
.pt-review__row {
  display: flex;
  align-items: center;
  gap: 1rem;
  padding: 0.875rem 1rem;
}
.pt-review__row + .pt-review__row {
  border-top: 1px solid var(--pt-border, var(--color-border));
}
.pt-review__text {
  flex: 1 1 auto;
  min-width: 0;
  font-size: 0.875rem;
  line-height: 1.6;
  color: var(--pt-text-secondary, var(--color-text-secondary));
}
.pt-review__text strong {
  color: var(--pt-text-primary, var(--color-text-primary));
  font-weight: 600;
}
.pt-review__change {
  flex: 0 0 auto;
}
.pt-doc-list {
  list-style: none;
  margin: 0;
  padding: 0;
  border: 1px solid var(--pt-border, var(--color-border));
  border-radius: 0.375rem;
}
.pt-doc-list__item {
  display: flex;
  align-items: center;
  gap: 0.625rem;
  padding: 0.625rem 1rem;
  font-size: 0.875rem;
}
.pt-doc-list__item + .pt-doc-list__item {
  border-top: 1px solid var(--pt-border, var(--color-border));
}
.pt-doc-list__icon {
  flex: 0 0 auto;
  color: var(--pt-text-muted, #9ca3af);
}
.pt-doc-list__title {
  flex: 1 1 auto;
  min-width: 0;
  color: var(--pt-text-primary, var(--color-text-primary));
  overflow-wrap: anywhere;
}
.pt-doc-list__version {
  flex: 0 0 auto;
  font-size: 0.6875rem;
  font-weight: 600;
  letter-spacing: 0.03em;
  color: var(--pt-text-secondary, var(--color-text-secondary));
  background: var(--pt-surface-muted, #f3f4f6);
  border-radius: 9999px;
  padding: 0.125rem 0.5rem;
}
.pt-post-tender__advert {
  margin: 0;
  font-size: 0.875rem;
  line-height: 1.7;
  color: var(--pt-text-secondary, var(--color-text-secondary));
}
.pt-post-tender__advert strong {
  color: var(--pt-text-primary, var(--color-text-primary));
  font-weight: 600;
}
.pt-bidding-fields {
  margin-bottom: 1.25rem;
}
.pt-bidding-fields .pt-field + .pt-field {
  margin-top: 1.25rem;
}
.pt-bidding-fields__input {
  display: block;
  width: 100%;
}
[data-bidding-period-target="startField"]:not([hidden]) {
  margin-top: 0.625rem;
}
.pt-bidding-toggle {
  display: inline-flex;
  align-self: flex-start;
  width: fit-content;
  border: 1px solid var(--pt-border, var(--color-border));
  border-radius: 0.375rem;
  overflow: hidden;
  background: var(--pt-surface-muted, #f3f4f6);
}
.pt-bidding-toggle__option {
  position: relative;
  display: inline-flex;
  margin: 0;
}
.pt-bidding-toggle__option + .pt-bidding-toggle__option {
  border-left: 1px solid var(--pt-border, var(--color-border));
}
.pt-bidding-toggle__input {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  margin: 0;
  opacity: 0;
  cursor: pointer;
}
.pt-bidding-toggle__label {
  display: inline-flex;
  align-items: center;
  gap: 0.375rem;
  padding: 0.375rem 0.75rem;
  font-size: 0.8125rem;
  font-weight: 500;
  color: var(--pt-text-secondary, var(--color-text-secondary));
  cursor: pointer;
  transition: background 0.12s ease, color 0.12s ease;
}
.pt-bidding-toggle__label:hover {
  background: var(--pt-surface, #fff);
}
.pt-bidding-toggle__input:checked + .pt-bidding-toggle__label {
  background: var(--pt-primary, var(--color-primary, #047857));
  color: #fff;
}
.pt-bidding-toggle__input:focus-visible + .pt-bidding-toggle__label {
  outline: 2px solid var(--pt-primary, var(--color-primary, #047857));
  outline-offset: -2px;
}
.pt-bidding-toggle__icon {
  flex: 0 0 auto;
}
.pt-input:disabled {
  background: var(--pt-surface-muted, #f3f4f6);
  color: var(--pt-text-muted, #9ca3af);
  cursor: not-allowed;
}
.pt-hint {
  margin: 0.375rem 0 0;
  font-size: 0.75rem;
  color: var(--pt-text-muted, #6b7280);
}
.pt-label--required::after {
  content: " *";
  color: var(--color-danger, #dc2626);
}
.pt-bids-page {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}
.pt-bids-page__header {
  display: flex;
  flex-direction: row;
  align-items: flex-end;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 0.75rem 1.5rem;
}
.pt-bids-page__header-main {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 0.5rem;
  min-width: 0;
}
.pt-bids-page__actions {
  flex: 0 0 auto;
  margin-left: auto;
}
.pt-bids-page__title {
  font-size: 1rem;
  font-weight: 600;
  color: var(--pt-color-text);
  margin: 0;
}
.pt-bids-page__meta {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  flex-wrap: wrap;
}
.pt-bids-page__dates {
  font-size: 0.8125rem;
  color: var(--pt-color-text-muted, #6b7280);
}
.pt-bids-page__meta .pt-status-badge {
  font-size: 0.6875rem;
}
.pt-bids-section-header {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  margin-bottom: 0.5rem;
}
.pt-bids-section-title {
  font-size: 0.9375rem;
  font-weight: 600;
  color: var(--pt-color-text);
  margin: 0;
}
.pt-bids-summary .pt-ag-grid-container {
  height: auto;
  padding-bottom: 1rem;
}
.pt-bids-summary .ag-layout-auto-height, .pt-bids-summary .ag-layout-auto-height .ag-center-cols-viewport, .pt-bids-summary .ag-layout-auto-height .ag-center-cols-container {
  min-height: 0;
}
.pt-bids-summary-grid__cell {
  display: flex;
  align-items: center;
  height: 100%;
}
.pt-bids-documents__grid .ag-pinned-left-cols-container .ag-cell {
  overflow: hidden;
}
.pt-bids-documents {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}
.pt-bids-documents__grid.pt-ag-grid-container {
  height: clamp(20rem, calc(100vh - 26rem), 52rem);
}
.pt-docs-grid__link {
  color: var(--pt-color-primary, #1d4ed8);
  text-decoration: none;
  font-size: 0.8125rem;
}
.pt-docs-grid__link:hover {
  text-decoration: underline;
}
.pt-bids-summary-grid .ag-header-cell-text, .pt-bids-documents__grid .ag-header-cell-text, .pt-bids-summary-grid .ag-header-group-cell-label, .pt-bids-documents__grid .ag-header-group-cell-label {
  font-size: 0.6875rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}
.pt-bids-summary-grid .ag-header-cell, .pt-bids-documents__grid .ag-header-cell, .bids-comparison-table-wrap .ag-header-cell {
  justify-content: center;
}
.pt-bids-summary-grid .ag-header-cell-label, .pt-bids-documents__grid .ag-header-cell-label, .bids-comparison-table-wrap .ag-header-cell-label {
  justify-content: center;
}
.pt-bids-summary-grid .ag-cell, .pt-bids-documents__grid .ag-cell {
  display: flex;
  align-items: center;
}
.pt-ag-cell--right {
  justify-content: flex-end !important;
  text-align: right;
}
.pt-ag-cell--center {
  justify-content: center !important;
  text-align: center;
}
.pt-bids-summary-grid .ag-header-group-cell, .pt-bids-summary-grid .ag-header-cell, .pt-bids-summary-grid .ag-cell {
  border-right: 1px solid var(--ag-border-color, #e5e7eb) !important;
}
.pt-bids-summary-grid .pt-bids-bidder-cell {
  white-space: normal;
  line-height: 1.25;
  word-break: break-word;
}
.pt-docs-cell {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex: 1;
  min-width: 0;
  overflow: hidden;
  gap: 0.5rem;
}
.pt-docs-status {
  font-size: 0.8125rem;
  font-weight: 600;
  white-space: nowrap;
  flex-shrink: 0;
}
.pt-docs-status--accepted {
  color: var(--pt-color-success, #15803d);
}
.pt-docs-status--received {
  color: var(--pt-color-danger, #b91c1c);
}
.pt-docs-grid__dl-btn {
  display: inline-flex;
  align-items: center;
  flex-shrink: 0;
  color: var(--pt-color-text-muted, #6b7280);
  line-height: 1;
}
.pt-docs-grid__dl-btn:hover {
  color: var(--pt-color-primary, #1d4ed8);
}
.pt-docs-grid__dl-all {
  display: inline-flex;
  align-items: center;
  flex-shrink: 0;
  color: currentColor;
  opacity: 0.55;
  line-height: 1;
}
.pt-docs-grid__dl-all:hover {
  opacity: 1;
}
.pt-score--high {
  color: var(--pt-color-success, #15803d);
  font-weight: 600;
}
.pt-score--low {
  color: var(--pt-color-danger, #b91c1c);
  font-weight: 600;
}
.pt-bidders-panel {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}
.pt-bidders-posting__select {
  width: 100%;
  font-size: 0.8125rem;
  padding: 0.3125rem 0.5rem;
  border: 1px solid var(--pt-color-border, #d1d5db);
  border-radius: 0.375rem;
  background: var(--pt-color-surface, #fff);
  color: var(--pt-color-text);
  cursor: pointer;
}
.pt-bidders-controls {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.375rem 0;
  border-bottom: 1px solid var(--pt-color-border, #e5e7eb);
}
.pt-bidders-controls__revoked {
  display: flex;
  align-items: center;
  gap: 0.3125rem;
  flex: 1;
  cursor: pointer;
  user-select: none;
}
.pt-bidders-controls__revoked--disabled {
  opacity: 0.45;
  cursor: not-allowed;
}
.pt-bidders-controls__revoked-input {
  width: 0.875rem;
  height: 0.875rem;
  accent-color: var(--pt-color-primary, #1d4ed8);
  cursor: inherit;
  flex-shrink: 0;
}
.pt-bidders-controls__revoked-label {
  font-size: 0.75rem;
  color: var(--pt-color-text-muted, #6b7280);
  line-height: 1.2;
}
.pt-bidders-controls__sort {
  flex-shrink: 0;
  max-width: 9.5rem;
  font-size: 0.75rem;
  padding: 0.25rem 0.5rem;
  border: 1px solid var(--pt-color-border, #d1d5db);
  border-radius: 0.375rem;
  background: var(--pt-color-surface, #fff);
  color: var(--pt-color-text);
  cursor: pointer;
}
.pt-bidders-list {
  display: flex;
  flex-direction: column;
  gap: 0.0625rem;
}
.pt-bidder-item {
  border-radius: 0.375rem;
  border-top: 1px solid var(--pt-color-border, #e5e7eb);
  transition: background 0.1s;
}
.pt-bidders-list > .pt-bidder-item:first-child {
  border-top: none;
}
.pt-bidder-item--winner {
  background: var(--pt-color-success-light, #f0fdf4);
}
.pt-bidder-item--revoked {
  opacity: 0.6;
}
.pt-bidder-item--revoked-group {
  display: flex;
  flex-direction: column;
  gap: 0;
}
.pt-bidder-item__label {
  display: flex;
  align-items: flex-start;
  gap: 0.375rem;
  padding: 0.5625rem 0.375rem 0.3125rem;
  cursor: pointer;
  border-radius: 0.375rem;
}
.pt-bidder-item__label:hover {
  background: var(--pt-color-surface-hover, #f3f4f6);
}
.pt-bidder-item--winner .pt-bidder-item__label:hover {
  background: #dcfce7;
}
.pt-bidder-item__check {
  position: relative;
  flex-shrink: 0;
  width: 1rem;
  height: 1rem;
  margin-top: 0.125rem;
}
.pt-bidder-item__input {
  position: absolute;
  opacity: 0;
  width: 100%;
  height: 100%;
  margin: 0;
  cursor: pointer;
}
.pt-bidder-item__checkmark {
  position: relative;
  display: block;
  width: 1rem;
  height: 1rem;
  border: 1.5px solid var(--pt-color-border, #d1d5db);
  border-radius: 0.25rem;
  background: var(--pt-color-surface, #fff);
  transition: background 0.1s, border-color 0.1s;
}
.pt-bidder-item__input:checked + .pt-bidder-item__checkmark {
  background: var(--pt-color-primary, #1d4ed8);
  border-color: var(--pt-color-primary, #1d4ed8);
}
.pt-bidder-item__input:checked + .pt-bidder-item__checkmark::after {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  width: 0.3125rem;
  height: 0.5625rem;
  border: 2px solid #fff;
  border-top: none;
  border-left: none;
  transform: translate(-50%, -60%) rotate(45deg);
}
.pt-bidder-item__body {
  display: flex;
  flex-direction: column;
  gap: 0.0625rem;
  min-width: 0;
  flex: 1;
}
.pt-bidder-item__body--indented {
  padding-left: 1.375rem;
}
.pt-bidder-item__name {
  font-size: 0.8125rem;
  font-weight: 600;
  color: var(--pt-color-text);
  overflow-wrap: anywhere;
  line-height: 1.3;
}
.pt-bidder-item__name--stat {
  font-weight: 500;
  color: var(--pt-color-text-muted, #6b7280);
  font-style: italic;
}
.pt-bidder-item__meta {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 0.0625rem;
}
.pt-bidder-item__status {
  font-size: 0.6875rem;
  font-weight: 600;
  letter-spacing: 0.01em;
}
.pt-bidder-item__status--submitted {
  color: var(--pt-color-success, #15803d);
}
.pt-bidder-item__status--revoked {
  color: var(--pt-color-danger, #b91c1c);
}
.pt-bidder-item__amount {
  font-size: 0.75rem;
  color: var(--pt-color-text-muted, #6b7280);
}
.pt-boq-detail-page {
  display: flex;
  flex-direction: column;
  gap: 0.875rem;
}
.pt-boq-header {
  display: flex;
  flex-direction: column;
  gap: 0.875rem;
  padding: 1rem 1.125rem;
  border: 1px solid var(--color-surface-3);
  border-radius: var(--radius-md, 0.5rem);
  background: var(--color-surface);
  box-shadow: 0 1px 2px rgb(15 23 42 / 4%);
}
.pt-boq-header__top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
}
.pt-boq-header__back {
  display: inline-flex;
  align-items: center;
  gap: 0.375rem;
  min-height: 2.25rem;
  color: var(--color-brand);
  font-size: 0.8125rem;
  font-weight: 600;
  text-decoration: none;
}
.pt-boq-header__back:hover {
  text-decoration: underline;
}
.pt-boq-header__back-icon {
  width: 0.95rem;
  height: 0.95rem;
}
.pt-boq-header__actions {
  display: inline-flex;
  flex-direction: row;
  align-items: center;
  justify-content: flex-end;
  gap: 0.75rem;
}
.pt-boq-header__actions .pt-btn {
  min-height: 2.25rem;
  padding-inline: 0.8rem;
  border: 1px solid var(--color-surface-3);
  border-radius: var(--radius-sm, 0.25rem);
  background: var(--color-surface-2);
  color: var(--color-text-primary);
  font-weight: 600;
}
.pt-boq-header__actions .pt-btn:hover {
  background: color-mix(in srgb, oklch(45% 0.18 250) 5%, oklch(97% 0.005 250));
  @supports (color: color-mix(in lab, red, red)) {
    background: color-mix(in srgb, var(--color-brand) 5%, var(--color-surface-2));
  }
  border-color: color-mix(in srgb, oklch(45% 0.18 250) 18%, oklch(94% 0.005 250));
  @supports (color: color-mix(in lab, red, red)) {
    border-color: color-mix(in srgb, var(--color-brand) 18%, var(--color-surface-3));
  }
}
.pt-boq-header__selection-status {
  display: inline-flex;
  align-items: center;
  min-height: 2.25rem;
  margin: 0;
  padding: 0 0.75rem;
  border: 1px solid transparent;
  border-radius: var(--radius-sm, 0.25rem);
  color: var(--color-text-secondary);
  font-size: 0.75rem;
  font-weight: 500;
  white-space: nowrap;
  transition: color 120ms ease, background-color 120ms ease, border-color 120ms ease;
}
.pt-boq-header__selection-status--active {
  border-color: color-mix(in srgb, oklch(45% 0.18 250) 18%, oklch(94% 0.005 250));
  @supports (color: color-mix(in lab, red, red)) {
    border-color: color-mix(in srgb, var(--color-brand) 18%, var(--color-surface-3));
  }
  background: color-mix(in srgb, oklch(45% 0.18 250) 7%, oklch(99% 0 0));
  @supports (color: color-mix(in lab, red, red)) {
    background: color-mix(in srgb, var(--color-brand) 7%, var(--color-surface));
  }
  color: var(--color-brand);
  font-weight: 600;
}
.pt-boq-header__content {
  display: flex;
  flex-direction: column;
  gap: 0.55rem;
}
.pt-boq-header__title {
  margin: 0;
  color: var(--color-text-primary);
  font-size: 1.0625rem;
  font-weight: 700;
  line-height: 1.3;
  letter-spacing: 0.035em;
}
.pt-boq-header__meta {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.5rem;
}
.pt-boq-header__meta .pt-status-badge {
  min-height: 1.4rem;
  padding: 0.15rem 0.55rem;
  font-size: 0.6875rem;
  font-weight: 700;
}
.pt-boq-header__meta-item {
  color: var(--color-text-secondary);
  font-size: 0.8125rem;
  font-weight: 500;
  line-height: 1.45;
}
.pt-boq-header__meta-item::before {
  content: "|";
  margin-right: 0.5rem;
  color: var(--color-text-muted);
}
.pt-boq-header__menu {
  min-width: 8rem;
  margin: 0;
  padding: 0.3rem;
  list-style: none;
}
.pt-boq-header__menu-link {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.55rem;
  padding: 0.5rem 0.625rem;
  border-radius: var(--radius-sm, 0.25rem);
  color: var(--color-text-primary);
  font-size: 0.8125rem;
  font-weight: 500;
  text-decoration: none;
}
.pt-boq-header__menu-link:hover {
  background: var(--color-surface-2);
}
.pt-boq-header__selection-badge {
  color: var(--color-brand);
  font-size: 0.75rem;
  font-weight: 700;
}
.pt-boq-tabs {
  border-top: 1px solid transparent;
}
.pt-boq-table {
  max-height: min(68vh, 56rem);
  overflow: auto;
  border: 1px solid var(--color-surface-3);
  border-radius: var(--radius-md, 0.5rem);
  background: var(--color-surface);
  box-shadow: 0 1px 2px rgb(15 23 42 / 4%);
}
.pt-boq-table__head, .pt-boq-table__row {
  display: grid;
  grid-template-columns: minmax(27rem, 3.6fr) minmax(7.5rem, 1fr) minmax(6.5rem, 0.85fr) minmax(8rem, 1fr) minmax(6rem, 0.75fr);
  align-items: center;
  gap: 0.625rem;
  padding-inline: 0.9rem;
}
.pt-boq-table__head {
  position: sticky;
  top: 0;
  z-index: 2;
  min-height: 3rem;
  padding-block: 0.72rem;
  background: color-mix(in srgb, oklch(97% 0.005 250) 92%, white);
  @supports (color: color-mix(in lab, red, red)) {
    background: color-mix(in srgb, var(--color-surface-2) 92%, white);
  }
  border-bottom: 1px solid var(--color-surface-3);
  color: var(--color-text-secondary);
  font-size: 0.6875rem;
  font-weight: 700;
  letter-spacing: 0.055em;
  text-transform: uppercase;
}
.pt-boq-table__col {
  display: flex;
  align-items: center;
  min-height: 1.5rem;
}
.pt-boq-table__col--title {
  gap: 0.65rem;
}
.pt-boq-table__row {
  min-height: 3.25rem;
  padding-block: 0.72rem;
  border-top: 1px solid var(--color-surface-3);
  background: var(--color-surface);
  transition: background-color 120ms ease;
}
.pt-boq-table__row:first-child {
  border-top: 0;
}
.pt-boq-table__row:hover {
  background: color-mix(in srgb, oklch(45% 0.18 250) 3%, oklch(99% 0 0));
  @supports (color: color-mix(in lab, red, red)) {
    background: color-mix(in srgb, var(--color-brand) 3%, var(--color-surface));
  }
}
.pt-boq-table__row--selected {
  background: color-mix(in srgb, oklch(45% 0.18 250) 7%, oklch(99% 0 0));
  @supports (color: color-mix(in lab, red, red)) {
    background: color-mix(in srgb, var(--color-brand) 7%, var(--color-surface));
  }
}
.pt-boq-table__row--selected:hover {
  background: color-mix(in srgb, oklch(45% 0.18 250) 10%, oklch(99% 0 0));
  @supports (color: color-mix(in lab, red, red)) {
    background: color-mix(in srgb, var(--color-brand) 10%, var(--color-surface));
  }
}
.pt-boq-table__row--partially-selected {
  background: color-mix(in srgb, oklch(45% 0.18 250) 3%, oklch(99% 0 0));
  @supports (color: color-mix(in lab, red, red)) {
    background: color-mix(in srgb, var(--color-brand) 3%, var(--color-surface));
  }
}
.pt-boq-table__row--partially-selected:hover {
  background: color-mix(in srgb, oklch(45% 0.18 250) 6%, oklch(99% 0 0));
  @supports (color: color-mix(in lab, red, red)) {
    background: color-mix(in srgb, var(--color-brand) 6%, var(--color-surface));
  }
}
.pt-boq-table__cell {
  display: flex;
  align-items: center;
  min-width: 0;
  min-height: 1.75rem;
  color: var(--color-text-primary);
  font-size: 0.8125rem;
  font-weight: 500;
  line-height: 1.4;
}
.pt-boq-table__cell--numeric, .pt-boq-table__cell--image {
  justify-content: flex-start;
}
.pt-boq-table__title-wrap {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  min-width: 0;
  min-height: 1.75rem;
}
.pt-boq-table__head-checkbox, .pt-boq-table__row-checkbox {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1.125rem;
  height: 1.125rem;
  flex: 0 0 1.125rem;
  cursor: pointer;
}
.pt-boq-table__head-checkbox input, .pt-boq-table__row-checkbox input {
  position: absolute;
  width: 1px;
  height: 1px;
  overflow: hidden;
  opacity: 0;
}
.pt-boq-table__head-checkbox span, .pt-boq-table__row-checkbox span {
  display: block;
  width: 1.05rem;
  height: 1.05rem;
  border: 1px solid color-mix(in srgb, oklch(45% 0.02 250) 52%, transparent);
  @supports (color: color-mix(in lab, red, red)) {
    border: 1px solid color-mix(in srgb, var(--color-text-secondary) 52%, transparent);
  }
  border-radius: 0.16rem;
  background: var(--color-surface);
  transition: border-color 120ms ease, background-color 120ms ease, box-shadow 120ms ease;
}
.pt-boq-table__head-checkbox:hover span, .pt-boq-table__row-checkbox:hover span {
  border-color: var(--color-brand);
}
.pt-boq-table__head-checkbox input:focus-visible + span, .pt-boq-table__row-checkbox input:focus-visible + span {
  border-color: var(--color-brand);
  box-shadow: 0 0 0 3px color-mix(in srgb, oklch(45% 0.18 250) 18%, transparent);
  @supports (color: color-mix(in lab, red, red)) {
    box-shadow: 0 0 0 3px color-mix(in srgb, var(--color-brand) 18%, transparent);
  }
}
.pt-boq-table__head-checkbox input:checked + span, .pt-boq-table__row-checkbox input:checked + span, .pt-boq-table__head-checkbox input:indeterminate + span {
  border-color: var(--color-brand);
  background: var(--color-brand);
}
.pt-boq-table__head-checkbox input:checked + span::after, .pt-boq-table__row-checkbox input:checked + span::after {
  content: "";
  display: block;
  width: 0.52rem;
  height: 0.29rem;
  margin: 0.26rem auto 0;
  border-left: 2px solid white;
  border-bottom: 2px solid white;
  transform: rotate(-45deg);
}
.pt-boq-table__head-checkbox input:indeterminate + span::after {
  content: "";
  display: block;
  width: 0.52rem;
  height: 2px;
  margin: 0.46rem auto 0;
  border-radius: 1px;
  background: white;
}
.pt-boq-table__toggle {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1.15rem;
  height: 1.15rem;
  padding: 0;
  border: 0;
  background: transparent;
  color: var(--color-text-secondary);
  flex: 0 0 1.15rem;
  cursor: pointer;
}
.pt-boq-table__toggle:hover {
  color: var(--color-brand);
}
.pt-boq-table__toggle[aria-expanded="false"] .pt-boq-table__toggle-icon {
  transform: rotate(-90deg);
}
.pt-boq-table__toggle-icon {
  width: 0.9rem;
  height: 0.9rem;
  transition: transform 150ms ease;
}
.pt-boq-table__toggle-placeholder {
  display: inline-block;
  width: 1.15rem;
  flex: 0 0 1.15rem;
}
.pt-boq-table__title {
  overflow: hidden;
  color: var(--color-text-primary);
  font-size: 0.8375rem;
  font-weight: 500;
  line-height: 1.42;
  text-overflow: ellipsis;
}
.pt-boq-table__lock, .pt-boq-table__cell-lock {
  display: inline-flex;
  align-items: center;
  margin-left: 0.38rem;
  color: var(--color-text-secondary);
}
.pt-boq-table__lock-icon {
  width: 0.8rem;
  height: 0.8rem;
}
.pt-boq-table__image {
  width: 2.25rem;
  height: 2.25rem;
  object-fit: cover;
  border: 1px solid var(--color-surface-3);
  border-radius: var(--radius-sm, 0.25rem);
}
.pt-boq-notes {
  min-height: 12rem;
  padding: 1rem 1.125rem;
  border: 1px solid var(--color-surface-3);
  border-radius: var(--radius-md, 0.5rem);
  background: var(--color-surface);
  box-shadow: 0 1px 2px rgb(15 23 42 / 4%);
}
.pt-boq-notes__field {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}
.pt-boq-notes__label {
  color: var(--color-text-primary);
  font-size: 0.8125rem;
  font-weight: 600;
}
.pt-boq-notes__textarea {
  width: 100%;
  min-height: 8rem;
  padding: 0.65rem;
  border: 1px solid var(--color-surface-3);
  border-radius: var(--radius-sm, 0.25rem);
  background: var(--color-surface-2);
  color: var(--color-text-primary);
  font-size: 0.8125rem;
}
.pt-boq-notes__meta {
  margin-bottom: 0.625rem;
  color: var(--color-text-secondary);
  font-size: 0.8125rem;
}
.pt-boq-notes__content {
  color: var(--color-text-primary);
  font-size: 0.875rem;
  line-height: 1.5;
}
.pt-detail-sidebar {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}
.pt-detail-sidebar__title {
  margin: 0;
  color: var(--color-text-primary);
  font-size: 0.8125rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}
.pt-detail-sidebar__list {
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
  margin: 0;
  padding: 0;
  list-style: none;
}
.pt-detail-sidebar__item {
  display: flex;
  gap: 0.55rem;
  padding: 0.625rem;
  border-radius: var(--radius-sm, 0.25rem);
  background: var(--color-surface-2);
}
.pt-detail-sidebar__item-icon {
  width: 0.95rem;
  height: 0.95rem;
  margin-top: 0.1rem;
  color: var(--color-text-secondary);
  flex-shrink: 0;
}
.pt-detail-sidebar__item-body {
  display: flex;
  flex-direction: column;
  gap: 0.2rem;
  min-width: 0;
}
.pt-detail-sidebar__item-title, .pt-detail-sidebar__item-link {
  color: var(--color-text-primary);
  font-size: 0.8125rem;
  font-weight: 600;
  line-height: 1.35;
}
.pt-detail-sidebar__item-link {
  color: var(--color-brand);
}
.pt-detail-sidebar__item-meta {
  color: var(--color-text-secondary);
  font-size: 0.75rem;
}
.pt-detail-sidebar__empty {
  display: flex;
  min-height: 11rem;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 0.55rem;
  color: var(--color-text-secondary);
  text-align: center;
}
.pt-detail-sidebar__empty-icon {
  width: 1.75rem;
  height: 1.75rem;
  color: var(--color-text-muted);
}
@media (max-width: 960px) {
  .pt-boq-header__top {
    align-items: flex-start;
    flex-direction: column;
  }
  .pt-boq-header__actions {
    align-items: center;
    justify-content: flex-start;
    flex-wrap: wrap;
  }
  .pt-boq-table__head {
    display: none;
  }
  .pt-boq-table__row {
    grid-template-columns: 1fr;
    gap: 0.4rem;
    padding: 0.75rem;
  }
}
.pt-context-sidebar {
  --ctx-width-collapsed: 3rem;
  --ctx-width-expanded: 20rem;
  --ctx-bg: var(--color-surface-2);
  --ctx-border: var(--pt-sidebar-border, var(--color-surface-3));
  --ctx-text: var(--color-text-primary);
  --ctx-text-muted: var(--color-text-secondary);
  --ctx-active: var(--color-brand);
  width: var(--ctx-width-expanded);
  min-width: var(--ctx-width-expanded);
  min-height: 100%;
  background: var(--ctx-bg);
  border-left: 1px solid var(--ctx-border);
  display: flex;
  flex-direction: row-reverse;
  transition: width 200ms ease, min-width 200ms ease;
  position: relative;
  overflow: visible;
}
.pt-ctx-task-content {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
}
.pt-ctx-task-title {
  color: var(--ctx-text);
  font-size: 0.8125rem;
  font-weight: 500;
  line-height: 1.45;
  overflow-wrap: anywhere;
}
.pt-ctx-task-due-date {
  color: var(--ctx-text-muted);
  font-size: 0.75rem;
  line-height: 1.4;
}
.pt-context-sidebar--collapsed {
  width: var(--ctx-width-collapsed);
  min-width: var(--ctx-width-collapsed);
}
.pt-context-sidebar--collapsed .pt-context-sidebar__body {
  display: none;
}
.pt-context-sidebar--collapsed .pt-context-sidebar__icons {
  display: flex;
}
.pt-context-sidebar__icons {
  display: none;
  flex-direction: column;
  align-items: center;
  width: var(--ctx-width-collapsed);
  min-width: var(--ctx-width-collapsed);
  padding-top: 0.5rem;
  padding-bottom: 0.5rem;
  gap: 0.25rem;
}
.pt-context-sidebar__toggle {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 2.25rem;
  height: 2.25rem;
  border-radius: 0.25rem;
  border: none;
  background: transparent;
  color: var(--ctx-text-muted);
  cursor: pointer;
  margin-bottom: 0.5rem;
  transition: background 150ms, color 150ms;
}
.pt-context-sidebar__toggle:hover {
  background: rgba(0, 0, 0, 0.06);
  color: var(--ctx-text);
}
.pt-context-sidebar__toggle-icon {
  width: 1rem;
  height: 1rem;
}
.pt-context-sidebar__icon-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 2.25rem;
  height: 2.25rem;
  border-radius: 0.25rem;
  border: none;
  background: transparent;
  color: var(--ctx-text-muted);
  cursor: pointer;
  transition: background 150ms, color 150ms;
}
.pt-context-sidebar__icon-btn:hover {
  background: rgba(0, 0, 0, 0.06);
  color: var(--ctx-text);
}
.pt-context-sidebar__icon-btn--active {
  color: var(--ctx-active);
  background: rgba(37, 99, 235, 0.08);
}
.pt-context-sidebar__icon-svg {
  width: 1.125rem;
  height: 1.125rem;
}
.pt-context-sidebar__body {
  flex: 1;
  display: flex;
  flex-direction: column;
  overflow: visible;
}
.pt-context-sidebar__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0.5rem 0.75rem;
  border-bottom: 1px solid var(--ctx-border);
  gap: 0.5rem;
}
.pt-context-sidebar__tabs {
  display: flex;
  gap: 0.125rem;
  flex: 1;
}
.pt-context-sidebar__tab {
  display: flex;
  align-items: center;
  gap: 0.25rem;
  padding: 0.375rem 0.5rem;
  border-radius: 0.25rem;
  border: none;
  background: transparent;
  color: var(--ctx-text-muted);
  font-size: 0.75rem;
  font-weight: 500;
  cursor: pointer;
  transition: background 150ms, color 150ms;
  white-space: nowrap;
  span {
    display: none;
  }
}
.pt-context-sidebar__tab--active span {
  display: inline;
}
.pt-context-sidebar__tab:hover {
  background: rgba(0, 0, 0, 0.05);
  color: var(--ctx-text);
}
.pt-context-sidebar__tab--active {
  color: var(--ctx-active);
  background: rgba(37, 99, 235, 0.08);
}
.pt-context-sidebar__tab-icon {
  width: 0.875rem;
  height: 0.875rem;
  flex-shrink: 0;
}
.pt-context-sidebar__collapse {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 1.75rem;
  height: 1.75rem;
  border-radius: 0.25rem;
  border: none;
  background: transparent;
  color: var(--ctx-text-muted);
  cursor: pointer;
  flex-shrink: 0;
  transition: background 150ms, color 150ms;
}
.pt-context-sidebar__collapse:hover {
  background: rgba(0, 0, 0, 0.06);
  color: var(--ctx-text);
}
.pt-context-sidebar__collapse-icon {
  width: 0.875rem;
  height: 0.875rem;
}
.pt-context-sidebar__panels {
  flex: 1;
  overflow-y: auto;
}
.pt-context-sidebar__panel {
  display: none;
  padding: 0.75rem;
}
.pt-context-sidebar__panel--active {
  display: block;
}
.pt-ctx-activity-list {
  list-style: none;
  padding: 0;
  margin: 0;
}
.pt-ctx-activity-item {
  display: flex;
  gap: 0.625rem;
  padding: 0.5rem 0;
  border-bottom: 1px solid rgba(0, 0, 0, 0.06);
  font-size: 0.8125rem;
  line-height: 1.4;
  color: var(--ctx-text);
}
.pt-ctx-activity-item:last-child {
  border-bottom: none;
}
.pt-ctx-activity-icon {
  width: 1.25rem;
  height: 1.25rem;
  flex-shrink: 0;
  color: var(--ctx-text-muted);
  margin-top: 0.125rem;
}
.pt-ctx-activity-content {
  flex: 1;
  min-width: 0;
}
.pt-ctx-activity-message {
  color: var(--ctx-text);
  line-height: 1.5;
  overflow-wrap: anywhere;
}
.pt-ctx-activity-content--structured {
  display: flex;
  flex-direction: column;
  gap: 0.125rem;
}
.pt-ctx-activity-action {
  margin-bottom: 0.125rem;
  color: var(--ctx-text);
  font-size: 0.8125rem;
  font-weight: 600;
  line-height: 1.45;
}
.pt-ctx-activity-company-link {
  display: block;
  margin-bottom: 0.625rem;
  color: var(--ctx-text);
  font-size: 0.8125rem;
  font-weight: 600;
  line-height: 1.45;
  text-decoration: none;
  overflow-wrap: anywhere;
}
.pt-ctx-activity-company-link:hover, .pt-ctx-activity-company-link:focus-visible {
  color: var(--ctx-active);
  text-decoration: underline;
  text-underline-offset: 0.15em;
}
.pt-ctx-activity-subject-link {
  display: block;
  color: var(--ctx-text);
  font-size: 0.8125rem;
  font-weight: 500;
  line-height: 1.45;
  text-decoration: none;
  overflow-wrap: anywhere;
}
.pt-ctx-activity-subject-link:hover, .pt-ctx-activity-subject-link:focus-visible {
  color: var(--ctx-active);
  text-decoration: underline;
  text-underline-offset: 0.15em;
}
.pt-ctx-activity-reference {
  margin-top: 0.0625rem;
  color: var(--ctx-text-muted);
  font-size: 0.75rem;
  font-weight: 500;
  line-height: 1.4;
}
.pt-ctx-activity-actor {
  margin-top: 0.625rem;
  color: var(--ctx-text-muted);
  font-size: 0.75rem;
  line-height: 1.4;
}
.pt-ctx-activity-actor__label {
  color: var(--ctx-text-muted);
  font-weight: 400;
}
.pt-ctx-activity-actor__link {
  display: block;
  color: var(--ctx-text-muted);
  font-weight: 500;
  line-height: 1.4;
  text-decoration: none;
  overflow-wrap: anywhere;
}
.pt-ctx-activity-actor__link:hover, .pt-ctx-activity-actor__link:focus-visible {
  color: var(--ctx-active);
  text-decoration: underline;
  text-underline-offset: 0.15em;
}
.pt-ctx-activity-time {
  display: block;
  margin-top: 0.125rem;
  color: var(--ctx-text-muted);
  font-size: 0.75rem;
  line-height: 1.4;
}
.pt-ctx-task-list {
  list-style: none;
  padding: 0;
  margin: 0;
}
.pt-ctx-task-item {
  display: flex;
  align-items: flex-start;
  gap: 0.5rem;
  padding: 0.5rem 0;
  border-bottom: 1px solid rgba(0, 0, 0, 0.06);
  font-size: 0.8125rem;
  color: var(--ctx-text);
}
.pt-ctx-task-item:last-child {
  border-bottom: none;
}
.pt-ctx-task-marker {
  width: 1rem;
  height: 1rem;
  flex-shrink: 0;
  margin-top: 0.125rem;
  color: var(--ctx-text-muted);
}
.pt-ctx-task-marker__icon {
  width: 1rem;
  height: 1rem;
}
.pt-ctx-task-link {
  line-height: 1.45;
}
.pt-ctx-task-link a {
  color: var(--ctx-text);
  font-size: 0.8125rem;
  font-weight: 500;
  line-height: 1.45;
  text-decoration: none;
  overflow-wrap: anywhere;
}
.pt-ctx-task-link a:hover, .pt-ctx-task-link a:focus-visible {
  color: var(--ctx-active);
  text-decoration: underline;
  text-underline-offset: 0.15em;
}
.pt-ctx-task-item--complete .pt-ctx-task-marker {
  color: #14804a;
}
.pt-ctx-task-item--optional .pt-ctx-task-marker {
  color: var(--ctx-active);
}
.pt-ctx-task-children {
  list-style: none;
  padding: 0;
  margin: 0.5rem 0 0;
}
.pt-ctx-task-children .pt-ctx-task-item {
  border-bottom: none;
  padding: 0.25rem 0;
}
.pt-ctx-empty {
  text-align: center;
  padding: 2rem 1rem;
  color: var(--ctx-text-muted);
  font-size: 0.8125rem;
}
.pt-ctx-empty-icon {
  width: 2rem;
  height: 2rem;
  margin: 0 auto 0.5rem;
  opacity: 0.4;
}
.pt-tender-context-sidebar {
  position: sticky;
  top: 0;
  align-self: flex-start;
  height: 100vh;
  min-height: 100vh;
  background: var(--color-surface-2);
}
.pt-tender-context-sidebar .pt-context-sidebar {
  height: 100%;
  min-height: 100%;
  padding-top: var(--pt-tender-shell-offset, 9.75rem);
  box-sizing: border-box;
  background: var(--color-surface-2);
}
.pt-data-grid {
  display: grid;
  gap: var(--space-4, 1rem);
  width: 100%;
}
.pt-data-grid--grid {
  grid-template-columns: repeat(2, 1fr);
}
.pt-data-grid--grid.pt-data-grid--cols-2 {
  grid-template-columns: repeat(2, 1fr);
}
.pt-data-grid--grid.pt-data-grid--cols-3 {
  grid-template-columns: repeat(3, 1fr);
}
.pt-data-grid--grid.pt-data-grid--cols-4 {
  grid-template-columns: repeat(4, 1fr);
}
.pt-data-grid--list {
  grid-template-columns: 1fr;
  gap: var(--space-2, 0.5rem);
}
.pt-data-grid--table {
  grid-template-columns: 1fr;
  gap: 0;
  .pt-data-grid__item {
    border-bottom: 1px solid var(--color-border);
    &:last-child {
      border-bottom: none;
    }
  }
}
.pt-data-grid__item {
  display: flex;
  flex-direction: column;
  min-width: 0;
}
.pt-data-grid__item > * {
  flex: 1;
}
@media (width <= 48rem) {
  .pt-data-grid--grid {
    grid-template-columns: 1fr;
  }
}
@media (48rem < width <= 64rem) {
  .pt-data-grid--grid.pt-data-grid--cols-3, .pt-data-grid--grid.pt-data-grid--cols-4 {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (width > 80rem) {
  .pt-data-grid--grid.pt-data-grid--cols-4 {
    grid-template-columns: repeat(4, 1fr);
  }
}
.pt-data-grid:empty::after {
  content: "";
  display: none;
}
.pt-preview-card {
  display: flex;
  flex-direction: column;
  background: var(--color-surface, var(--color-surface));
  border: 1px solid var(--color-border, oklch(91% 0 0));
  border-radius: var(--radius-lg, 0.75rem);
  overflow: hidden;
  height: 100%;
  transition: box-shadow 0.15s ease;
  &:hover {
    box-shadow: 0 4px 16px oklch(0% 0 0 / 8%);
  }
}
.pt-preview-card__logo {
  width: 2.5rem;
  height: 2.5rem;
  border-radius: 0.375rem;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.75rem;
  font-weight: 700;
  color: var(--color-surface);
  flex-shrink: 0;
}
.pt-preview-card__body {
  flex: 1;
  padding: 1rem;
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
}
.pt-preview-card__name {
  font-size: 0.9375rem;
  font-weight: 600;
  color: var(--color-text, oklch(15% 0 0));
  margin: 0;
}
.pt-preview-card__meta {
  font-size: 0.8125rem;
  color: var(--color-muted, oklch(55% 0 0));
  margin: 0;
}
.pt-preview-card__location {
  font-size: 0.75rem;
  color: var(--color-muted, oklch(60% 0 0));
  margin: 0;
}
.pt-preview-card__footer {
  padding: 0.625rem 1rem;
  border-top: 1px solid var(--color-border, oklch(91% 0 0));
  background: var(--color-surface-alt, oklch(98% 0 0));
}
.pt-preview-card__stat {
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--color-text, oklch(25% 0 0));
  small {
    font-weight: 400;
    color: var(--color-muted, oklch(55% 0 0));
    margin-left: 0.25rem;
  }
}
.pt-data-grid--list .pt-preview-card, .pt-data-grid--table .pt-preview-card {
  flex-direction: row;
  align-items: center;
  gap: 0;
  border-radius: 0;
  border-left: none;
  border-right: none;
  border-top: none;
  .pt-preview-card__body {
    flex: 1;
    padding: 0.75rem 1rem;
    flex-direction: row;
    align-items: center;
    gap: 1.5rem;
    p {
      margin: 0;
    }
  }
  .pt-preview-card__footer {
    border-top: none;
    border-left: 1px solid var(--color-border, oklch(91% 0 0));
    padding: 0.75rem 1rem;
    background: transparent;
  }
  .pt-preview-card__logo {
    margin: 0.75rem;
  }
}
.pt-directory-banner {
  padding: 2rem 2.5rem;
  min-height: 15rem;
  display: flex;
  flex-direction: column;
  justify-content: center;
  border-radius: var(--radius-lg);
  background-color: #305f82;
  background-image: var(--background-image, none);
  background-repeat: no-repeat;
  background-position: right bottom;
  background-size: contain;
  overflow: hidden;
  @media (max-width: 768px) {
    display: none;
  }
}
.pt-directory-banner__title {
  font-size: 1.75rem;
  font-weight: 400;
  color: oklch(98% 0 0);
  line-height: 1.2;
  letter-spacing: -0.01em;
  margin: 0 0 0.75rem;
}
.pt-directory-banner__body {
  font-size: 0.9375rem;
  color: oklch(82% 0.01 250);
  line-height: 1.55;
  margin: 0;
  max-width: 26rem;
}
.pt-directory-banner__cta {
  margin-top: 1.25rem;
}
.pt-table-columns-menu {
  position: relative;
  display: inline-flex;
  align-items: center;
}
.pt-table-columns-menu[hidden] {
  display: none !important;
}
.pt-table-columns-menu__button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.45rem;
  min-height: 2.25rem;
  padding: 0 0.75rem;
  border: 1px solid oklch(83% 0 0);
  border-radius: 0.375rem;
  background: var(--color-surface);
  color: oklch(24% 0 0);
  font-size: 0.875rem;
  font-weight: 500;
  line-height: 1;
  cursor: pointer;
  white-space: nowrap;
  transition: background 0.12s, border-color 0.12s, color 0.12s;
}
.pt-table-columns-menu__button:hover, .pt-table-columns-menu--open .pt-table-columns-menu__button {
  background: oklch(96% 0 0);
  border-color: oklch(76% 0 0);
  color: oklch(18% 0 0);
}
.pt-table-columns-menu__icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1rem;
  height: 1rem;
  flex: 0 0 auto;
}
.pt-table-columns-menu__icon svg, .pt-table-columns-menu__icon .pt-icon {
  display: block;
  width: 1rem;
  height: 1rem;
}
.pt-table-columns-menu__panel {
  position: absolute;
  top: calc(100% + 0.5rem);
  right: 0;
  z-index: 80;
  min-width: 13.75rem;
  padding: 0.65rem 0.75rem;
  border: 1px solid oklch(82% 0 0);
  border-radius: 0.25rem;
  background: var(--color-surface);
  box-shadow: 0 0.55rem 1.25rem oklch(20% 0 0 / 16%);
}
.pt-table-columns-menu__panel[hidden] {
  display: none !important;
}
.pt-table-columns-menu__panel::before {
  content: "";
  position: absolute;
  top: -0.42rem;
  right: 1.35rem;
  width: 0.75rem;
  height: 0.75rem;
  background: var(--color-surface);
  border-left: 1px solid oklch(82% 0 0);
  border-top: 1px solid oklch(82% 0 0);
  transform: rotate(45deg);
}
.pt-table-columns-menu__group + .pt-table-columns-menu__group {
  margin-top: 0.55rem;
}
.pt-table-columns-menu__item {
  display: flex;
  align-items: center;
  gap: 0.45rem;
  min-height: 1.45rem;
  color: oklch(25% 0 0);
  font-size: 0.8125rem;
  line-height: 1.2;
  cursor: pointer;
  user-select: none;
}
.pt-table-columns-menu__item input {
  width: 1rem;
  height: 1rem;
  margin: 0;
  flex: 0 0 auto;
  accent-color: oklch(45% 0.18 250);
  cursor: pointer;
}
.pt-table-columns-menu__item span {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.pt-table-columns-menu__item--group {
  font-weight: 700;
}
.pt-table-columns-menu__item--child {
  padding-left: 1.35rem;
  font-size: 0.8rem;
  color: oklch(32% 0 0);
}
.pt-table-columns-menu__item:hover span {
  color: oklch(45% 0.18 250);
}
.pt-company-directory {
  display: inline-flex;
  flex-direction: column;
  gap: 1.25rem;
  width: 100%;
}
.pt-directory-controls {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
  width: 100%;
  min-width: 0;
}
.pt-directory-has-no-active-refinements .pt-directory-controls {
  gap: 0.35rem;
}
.pt-directory-controls__top {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  row-gap: 0.6rem;
  flex-wrap: wrap;
  width: 100%;
  min-width: 0;
}
.pt-directory-controls__top > .pt-directory-toolbar {
  display: contents;
}
.pt-directory-toolbar {
  display: inline-flex;
  align-items: center;
  gap: 0.75rem;
  flex-wrap: nowrap;
  width: auto;
  min-width: 0;
}
.pt-directory-toolbar__stats, .pt-search-stats {
  font-size: 0.8125rem;
  color: oklch(50% 0 0);
  white-space: nowrap;
}
.pt-directory-controls .pt-view-mode-switcher {
  order: 1;
  flex: 0 0 auto;
  margin-left: 0;
}
.pt-directory-controls .pt-directory-toolbar__stats, .pt-directory-controls .pt-search-stats {
  order: 2;
  flex: 0 0 auto;
}
.pt-directory-refinements__actions {
  order: 3;
  display: inline-flex;
  align-items: center;
  justify-content: flex-end;
  gap: 0.5rem;
  flex: 0 0 auto;
  margin-left: auto;
  white-space: nowrap;
}
.pt-directory-controls .pt-directory-toolbar__sort {
  order: 4;
  flex: 0 0 auto;
  margin-left: 0;
}
.pt-directory-controls__top:not(:has(.pt-directory-refinements__actions)) .pt-directory-toolbar__sort {
  margin-left: auto;
}
.pt-directory-toolbar__actions {
  display: flex;
  align-items: center;
  gap: 0.5rem;
}
.pt-directory-controls__filters {
  display: flex;
  width: 100%;
  min-width: 0;
}
.pt-directory-has-no-active-refinements .pt-directory-controls__filters {
  display: none;
}
.pt-directory-refinements {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  flex-wrap: wrap;
  width: 100%;
  min-width: 0;
}
.pt-directory-refinements > div:empty {
  display: none;
}
.pt-directory-refinements .ais-CurrentRefinements-list {
  display: inline-flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 0.5rem;
}
.pt-view-mode-switcher {
  display: inline-flex;
  align-items: center;
  gap: 0;
  border: 1px solid oklch(83% 0 0);
  border-radius: 0.5rem;
  overflow: hidden;
  margin-left: 0;
}
.pt-view-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.25rem;
  height: 2.25rem;
  background: var(--color-surface);
  border: none;
  border-right: 1px solid oklch(83% 0 0);
  cursor: pointer;
  color: oklch(55% 0 0);
  font-size: 0.875rem;
  transition: background 0.12s, color 0.12s;
  & .pt-icon {
    width: 1.25rem;
    height: 1.25rem;
  }
  &:last-child {
    border-right: none;
  }
  &:hover {
    background: oklch(96% 0 0);
    color: oklch(30% 0 0);
  }
  &.pt-view-btn--active {
    background: oklch(45% 0.18 250);
    color: var(--color-surface);
  }
}
.pt-export-disabled-wrapper {
  display: inline-block;
}
.pt-company-directory, .pt-product-directory, .pt-project-directory, .pt-task-directory, .pt-opportunities-directory, .pt-vendor-registrations-directory, .pt-wp-project-directory {
  container: pt-directory / inline-size;
}
.pt-directory-layout {
  display: grid;
  grid-template-columns: 18.75rem minmax(0, 1fr);
  gap: 1.5rem;
  align-items: start;
  @container pt-directory (max-width: 48rem) {
    grid-template-columns: 1fr;
  }
}
.pt-directory-filters {
  display: inline-flex;
  flex-direction: column;
  gap: 0;
  background: var(--color-surface);
  border: 1px solid oklch(91% 0 0);
  border-radius: 0.625rem;
  overflow: hidden;
}
.pt-directory-filters__header {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.625rem 0.875rem;
  border-bottom: 1px solid oklch(91% 0 0);
  background: oklch(97% 0 0);
  .pt-directory-filters__header-icon {
    width: 1rem;
    height: 1rem;
    color: oklch(45% 0 0);
    flex-shrink: 0;
  }
  .pt-directory-filters__header-label {
    font-size: 0.7rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: oklch(45% 0 0);
  }
}
.pt-filter-section {
  border-bottom: 1px solid oklch(93% 0 0);
  &:last-child {
    border-bottom: none;
  }
  .pt-filter-section__title {
    font-size: 0.75rem;
    font-weight: 600;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: oklch(45% 0 0);
    padding: 0.625rem 0.875rem 0.375rem;
    margin: 0;
  }
  .pt-filter-section__body {
    padding: 0 0.875rem 0.75rem;
  }
  .pt-filter-section__addon {
    display: flex;
    align-items: center;
    padding: 0.625rem 0 0.5rem;
  }
}
.pt-filter-section__toggle {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  background: none;
  border: none;
  cursor: pointer;
  padding: 0.625rem 0.875rem 0.375rem;
  gap: 0.5rem;
  text-align: left;
  .pt-filter-section__title {
    padding: 0;
  }
  .pt-filter-section__chevron {
    flex-shrink: 0;
    color: oklch(55% 0 0);
    transition: transform 150ms ease;
  }
}
.pt-filter-section--collapsible[data-collapsed="true"] .pt-filter-section__body {
  display: none;
}
.pt-filter-section--collapsible[data-collapsed="true"] .pt-filter-section__chevron {
  transform: rotate(-90deg);
}
.pt-filter-section--locked {
  .pt-filter-section__title {
    color: oklch(65% 0 0);
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    &::after {
      content: "🔒";
      font-size: 0.7em;
    }
  }
}
.pt-filter-section__body--locked {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  padding: 0.25rem 0 0.5rem;
  font-size: 0.8rem;
  color: oklch(65% 0 0);
  font-style: italic;
}
.pt-directory-results {
  display: inline-flex;
  flex-direction: column;
  gap: 1.25rem;
  min-width: 0;
  container: pt-directory-results / inline-size;
}
.pt-directory-has-no-active-refinements .pt-directory-results {
  gap: 0.85rem;
}
.pt-company-hits, .pt-product-hits, .pt-project-hits {
  position: relative;
}
.pt-company-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(min(100%, 13rem), 1fr));
  gap: 0.85rem;
  align-items: stretch;
  list-style: none;
  margin: 0;
  padding: 0;
}
.pt-company-grid__item {
  display: inline-flex;
  min-width: 0;
}
.pt-company-card {
  position: relative;
  display: flex;
  flex-direction: column;
  width: 100%;
  height: 100%;
  min-width: 0;
  min-height: 30rem;
  background: var(--color-surface);
  border: 1px solid oklch(89% 0 0);
  border-radius: var(--radius-xl);
  overflow: visible;
  box-shadow: 0 0.25rem 0.75rem oklch(20% 0 0 / 6%);
  transition: box-shadow 0.15s ease, transform 0.15s ease, border-color 0.15s ease;
  &:hover, &.pt-company-card--menu-open {
    border-color: oklch(82% 0 0);
    box-shadow: 0 0.5rem 1.25rem oklch(20% 0 0 / 10%);
    transform: translateY(-1px);
    z-index: 20;
  }
}
.pt-company-card__header {
  position: relative;
  display: flex;
  align-items: flex-start;
  justify-content: flex-start;
  min-height: 10.25rem;
  padding: 1rem 1rem 0;
  min-width: 0;
}
.pt-company-card__logo-link {
  flex: 0 0 auto;
  text-decoration: none;
}
.pt-company-card__logo {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 9.25rem;
  height: 9.25rem;
  border: 1px solid oklch(86% 0 0);
  border-radius: 0.85rem;
  background: oklch(98% 0 0);
  overflow: hidden;
  img {
    max-width: 82%;
    max-height: 82%;
    width: auto;
    height: auto;
    object-fit: contain;
    display: block;
  }
}
.pt-company-card__logo-placeholder {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
  font-size: 2.25rem;
  font-weight: 700;
  color: oklch(45% 0.16 250);
  background: oklch(94% 0.035 250);
}
.pt-company-card__actions {
  position: absolute;
  top: 1rem;
  right: 1rem;
  left: auto;
  z-index: 30;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.35rem;
}
.pt-card-action-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2rem;
  height: 2rem;
  border: none;
  border-radius: var(--radius-sm);
  background: transparent;
  cursor: pointer;
  color: oklch(66% 0 0);
  padding: 0;
  transition: background 0.12s, color 0.12s, border-color 0.12s;
  .pt-icon-wrap, .pt-icon {
    width: 1.25rem;
    height: 1.25rem;
    display: block;
  }
  &:hover {
    background: oklch(96% 0 0);
    color: oklch(35% 0 0);
  }
}
.pt-card-action-btn--like.pt-card-action-btn--active {
  color: oklch(55% 0.22 10);
}
.pt-card-action-btn--tag.pt-card-action-btn--active {
  color: oklch(45% 0.18 250);
}
.pt-company-card__menu {
  position: relative;
  display: inline-flex;
}
.pt-company-card__dropdown {
  position: absolute;
  top: 0;
  right: calc(100% + 0.65rem);
  left: auto;
  z-index: 50;
  display: none;
  width: 13.75rem;
  padding: 0.6rem 0.8rem;
  background: white;
  border: 1px solid oklch(82% 0 0);
  box-shadow: 0 0.45rem 1rem oklch(20% 0 0 / 16%);
}
.pt-company-card__dropdown::before {
  content: "";
  position: absolute;
  top: 0.65rem;
  right: -0.5rem;
  left: auto;
  width: 0.9rem;
  height: 0.9rem;
  background: white;
  border-right: 1px solid oklch(82% 0 0);
  border-top: 1px solid oklch(82% 0 0);
  border-left: none;
  border-bottom: none;
  transform: rotate(45deg);
}
.pt-company-card__menu--open .pt-company-card__dropdown {
  display: block;
}
.pt-company-card__dropdown-item {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  min-height: 2.75rem;
  color: oklch(25% 0 0);
  font-size: 0.95rem;
  font-weight: 500;
  line-height: 1.2;
  text-decoration: none;
  white-space: nowrap;
  .pt-icon-wrap, .pt-icon {
    width: 1.25rem;
    height: 1.25rem;
    flex: 0 0 auto;
    color: oklch(32% 0 0);
  }
  &:hover {
    color: oklch(45% 0.18 250);
  }
  & + & {
    border-top: 1px solid oklch(86% 0 0);
  }
}
.pt-company-card__body {
  display: flex;
  flex: 1 1 auto;
  flex-direction: column;
  justify-content: center;
  align-items: flex-start;
  gap: 0.45rem;
  min-width: 0;
  min-height: 8rem;
  padding: 0.625rem 1rem 1rem;
}
.pt-company-card__name {
  width: 100%;
  margin: 0;
  color: oklch(18% 0 0);
  font-size: 1.06rem;
  font-weight: 750;
  line-height: 1.22;
}
.pt-company-card__name-link {
  display: -webkit-box;
  width: 100%;
  color: inherit;
  text-decoration: none;
  overflow: hidden;
  overflow-wrap: anywhere;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  &:hover {
    color: oklch(45% 0.18 250);
  }
}
.pt-company-card__location {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  max-width: 100%;
  margin: 0;
  color: oklch(48% 0 0);
  font-size: 0.84rem;
  line-height: 1.25;
  min-width: 0;
  span:last-child {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
  }
  .pt-icon-wrap, .pt-icon {
    flex: 0 0 auto;
    width: 1rem;
    height: 1rem;
    color: oklch(58% 0 0);
  }
}
.pt-company-card__activities {
  display: flex;
  flex-wrap: wrap;
  gap: 0.3rem;
  max-width: 100%;
  max-height: 5.75rem;
  overflow: hidden;
}
.pt-activity-chip {
  display: inline-flex;
  align-items: center;
  max-width: 100%;
  min-width: 0;
  padding: 0.2rem 0.56rem;
  border-radius: 999px;
  background: oklch(91% 0.055 250);
  color: oklch(35% 0.18 250);
  font-size: 0.75rem;
  line-height: 1.2;
  text-decoration: none;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  cursor: pointer;
  transition: background 0.12s ease, transform 0.12s ease;
  &:hover {
    background: oklch(86% 0.075 250);
    transform: translateY(-1px);
  }
}
.pt-activity-chip--muted {
  background: oklch(94% 0 0);
  color: oklch(44% 0 0);
}
.pt-activity-chip--count {
  background: oklch(90% 0 0);
  color: oklch(38% 0 0);
  flex: 0 0 auto;
}
.pt-activity-chip--count:hover {
  transform: none;
}
.pt-company-card__stats {
  display: flex;
  flex-wrap: wrap;
  gap: 0.35rem;
  max-width: 100%;
  margin-top: 0.05rem;
}
.pt-stat-pill {
  display: inline-flex;
  align-items: center;
  gap: 0.3rem;
  max-width: 100%;
  min-width: 0;
  padding: 0.18rem 0.58rem;
  border: 1px solid oklch(87% 0 0);
  border-radius: 999px;
  background: oklch(94% 0 0);
  color: oklch(44% 0 0);
  font-size: 0.75rem;
  line-height: 1.2;
  white-space: nowrap;
  .pt-icon-wrap, .pt-icon {
    width: 0.95rem;
    height: 0.95rem;
    flex: 0 0 auto;
    color: oklch(50% 0 0);
  }
}
.pt-stat-pill__label {
  color: oklch(48% 0 0);
  overflow: hidden;
  text-overflow: ellipsis;
}
.pt-company-card__footer {
  margin-top: auto;
  border-top: 1px solid oklch(91% 0 0);
  background: oklch(98% 0 0);
  border-radius: 0 0 var(--radius-xl) var(--radius-xl);
  overflow: hidden;
}
.pt-company-card__project-strip {
  display: grid;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  gap: 0.35rem;
  padding: 0.7rem 1rem 0.8rem;
}
.pt-project-thumb {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  aspect-ratio: 1 / 1;
  min-width: 0;
  border-radius: var(--radius-md);
  overflow: hidden;
  background: oklch(91% 0 0);
  text-decoration: none;
  img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
  }
  &:hover {
    filter: brightness(0.96);
  }
}
.pt-project-thumb__placeholder {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: oklch(62% 0 0);
  .pt-icon-wrap, .pt-icon {
    width: 1.25rem;
    height: 1.25rem;
  }
}
.pt-project-thumb--count {
  background: oklch(24% 0 0);
  color: white;
  font-size: 0.98rem;
  font-weight: 750;
  &:hover {
    background: oklch(18% 0 0);
  }
}
.pt-company-card__no-projects {
  padding: 0.7rem 1rem 0.8rem;
  color: oklch(55% 0 0);
  font-size: 0.75rem;
}
.pt-directory-pagination {
  margin-top: 0.5rem;
}
.pt-directory-pagination[hidden] {
  display: none !important;
}
.pt-empty-state--directory {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  min-height: 20rem;
  width: 100%;
  padding: 3rem 1.5rem;
  border: 1px dashed oklch(84% 0 0);
  border-radius: 1rem;
  background: oklch(98% 0 0 / 70%);
  color: oklch(42% 0 0);
  text-align: center;
}
.pt-empty-state__icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 3rem;
  height: 3rem;
  margin-bottom: 0.85rem;
  border-radius: 999px;
  background: oklch(94% 0.025 250);
  color: oklch(45% 0.15 250);
}
.pt-empty-state__icon .pt-icon, .pt-empty-state__icon svg {
  width: 1.35rem;
  height: 1.35rem;
}
.pt-empty-state__heading {
  margin: 0;
  color: oklch(20% 0 0);
  font-size: 1.05rem;
  font-weight: 750;
}
.pt-empty-state__body {
  max-width: 26rem;
  margin: 0.5rem 0 0;
  color: oklch(50% 0 0);
  font-size: 0.875rem;
  line-height: 1.45;
}
.pt-search-input--algolia .pt-search-input__form {
  position: relative;
  display: flex;
  width: 100%;
}
.pt-search-input__icon--button {
  position: absolute;
  left: 0.625rem;
  top: 50%;
  transform: translateY(-50%);
  background: none;
  border: none;
  padding: 0;
  margin: 0;
  color: var(--color-muted);
  pointer-events: none;
  display: flex;
  align-items: center;
  justify-content: center;
}
.pt-search-input__icon--button svg {
  width: 1rem;
  height: 1rem;
  display: block;
}
.pt-search-input--algolia .pt-search-input__clear {
  top: 50%;
  transform: translateY(-50%);
  color: oklch(20% 0 0);
}
.pt-search-input--algolia .pt-search-input__clear svg {
  width: 0.85rem;
  height: 0.85rem;
}
.pt-search-input--algolia .pt-search-input__field::-webkit-search-cancel-button {
  display: none;
  -webkit-appearance: none;
}
.pt-filter-option {
  display: grid;
  grid-template-columns: 1rem minmax(0, 1fr) 2rem;
  align-items: center;
  gap: 0.5rem;
  width: 100%;
  min-width: 0;
}
.pt-filter-option__label, .pt-filter-option .pt-checkbox__label {
  grid-column: 2;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.pt-filter-option .pt-checkbox__indicator {
  grid-column: 1;
}
.pt-filter-option__count, .pt-filter-option .pt-refinement-list__count {
  grid-column: 3;
  justify-self: end;
  width: 2rem;
  min-width: 2rem;
  padding: 0.0625rem 0.375rem;
  border-radius: 999px;
  background: oklch(94% 0 0);
  color: oklch(42% 0 0);
  font-size: 0.6875rem;
  font-weight: 800;
  line-height: 1.25;
  text-align: center;
}
.pt-refinement-list {
  .ais-RefinementList-list {
    list-style: none;
    margin: 0;
    padding: 0;
  }
  .ais-RefinementList-item {
    margin-bottom: 0.25rem;
    display: flex;
    align-items: center;
    height: 1.625rem;
    width: 100%;
    min-width: 0;
    overflow: hidden;
  }
  .ais-RefinementList-item > div {
    display: flex;
    flex: 1 1 0;
    min-width: 0;
    max-width: 100%;
    overflow: hidden;
  }
  .ais-RefinementList-item .pt-checkbox {
    display: flex;
    width: 100%;
    min-width: 0;
    overflow: hidden;
    font-size: 0.8125rem;
  }
  .ais-RefinementList-item .pt-filter-option {
    display: grid;
  }
  .ais-RefinementList-item .pt-checkbox__label {
    flex: 0 1 auto;
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
  }
  .ais-RefinementList-item--selected .pt-checkbox__label {
    color: var(--color-brand);
    text-shadow: 0.4px 0 0 currentColor;
  }
  .pt-refinement-list__count {
    flex-shrink: 0;
    font-size: 0.7rem;
    background: oklch(94% 0 0);
    border-radius: 99px;
    padding: 0.1em 0.5em;
    color: oklch(45% 0 0);
  }
  .ais-RefinementList-showMore {
    font-size: 0.75rem;
    color: oklch(45% 0.18 250);
    background: none;
    border: none;
    padding: 0.25rem 0;
    cursor: pointer;
    text-decoration: underline;
    &.ais-RefinementList-showMore--disabled {
      display: none;
    }
  }
  .ais-RefinementList-searchBox {
    margin-bottom: 0.5rem;
  }
}
.pt-numeric-menu {
  .ais-NumericMenu-list {
    list-style: none;
    margin: 0;
    padding: 0;
  }
  .ais-NumericMenu-item {
    margin-bottom: 0.2rem;
    label {
      display: inline-flex;
      align-items: center;
      gap: 0.5rem;
      font-size: 0.8125rem;
      cursor: pointer;
      color: oklch(25% 0 0);
    }
  }
  .ais-NumericMenu-item--selected label {
    font-weight: 600;
    color: oklch(45% 0.18 250);
  }
}
.pt-search-stats {
  font-size: 0.8125rem;
  color: oklch(50% 0 0);
}
.pt-current-refinements {
  .ais-CurrentRefinements-list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: inline-flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    align-items: center;
  }
  .ais-CurrentRefinements-item {
    display: inline-flex;
    flex-wrap: wrap;
    gap: 0.35rem;
    align-items: center;
  }
  .ais-CurrentRefinements-label {
    font-size: 0.75rem;
    font-weight: 500;
    color: oklch(45% 0 0);
    text-transform: none;
    letter-spacing: 0;
  }
  .ais-CurrentRefinements-label::after {
    content: none;
  }
  .ais-CurrentRefinements-category {
    display: inline-flex;
    align-items: center;
    gap: 0.3rem;
    background: oklch(45% 0.18 250 / 10%);
    border: 1px solid oklch(45% 0.18 250 / 25%);
    border-radius: 99px;
    padding: 0.2rem 0.5rem 0.2rem 0.65rem;
    font-size: 0.75rem;
    color: oklch(30% 0.12 250);
  }
  .ais-CurrentRefinements-delete {
    background: none;
    border: none;
    cursor: pointer;
    padding: 0;
    color: oklch(45% 0.18 250);
    font-size: 0.8rem;
    line-height: 1;
    &:hover {
      color: oklch(30% 0 0);
    }
  }
}
.pt-clear-refinements {
  .ais-ClearRefinements-button--disabled {
    display: none;
  }
}
@container pt-directory-results (max-width: 27rem) {
  .pt-directory-controls__top {
    flex-direction: column;
    align-items: stretch;
  }
  .pt-directory-controls__top > .pt-view-mode-switcher {
    align-self: flex-start;
  }
  .pt-directory-controls .pt-directory-toolbar__sort, .pt-directory-refinements__actions {
    margin-left: 0;
    width: 100%;
  }
  .pt-directory-toolbar__sort .ais-SortBy, .pt-directory-toolbar__sort .ais-SortBy-select, .pt-directory-toolbar__sort select {
    width: 100%;
  }
  .pt-directory-refinements__actions .pt-btn {
    width: 100%;
  }
}
.pt-project-directory {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}
.pt-project-status--tender {
  --pt-status-color: #f9ac22;
}
.pt-project-status--planning, .pt-project-status--under_design {
  --pt-status-color: #3196d1;
}
.pt-project-status--under_construction {
  --pt-status-color: #fe9038;
}
.pt-project-status--on_hold {
  --pt-status-color: #795f9c;
}
.pt-project-status--completed {
  --pt-status-color: #22b68e;
}
.pt-project-status--cancelled {
  --pt-status-color: #ee5b4e;
}
.pt-status-chip {
  display: inline-flex;
  align-items: center;
  padding: 0.2rem 0.7rem;
  border-radius: 999px;
  background: var(--pt-status-color, oklch(85% 0 0));
  color: white;
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  line-height: 1.2;
  text-shadow: 0 1px 1px oklch(20% 0 0 / 18%);
  white-space: nowrap;
}
.pt-project-hits--grid .pt-project-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(min(100%, 14rem), 1fr));
  gap: 1rem;
  list-style: none;
  padding: 0;
  margin: 0;
}
.pt-project-hits--list .pt-project-grid {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
  list-style: none;
  padding: 0;
  margin: 0;
}
.pt-project-grid__item {
  list-style: none;
  min-width: 0;
  display: flex;
}
.pt-project-hits--list .pt-project-grid__item {
  width: 100%;
}
.pt-project-hits--list .pt-project-grid__item > *, .pt-project-hits--list .pt-project-grid__item .pt-card {
  flex: 1 1 auto;
  width: 100%;
}
.pt-project-hits--grid .pt-project-grid {
  grid-auto-rows: 1fr;
}
.pt-project-hits--grid .pt-project-grid__item .pt-card, .pt-project-hits--grid .pt-project-grid__item > * {
  height: 100%;
  width: 100%;
}
.pt-project-hits--empty {
  padding: 3rem 1rem;
  text-align: center;
}
.pt-project-hits--list .pt-project-card {
  flex-direction: row;
  align-items: stretch;
  border-radius: 0.75rem;
}
.pt-project-hits--list .pt-project-card__media-link {
  flex: 0 0 14rem;
  max-width: 14rem;
}
.pt-project-hits--list .pt-project-card__media {
  aspect-ratio: auto;
  height: 100%;
  min-height: 7.5rem;
}
.pt-project-hits--list .pt-project-card__content {
  flex: 1 1 auto;
  padding: 0;
}
.pt-project-hits--list .pt-project-card__body {
  padding: 0.85rem 1.1rem 0.5rem;
}
.pt-project-hits--list .pt-project-card__footer {
  flex-direction: row;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.55rem;
  padding: 0.5rem 1.1rem 0.85rem;
  background: transparent;
  border-top: 0;
}
.pt-project-hits--list .pt-project-card__sectors-row {
  min-height: 0;
}
.pt-project-hits--list .pt-project-card__metrics {
  margin-left: auto;
}
.pt-project-hits--list .pt-project-card__title {
  -webkit-line-clamp: 1;
  font-size: 1.1rem;
}
.pt-project-hits--list .pt-metric-pill__label {
  display: inline;
}
.pt-project-card {
  position: relative;
  display: flex;
  flex-direction: column;
  min-width: 0;
  overflow: hidden;
  background: var(--color-surface, white);
  border-radius: 1rem;
  border: 1px solid oklch(91% 0 0);
  box-shadow: 0 0.25rem 0.75rem oklch(20% 0 0 / 6%);
  transition: transform 120ms ease-out, box-shadow 120ms ease-out, border-color 120ms ease-out;
}
.pt-card--clickable:hover .pt-project-card, .pt-project-card:hover {
  border-color: oklch(82% 0 0);
  box-shadow: 0 0.45rem 1rem oklch(20% 0 0 / 12%);
  transform: translateY(-1px);
}
.pt-project-card__media {
  position: relative;
  width: 100%;
  aspect-ratio: 16 / 10;
  overflow: hidden;
  background: oklch(94% 0 0);
}
.pt-project-card__media-link {
  display: block;
  color: inherit;
  text-decoration: none;
}
.pt-project-card__photo {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.pt-project-card__photo-placeholder {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 0.375rem;
  color: oklch(62% 0 0);
}
.pt-project-card__photo-placeholder::after {
  content: "No Photo";
  font-size: 0.6875rem;
  font-weight: 600;
  letter-spacing: 0.03em;
  text-transform: uppercase;
}
.pt-project-card--list .pt-project-card__media:has(.pt-project-card__photo-placeholder) {
  height: auto;
}
.pt-project-card__verified {
  position: absolute;
  top: 0.75rem;
  left: 0.75rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1.65rem;
  height: 1.65rem;
  border-radius: 999px;
  background: oklch(98% 0 0 / 95%);
  color: oklch(45% 0.18 145);
  box-shadow: 0 1px 3px oklch(20% 0 0 / 18%);
}
.pt-project-card__status-wrap {
  --pt-status-stripe-h: 4px;
  --pt-status-curve: 0.6rem;
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  height: 0;
  pointer-events: none;
}
.pt-project-card__status-wrap::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  height: var(--pt-status-stripe-h);
  background: var(--pt-status-color);
}
.pt-project-card__status-pill {
  position: absolute;
  left: 0;
  bottom: 0;
  z-index: 1;
  display: inline-flex;
  align-items: center;
  gap: 0.3rem;
  padding: 0.32rem 0.7rem;
  background: var(--pt-status-color);
  color: white;
  font-size: 0.62rem;
  font-weight: 700;
  line-height: 1.15;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  text-shadow: 0 1px 1px oklch(20% 0 0 / 18%);
  border-radius: 0 var(--pt-status-curve) 0 0;
  max-width: 100%;
}
.pt-project-card__status-pill::after {
  content: "";
  position: absolute;
  left: 100%;
  bottom: var(--pt-status-stripe-h);
  width: var(--pt-status-curve);
  height: var(--pt-status-curve);
  background: var(--pt-status-color);
  -webkit-mask: radial-gradient(circle var(--pt-status-curve) at right top, transparent 99%, black 100%);
  mask: radial-gradient(circle var(--pt-status-curve) at right top, transparent 99%, black 100%);
}
.pt-project-card__status-label, .pt-project-card__status-percent {
  white-space: nowrap;
}
.pt-project-card__status-sep {
  opacity: 0.9;
}
.pt-project-card__actions {
  position: absolute;
  top: 0.75rem;
  right: 0.75rem;
  z-index: 2;
  display: inline-flex;
  flex-direction: row;
  gap: 0.4rem;
}
.pt-project-card__actions .pt-card-action-btn {
  background: transparent;
  color: white;
  filter: drop-shadow(0 1px 2px oklch(20% 0 0 / 45%));
  transition: filter 140ms ease-out;
}
.pt-project-card:hover .pt-project-card__actions .pt-card-action-btn {
  background: transparent;
  color: white;
}
.pt-project-card__actions .pt-card-action-btn:hover, .pt-project-card__actions .pt-card-action-btn:focus-visible {
  background: transparent;
  color: oklch(82% 0 0);
  filter: drop-shadow(0 2px 4px oklch(20% 0 0 / 70%));
}
.pt-project-card__actions .pt-card-action-btn:hover .pt-icon, .pt-project-card__actions .pt-card-action-btn:focus-visible .pt-icon {
  opacity: 0.7;
}
.pt-project-card__actions .pt-card-action-btn--like.pt-card-action-btn--active, .pt-project-card__actions .pt-card-action-btn--like.pt-card-action-btn--active:hover, .pt-project-card:hover .pt-project-card__actions .pt-card-action-btn--like.pt-card-action-btn--active {
  color: #ee5b4e;
}
.pt-project-card__actions .pt-card-action-btn--tag.pt-card-action-btn--active, .pt-project-card__actions .pt-card-action-btn--tag.pt-card-action-btn--active:hover, .pt-project-card:hover .pt-project-card__actions .pt-card-action-btn--tag.pt-card-action-btn--active {
  color: #3196d1;
}
.pt-card-action-btn__icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.pt-card-action-btn__icon--solid, .pt-card-action-btn--active .pt-card-action-btn__icon--outline {
  display: none;
}
.pt-card-action-btn--active .pt-card-action-btn__icon--solid {
  display: inline-flex;
}
.pt-card-action-btn--like.pt-card-action-btn--active {
  color: #ee5b4e;
}
.pt-card-action-btn--tag.pt-card-action-btn--active {
  color: #3196d1;
}
.pt-project-card__content {
  display: flex;
  flex-direction: column;
  flex: 1 1 auto;
  min-height: 0;
}
.pt-project-card__body {
  display: flex;
  flex-direction: column;
  gap: 0.35rem;
  padding: 1rem 1.15rem 0.75rem;
  flex: 1 1 auto;
  min-height: 8rem;
}
.pt-project-card__title {
  font-size: 1.05rem;
  font-weight: 700;
  color: oklch(18% 0 0);
  line-height: 1.25;
  margin: 0 0 0.3rem;
  overflow: hidden;
  text-overflow: ellipsis;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
}
.pt-project-card__title-link {
  color: inherit;
  text-decoration: none;
}
.pt-project-card__title-link:hover {
  color: oklch(35% 0.18 250);
}
.pt-project-card__meta, .pt-project-card__dates {
  margin: 0;
  font-size: 0.85rem;
  color: oklch(45% 0 0);
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.35rem;
}
.pt-project-card__meta {
  justify-content: space-between;
}
.pt-project-card__dates {
  flex-direction: column;
  align-items: flex-start;
  justify-content: center;
  gap: 0.25rem;
  min-height: 2.5rem;
}
.pt-project-card__dates .pt-project-card__date-sep {
  display: none;
}
.pt-project-card__meta-type {
  margin-left: auto;
}
.pt-project-card__meta-location, .pt-project-card__meta-type, .pt-project-card__date {
  display: inline-flex;
  align-items: center;
  gap: 0.3rem;
}
.pt-project-card__meta-location .pt-icon, .pt-project-card__meta-type .pt-icon, .pt-project-card__date .pt-icon {
  color: oklch(55% 0 0);
  flex-shrink: 0;
}
.pt-project-card__date-sep {
  color: oklch(78% 0 0);
}
.pt-project-card__date-label {
  color: oklch(45% 0 0);
}
.pt-project-card__date-value {
  color: oklch(25% 0 0);
  font-weight: 500;
}
.pt-project-card__footer {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: 0.5rem;
  padding: 0.7rem 1.15rem 0.95rem;
  margin-top: auto;
  border-top: 1px solid oklch(94% 0 0);
  background: oklch(98% 0 0);
}
.pt-project-card__sectors-row {
  display: inline-flex;
  align-items: center;
  gap: 0;
  min-height: 2rem;
}
.pt-project-card__metrics {
  display: flex;
  flex-wrap: wrap;
  gap: 0.4rem;
  align-items: center;
}
.pt-sector-icon {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1.85rem;
  height: 1.85rem;
  border-radius: 50%;
  border: 2px solid oklch(98% 0 0);
  background: var(--color-surface, white);
  color: oklch(28% 0 0);
  flex-shrink: 0;
  box-shadow: 0 0 0 1px oklch(89% 0 0);
  transition: margin-left 220ms ease-out, transform 180ms ease-out;
}
.pt-project-card__sectors-row .pt-sector-icon + .pt-sector-icon {
  margin-left: -0.6rem;
}
.pt-project-card__sectors-row:hover .pt-sector-icon + .pt-sector-icon {
  margin-left: 0.3rem;
}
.pt-sector-icon:hover {
  z-index: 3;
  transform: translateY(-2px) scale(1.05);
}
.pt-project-card__par-score {
  display: inline-block;
  width: 0.6rem;
  height: 0.6rem;
  border-radius: 50%;
  background: #22b68e;
  flex-shrink: 0;
  margin-left: 0.55rem;
}
.pt-metric-pill {
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: 0.3rem;
  padding: 0.34rem 0.7rem;
  border: 1px solid oklch(89% 0 0);
  border-radius: 999px;
  background: oklch(96% 0 0);
  color: oklch(35% 0 0);
  font-size: 0.78rem;
  font-weight: 500;
  line-height: 1;
  white-space: nowrap;
}
.pt-metric-pill .pt-icon {
  color: oklch(45% 0 0);
}
.pt-metric-pill__value {
  color: oklch(20% 0 0);
  font-weight: 600;
}
.pt-metric-pill__label {
  display: none;
  color: oklch(40% 0 0);
}
.pt-sector-icon[data-tooltip]::after, .pt-metric-pill[data-tooltip]::after, .pt-export-disabled-wrapper[data-tooltip]::after {
  content: attr(data-tooltip);
  position: absolute;
  bottom: calc(100% + 0.4rem);
  left: 50%;
  transform: translateX(-50%) translateY(4px);
  padding: 0.32rem 0.6rem;
  background-color: #181818;
  background-image: none;
  color: #ffffff;
  text-shadow: none;
  filter: none;
  font-size: 0.7rem;
  font-weight: 600;
  line-height: 1;
  letter-spacing: 0.01em;
  border-radius: 0.3rem;
  white-space: nowrap;
  opacity: 0;
  pointer-events: none;
  transition: opacity 140ms ease-out, transform 140ms ease-out;
  z-index: 10;
}
.pt-sector-icon[data-tooltip]:hover::after, .pt-metric-pill[data-tooltip]:hover::after, .pt-export-disabled-wrapper[data-tooltip]:hover::after {
  opacity: 1;
  transform: translateX(-50%) translateY(0);
}
.pt-export-disabled-wrapper {
  position: relative;
  display: inline-block;
}
.pt-export-disabled-wrapper[data-tooltip]::after {
  white-space: normal;
  max-width: 18rem;
  text-align: center;
  line-height: 1.35;
}
.pt-project-card__sectors-row > [data-tooltip]:first-child:not(:only-child)::after, .pt-project-card__metrics > [data-tooltip]:first-child:not(:only-child)::after {
  left: 0;
  transform: translateX(0) translateY(4px);
}
.pt-project-card__sectors-row > [data-tooltip]:first-child:not(:only-child):hover::after, .pt-project-card__metrics > [data-tooltip]:first-child:not(:only-child):hover::after {
  transform: translateX(0) translateY(0);
}
.pt-project-card__sectors-row > [data-tooltip]:last-child:not(:only-child)::after, .pt-project-card__metrics > [data-tooltip]:last-child:not(:only-child)::after {
  left: auto;
  right: 0;
  transform: translateX(0) translateY(4px);
}
.pt-project-card__sectors-row > [data-tooltip]:last-child:not(:only-child):hover::after, .pt-project-card__metrics > [data-tooltip]:last-child:not(:only-child):hover::after {
  transform: translateX(0) translateY(0);
}
.pt-project-card--list {
  flex-direction: row;
  align-items: stretch;
  border-radius: 0.75rem;
}
.pt-project-card--list .pt-project-card__media-link {
  flex: 0 0 14rem;
  max-width: 14rem;
}
.pt-project-card--list .pt-project-card__media {
  aspect-ratio: auto;
  height: 100%;
  min-height: 7.5rem;
}
.pt-project-card--list .pt-project-card__content {
  flex: 1 1 auto;
  padding: 0;
}
.pt-project-card--list .pt-project-card__body {
  padding: 0.85rem 1.1rem 0.5rem;
}
.pt-project-card--list .pt-project-card__footer {
  flex-direction: row;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.55rem;
  padding: 0.5rem 1.1rem 0.85rem;
  background: transparent;
  border-top: 0;
}
.pt-project-card--list .pt-project-card__sectors-row {
  min-height: 0;
}
.pt-project-card--list .pt-project-card__metrics {
  margin-left: auto;
}
.pt-project-card--list .pt-project-card__title {
  -webkit-line-clamp: 1;
  font-size: 1.1rem;
}
.pt-project-card--list .pt-metric-pill__label {
  display: inline;
}
@media (max-width: 720px) {
  .pt-project-card--list, .pt-project-hits--list .pt-project-card {
    flex-direction: column;
  }
  .pt-project-card--list .pt-project-card__media-link, .pt-project-hits--list .pt-project-card__media-link {
    flex: none;
    max-width: 100%;
  }
  .pt-project-card--list .pt-project-card__media, .pt-project-hits--list .pt-project-card__media {
    aspect-ratio: 16 / 10;
    min-height: 0;
  }
}
.pt-documents-page {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}
.pt-document-set-card {
  display: flex;
  align-items: flex-start;
  gap: 1rem;
  padding: 1rem;
  background: var(--color-surface);
  border: 1px solid var(--color-surface-3);
  border-radius: var(--radius-md, 0.5rem);
  transition: box-shadow 150ms, border-color 150ms;
}
.pt-document-set-card:hover {
  border-color: var(--color-border);
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.06);
}
.pt-document-set-card__icon-wrap {
  flex-shrink: 0;
  width: 2.5rem;
  height: 2.5rem;
  border-radius: var(--radius-sm, 0.25rem);
  background: var(--color-brand-subtle);
  display: flex;
  align-items: center;
  justify-content: center;
}
.pt-document-set-card__icon {
  width: 1.25rem;
  height: 1.25rem;
  color: var(--color-brand);
}
.pt-document-set-card__body {
  flex: 1;
  min-width: 0;
}
.pt-document-set-card__title {
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--color-text-primary);
  margin-bottom: 0.25rem;
}
.pt-document-set-card__meta {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 0.5rem;
  font-size: 0.75rem;
  color: var(--color-text-secondary);
}
.pt-document-set-card__stat {
  display: inline-flex;
  align-items: center;
  gap: 0.25rem;
}
.pt-document-set-card__stat-icon {
  width: 0.75rem;
  height: 0.75rem;
}
.pt-documentation-options {
  display: flex;
  flex-direction: column;
  gap: 1.25rem;
  padding: 1.5rem;
  border: 1px solid var(--color-surface-3);
  border-radius: var(--radius-md, 0.5rem);
  background: var(--color-surface);
}
.pt-documentation-options__intro {
  margin: 0;
  color: var(--color-text-secondary);
  font-size: 0.875rem;
  font-weight: 500;
  line-height: 1.4;
}
.pt-documentation-options__grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 18rem));
  gap: 1.25rem;
}
@media (max-width: 640px) {
  .pt-documentation-options__grid {
    grid-template-columns: minmax(0, 1fr);
  }
}
.pt-document-version-viewer {
  display: flex;
  flex-direction: column;
  gap: 0.875rem;
}
.pt-document-viewer-header {
  display: flex;
  flex-direction: column;
  gap: 0.875rem;
  padding: 1rem 1.125rem;
  border: 1px solid var(--color-surface-3);
  border-radius: var(--radius-md, 0.5rem);
  background: var(--color-surface);
  box-shadow: 0 1px 2px rgb(15 23 42 / 4%);
}
.pt-document-viewer-header__top {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 1rem;
}
.pt-document-viewer-header__back {
  display: inline-flex;
  align-items: center;
  gap: 0.375rem;
  color: var(--color-brand);
  font-size: 0.8125rem;
  font-weight: 600;
}
.pt-document-viewer-header__back:hover {
  text-decoration: underline;
}
.pt-document-viewer-header__back-icon {
  width: 0.95rem;
  height: 0.95rem;
}
.pt-document-viewer-header__download {
  min-height: 2.25rem;
  padding-inline: 0.75rem;
  font-weight: 600;
}
.pt-document-viewer-header__content {
  display: flex;
  flex-direction: column;
  gap: 0.55rem;
}
.pt-document-viewer-header__title {
  margin: 0;
  color: var(--color-text-primary);
  font-size: 1.0625rem;
  font-weight: 700;
  line-height: 1.3;
  letter-spacing: 0.035em;
}
.pt-document-viewer-header__meta {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.5rem;
}
.pt-document-viewer-header__meta .pt-status-badge {
  min-height: 1.4rem;
  padding: 0.15rem 0.55rem;
  font-size: 0.6875rem;
  font-weight: 700;
}
.pt-document-viewer-header__meta-item {
  color: var(--color-text-secondary);
  font-size: 0.8125rem;
  font-weight: 500;
}
.pt-document-viewer-header__meta-item::before {
  content: "|";
  margin-right: 0.5rem;
  color: var(--color-text-muted);
}
.pt-document-version-viewer__empty {
  display: flex;
  min-height: 22rem;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 0.625rem;
  border: 1px solid var(--color-surface-3);
  border-radius: var(--radius-md, 0.5rem);
  background: var(--color-surface);
  color: var(--color-text-secondary);
}
.pt-document-version-viewer__empty-icon {
  width: 2rem;
  height: 2rem;
  color: var(--color-text-muted);
}
@media (max-width: 960px) {
  .pt-document-viewer-header__top {
    flex-direction: column;
    align-items: flex-start;
  }
}
.pt-grading-matrix-builder {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-xl);
}
.pt-grading-matrix-builder__back {
  display: inline-flex;
  align-items: center;
  gap: 0.25rem;
  margin-bottom: var(--spacing-sm);
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--color-text-muted);
  text-decoration: none;
  transition: color 0.15s;
}
.pt-grading-matrix-builder__back:hover {
  color: var(--color-brand);
}
.pt-grading-add-btn.pt-btn {
  display: flex;
  width: 100%;
  justify-content: center;
  border: 1px dashed var(--color-border-strong, var(--color-border));
  background: transparent;
  color: var(--color-text-secondary);
  font-weight: 600;
}
.pt-grading-add-btn.pt-btn:hover {
  border-color: var(--color-brand);
  color: var(--color-brand);
  background: var(--color-brand-subtle, var(--color-surface-2));
}
.pt-grading-matrix-builder__header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: var(--spacing-lg);
  flex-wrap: wrap;
}
.pt-grading-matrix-builder__name-form {
  flex: 1 1 20rem;
  min-width: 0;
}
.pt-grading-matrix-builder__name-input {
  width: 100%;
  border: 1px solid transparent;
  background: transparent;
  font-size: var(--text-2xl);
  font-weight: 700;
  color: var(--color-text-primary);
  padding: 0.25rem 0.5rem;
  border-radius: var(--radius-md);
}
.pt-grading-matrix-builder__name-input:hover {
  border-color: var(--color-border);
}
.pt-grading-matrix-builder__name-input:focus {
  outline: none;
  border-color: var(--color-brand);
  background: var(--color-surface);
}
.pt-grading-matrix-builder__meta {
  display: flex;
  align-items: center;
  gap: var(--spacing-md);
  flex-wrap: wrap;
  margin-top: var(--spacing-xs);
}
.pt-grading-matrix-builder__actions {
  display: flex;
  align-items: center;
  gap: var(--spacing-sm);
  flex-wrap: wrap;
}
.pt-grading-category-list {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-lg);
}
.pt-grading-category-list__add {
  align-self: stretch;
}
.pt-grading-category-list__empty {
  padding: var(--spacing-lg);
}
.pt-grading-category-editor {
  display: block;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  background: var(--color-surface);
  box-shadow: var(--shadow-card);
}
.pt-grading-category-editor__bar {
  display: flex;
  align-items: center;
  gap: var(--spacing-sm);
  padding: var(--spacing-sm) var(--spacing-lg);
  border-bottom: 1px solid var(--color-border);
  background: var(--color-surface-2);
  border-radius: var(--radius-lg) var(--radius-lg) 0 0;
}
.pt-grading-category-editor[data-disclosure-open="false"] .pt-grading-category-editor__bar {
  border-bottom: none;
  border-radius: var(--radius-lg);
}
.pt-grading-category-editor__toggle, .pt-grading-criterion-editor__toggle {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--color-text-muted);
  border: none;
  background: transparent;
  padding: 0.25rem;
  border-radius: var(--radius-sm);
  cursor: pointer;
  transition: transform 0.15s ease, color 0.15s ease;
}
.pt-grading-category-editor__toggle:hover, .pt-grading-criterion-editor__toggle:hover {
  color: var(--color-text-primary);
  background: var(--color-surface-3);
}
.pt-grading-category-editor__toggle[aria-expanded="true"], .pt-grading-criterion-editor__toggle[aria-expanded="true"] {
  transform: rotate(180deg);
}
.pt-grading-category-editor__number, .pt-grading-criterion-editor__number {
  font-variant-numeric: tabular-nums;
  font-size: var(--text-xs);
  font-weight: 700;
  color: var(--color-text-muted);
  background: var(--color-surface-3);
  border-radius: var(--radius-sm);
  padding: 0.0625rem 0.375rem;
  flex: 0 0 auto;
}
.pt-grading-category-editor__title-input, .pt-grading-criterion-editor__title-input {
  flex: 1 1 auto;
  min-width: 0;
  border: 1px solid transparent;
  background: transparent;
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--color-text-primary);
  padding: 0.25rem 0.5rem;
  border-radius: var(--radius-sm);
}
.pt-grading-category-editor__title-input::placeholder, .pt-grading-criterion-editor__title-input::placeholder {
  color: var(--color-text-muted);
  font-weight: 400;
}
.pt-grading-category-editor__title-input:hover, .pt-grading-criterion-editor__title-input:hover {
  border-color: var(--color-border);
}
.pt-grading-category-editor__title-input:focus, .pt-grading-criterion-editor__title-input:focus {
  outline: none;
  border-color: var(--color-brand);
  background: var(--color-surface);
}
.pt-grading-category-editor__weight {
  flex: 0 0 auto;
}
.pt-grading-category-editor__status, .pt-grading-criterion-editor__status {
  margin-left: auto;
  flex: 0 0 auto;
  min-width: 5.5rem;
  min-height: 1.25rem;
  display: flex;
  justify-content: flex-end;
  align-items: center;
  gap: 0.375rem;
  font-size: var(--text-xs);
  color: var(--color-text-muted);
}
.pt-grading-category-editor__status[data-state="saving"], .pt-grading-criterion-editor__status[data-state="saving"] {
  color: var(--color-warning-hover);
}
.pt-grading-category-editor__status[data-state="saved"], .pt-grading-criterion-editor__status[data-state="saved"] {
  color: var(--color-success);
}
.pt-grading-category-editor__status[data-state="error"], .pt-grading-criterion-editor__status[data-state="error"] {
  color: var(--color-danger);
}
.pt-grading-category-editor__body {
  padding: var(--spacing-sm) var(--spacing-md);
  display: flex;
  flex-direction: column;
  gap: var(--spacing-sm);
}
.pt-grading-category-editor__add {
  display: flex;
}
.pt-grading-category-editor__add form {
  flex: 1 1 auto;
}
.pt-grading-category-editor__criteria {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-sm);
  padding-left: var(--spacing-md);
  border-left: 2px solid var(--color-surface-3);
}
.pt-grading-category-editor__criteria:not(:has(> *)) {
  border-left: none;
  padding-left: 0;
}
.pt-grading-category-editor__footer, .pt-grading-criterion-editor__footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--spacing-sm);
  flex-wrap: wrap;
}
.pt-grading-criterion-editor {
  display: block;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  background: var(--color-surface);
}
.pt-grading-criterion-editor__bar {
  display: flex;
  align-items: center;
  gap: var(--spacing-sm);
  padding: var(--spacing-xs) var(--spacing-md);
  background: var(--color-surface-2);
  border-radius: var(--radius-md) var(--radius-md) 0 0;
  flex-wrap: wrap;
}
.pt-grading-criterion-editor[data-disclosure-open="false"] .pt-grading-criterion-editor__bar {
  border-radius: var(--radius-md);
}
.pt-grading-criterion-editor[data-disclosure-open="true"] .pt-grading-criterion-editor__bar {
  border-bottom: 1px solid var(--color-border);
}
.pt-grading-criterion-editor__weight {
  flex: 0 0 auto;
}
.pt-grading-criterion-editor__body {
  padding: var(--spacing-sm) var(--spacing-md);
  display: flex;
  flex-direction: column;
  gap: var(--spacing-sm);
}
.pt-grading-criterion-editor__type {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: var(--spacing-sm) var(--spacing-md);
}
.pt-grading-criterion-editor__type-hint {
  flex: 1 1 12rem;
  font-size: var(--text-xs);
  color: var(--color-text-muted);
  margin: 0;
}
.pt-grading-criterion-editor__guide {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-2xs, 0.25rem);
}
.pt-grading-criterion-editor__guide-intro {
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  margin: 0 0 var(--spacing-2xs, 0.25rem);
}
.pt-grading-criterion-editor__footer {
  padding: var(--spacing-sm) var(--spacing-md);
  border-top: 1px solid var(--color-border);
}
.pt-grading-category-editor__footer {
  justify-content: flex-end;
}
.pt-grading-tiers {
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  background: var(--color-surface);
  padding: var(--spacing-lg);
}
.pt-grading-tiers__form {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-md);
}
.pt-grading-tiers__header {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-xs);
}
.pt-grading-tiers__title {
  font-size: var(--text-lg);
  font-weight: 700;
  color: var(--color-text-primary);
  margin: 0;
}
.pt-grading-tiers__description {
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  margin: 0;
}
.pt-grading-tiers__bar {
  position: relative;
  display: flex;
  width: 100%;
  height: 2.25rem;
  border-radius: var(--radius-md);
  overflow: hidden;
  background: var(--color-surface-3);
}
.pt-grading-tiers__bar:empty {
  min-height: 2.25rem;
}
.pt-grading-tiers__band {
  display: flex;
  align-items: center;
  justify-content: center;
  min-width: 0;
  height: 100%;
  padding: 0 var(--spacing-xs);
  color: #fff;
  font-size: var(--text-xs);
  font-weight: 700;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  transition: width 0.2s ease;
}
.pt-grading-tiers__band--1 {
  background: var(--color-success, #16a34a);
}
.pt-grading-tiers__band--2 {
  background: #4d9e2a;
}
.pt-grading-tiers__band--3 {
  background: #c9a227;
}
.pt-grading-tiers__band--4 {
  background: var(--color-warning, #d97706);
}
.pt-grading-tiers__band--5 {
  background: #dc6a1e;
}
.pt-grading-tiers__band--6 {
  background: var(--color-danger, #dc2626);
}
.pt-grading-tiers__band-label {
  overflow: hidden;
  text-overflow: ellipsis;
}
.pt-grading-tiers__marker {
  position: absolute;
  top: 0;
  bottom: 0;
  width: 0;
  border-left: 2px solid rgba(255, 255, 255, 0.85);
  pointer-events: none;
}
.pt-grading-tiers__marker-label {
  position: absolute;
  bottom: 2px;
  left: 3px;
  font-size: 0.625rem;
  font-weight: 700;
  color: #fff;
  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.4);
  font-variant-numeric: tabular-nums;
}
.pt-grading-tiers__rows {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-sm);
}
.pt-grading-tiers__footer {
  display: flex;
  justify-content: flex-start;
}
.pt-grading-tier-row {
  display: flex;
  align-items: flex-end;
  gap: var(--spacing-md);
  padding: var(--spacing-md);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  background: var(--color-surface-subtle, var(--color-background));
}
.pt-grading-tier-row__badge {
  flex: 0 0 auto;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1.75rem;
  height: 1.75rem;
  margin-bottom: 0.35rem;
  border-radius: var(--radius-full, 9999px);
  background: var(--color-primary, #2563eb);
  color: #fff;
  font-size: var(--text-sm);
  font-weight: 700;
}
.pt-grading-tier-row__fields {
  flex: 1 1 auto;
  display: grid;
  grid-template-columns: minmax(0, 1.2fr) minmax(0, 1.6fr) minmax(0, 0.8fr);
  gap: var(--spacing-md);
}
.pt-grading-tier-row__field {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-2xs, 0.25rem);
}
.pt-grading-tier-row__label {
  font-size: var(--text-xs);
  font-weight: 600;
  color: var(--color-text-muted);
}
.pt-grading-tier-row__field--floor {
  position: relative;
}
.pt-grading-tier-row__field--floor input:disabled {
  display: none;
}
.pt-grading-tier-row__catch-all {
  font-size: var(--text-sm);
  font-style: italic;
  color: var(--color-text-muted);
  padding: 0.5rem 0;
}
.pt-grading-tier-row__catch-all--hidden {
  display: none;
}
.pt-grading-tier-row__remove {
  flex: 0 0 auto;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.25rem;
  height: 2.25rem;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  background: transparent;
  color: var(--color-text-muted);
  cursor: pointer;
  transition: color 0.15s, border-color 0.15s, background 0.15s;
}
.pt-grading-tier-row__remove:hover:not(:disabled) {
  color: var(--color-danger, #dc2626);
  border-color: var(--color-danger, #dc2626);
  background: var(--color-danger-subtle, rgba(220, 38, 38, 0.08));
}
.pt-grading-tier-row__remove:disabled {
  opacity: 0.4;
  cursor: not-allowed;
}
@media (max-width: 640px) {
  .pt-grading-tier-row__fields {
    grid-template-columns: minmax(0, 1fr);
  }
}
.pt-grading-matrix-list {
  display: flex;
  flex-direction: column;
}
.pt-grading-matrix-list__rows {
  margin: 0;
  padding: 0;
  list-style: none;
  display: flex;
  flex-direction: column;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md, 0.375rem);
  overflow: hidden;
}
.pt-grading-matrix-list__row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: 0.875rem 1rem;
  background: var(--color-surface, #fff);
  border-bottom: 1px solid var(--color-border);
}
.pt-grading-matrix-list__row:last-child {
  border-bottom: none;
}
.pt-grading-matrix-list__row:hover {
  background: var(--color-surface-2, oklch(97.5% 0.01 250));
}
.pt-grading-matrix-list__meta {
  display: flex;
  align-items: center;
  gap: 0.625rem;
  min-width: 0;
  flex: 1 1 auto;
}
.pt-grading-matrix-list__name {
  font-weight: 600;
  color: var(--color-text-primary);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  text-decoration: none;
}
.pt-grading-matrix-list__name:hover {
  color: var(--color-primary, #2563eb);
  text-decoration: underline;
}
.pt-grading-matrix-list__version {
  font-size: var(--text-sm, 0.875rem);
  color: var(--color-text-secondary);
  white-space: nowrap;
  flex-shrink: 0;
}
.pt-grading-matrix-list__actions {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  flex-shrink: 0;
}
.pt-grading-matrix-list__empty {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 3rem 1.5rem;
  color: var(--color-text-secondary);
  font-size: var(--text-sm, 0.875rem);
  text-align: center;
  border: 1px dashed var(--color-border);
  border-radius: var(--radius-md, 0.375rem);
}
.pt-grading-summary-page {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-lg);
}
.pt-grading-summary-page__header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: var(--spacing-md);
  flex-wrap: wrap;
}
.pt-grading-summary-page__heading {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-sm);
}
.pt-grading-summary-page__back {
  display: inline-flex;
  align-items: center;
  gap: 0.25rem;
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  text-decoration: none;
}
.pt-grading-summary-page__back:hover {
  color: var(--color-primary, #2563eb);
}
.pt-grading-summary-page__title-row {
  display: flex;
  align-items: center;
  gap: var(--spacing-sm);
}
.pt-grading-summary-page__title {
  font-size: var(--text-xl);
  font-weight: 700;
  color: var(--color-text-primary);
  margin: 0;
}
.pt-grading-summary-page__version {
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  font-weight: 600;
}
.pt-grading-summary-page__actions {
  display: flex;
  gap: var(--spacing-sm);
}
.pt-grading-summary {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-lg);
}
.pt-grading-summary__bar, .pt-grading-summary__rubric {
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  background: var(--color-surface);
  padding: var(--spacing-lg);
}
.pt-grading-summary__section-title {
  font-size: var(--text-lg);
  font-weight: 700;
  color: var(--color-text-primary);
  margin: 0 0 var(--spacing-md);
}
.pt-grading-summary__bar .pt-grading-tiers__bar {
  margin-bottom: var(--spacing-md);
}
.pt-grading-summary__tiers {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: var(--spacing-sm);
}
.pt-grading-summary__tier {
  display: flex;
  align-items: center;
  gap: var(--spacing-md);
  padding: var(--spacing-sm) var(--spacing-md);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  background: var(--color-surface-subtle, var(--color-background));
}
.pt-grading-summary__tier-badge {
  flex: 0 0 auto;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1.75rem;
  height: 1.75rem;
  border-radius: var(--radius-full, 9999px);
  background: var(--color-primary, #2563eb);
  color: #fff;
  font-weight: 700;
  font-size: var(--text-sm);
}
.pt-grading-summary__tier-text {
  flex: 1 1 auto;
  display: flex;
  flex-direction: column;
}
.pt-grading-summary__tier-name {
  font-weight: 600;
  color: var(--color-text-primary);
}
.pt-grading-summary__tier-desc {
  font-size: var(--text-sm);
  color: var(--color-text-muted);
}
.pt-grading-summary__tier-floor {
  flex: 0 0 auto;
  font-weight: 600;
  color: var(--color-text-secondary, var(--color-text-muted));
}
.pt-grading-summary__rubric-head {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: var(--spacing-md);
  margin-bottom: var(--spacing-md);
}
.pt-grading-summary__rubric-head .pt-grading-summary__section-title {
  margin: 0;
}
.pt-grading-summary__category {
  border-top: 1px solid var(--color-border);
  padding-top: var(--spacing-md);
  margin-top: var(--spacing-md);
}
.pt-grading-summary__category:first-of-type {
  border-top: 0;
  padding-top: 0;
  margin-top: 0;
}
.pt-grading-summary__category-head {
  display: flex;
  align-items: center;
  gap: var(--spacing-sm);
  margin-bottom: var(--spacing-sm);
}
.pt-grading-summary__category-number {
  font-weight: 700;
  color: var(--color-text-muted);
}
.pt-grading-summary__category-name {
  flex: 1 1 auto;
  font-size: 1rem;
  font-weight: 700;
  color: var(--color-text-primary);
  margin: 0;
}
.pt-grading-summary__category-weight {
  font-weight: 600;
  color: var(--color-text-muted);
}
.pt-grading-summary__criteria {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: var(--spacing-md);
}
.pt-grading-summary__criterion {
  padding-left: var(--spacing-md);
  border-left: 2px solid var(--color-border);
}
.pt-grading-summary__criterion-head {
  display: flex;
  align-items: center;
  gap: var(--spacing-sm);
  margin-bottom: var(--spacing-xs);
}
.pt-grading-summary__criterion-number {
  font-weight: 600;
  color: var(--color-text-muted);
  font-size: var(--text-sm);
}
.pt-grading-summary__criterion-title {
  flex: 1 1 auto;
  font-weight: 600;
  color: var(--color-text-primary);
}
.pt-grading-summary__criterion-weight {
  color: var(--color-text-muted);
  font-size: var(--text-sm);
}
.pt-grading-summary__guide {
  margin: 0;
  display: grid;
  grid-template-columns: minmax(0, 12rem) 1fr;
  gap: 0.25rem var(--spacing-md);
}
.pt-grading-summary__guide-term {
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--color-text-secondary, var(--color-text-muted));
}
.pt-grading-summary__guide-desc {
  margin: 0;
  font-size: var(--text-sm);
  color: var(--color-text-primary);
}
.pt-grading-summary__empty {
  color: var(--color-text-muted);
  font-size: var(--text-sm);
}
@media (max-width: 640px) {
  .pt-grading-summary__guide {
    grid-template-columns: minmax(0, 1fr);
    gap: 0;
    margin-bottom: var(--spacing-sm);
  }
}
.pt-vendor-hub__loading, .pt-vendor-hub__empty {
  padding: var(--spacing-lg);
  color: var(--color-text-muted);
  font-size: var(--text-sm);
}
.pt-issues-page {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}
.pt-issue-card {
  display: flex;
  align-items: flex-start;
  gap: 0.75rem;
  padding: 0.875rem 1rem;
  background: var(--color-surface);
  border: 1px solid var(--color-surface-3);
  border-radius: var(--radius-md, 0.5rem);
  border-left-width: 3px;
  box-shadow: 0 0.25rem 0.75rem oklch(20% 0 0 / 6%);
  transition: box-shadow 0.15s ease, transform 0.15s ease, border-color 0.15s ease;
}
.pt-issue-card:hover {
  box-shadow: 0 0.5rem 1.25rem oklch(20% 0 0 / 10%);
  transform: translateY(-1px);
}
.pt-issue-card--default {
  border-left-color: var(--color-surface-3);
}
.pt-issue-card--warning {
  border-left-color: var(--color-warning);
}
.pt-issue-card--info {
  border-left-color: var(--color-info, #0ea5e9);
}
.pt-issue-card--success {
  border-left-color: var(--color-success);
}
.pt-issue-card--danger {
  border-left-color: var(--color-danger, #dc2626);
}
a.pt-issue-card {
  cursor: pointer;
  text-decoration: none;
  color: inherit;
}
.pt-issue-card--selected {
  border-color: var(--color-brand);
}
.pt-issue-card--active {
  border-color: var(--color-brand);
  background: var(--color-surface-2, #f8fafc);
}
.pt-issue-card__body {
  flex: 1;
  min-width: 0;
}
.pt-issue-card__title {
  font-size: 0.8125rem;
  font-weight: 600;
  color: var(--color-text-primary);
  margin-bottom: 0.625rem;
}
.pt-issue-card__meta {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 0.5rem 1rem;
  font-size: 0.6875rem;
  color: var(--color-text-secondary);
}
.pt-issue-card__meta-main {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 0.875rem;
  min-width: 0;
}
.pt-issue-card__meta-aside {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 0.875rem;
  margin-left: auto;
  white-space: nowrap;
}
.pt-issue-card__meta-item {
  display: inline-flex;
  align-items: center;
  gap: 0.25rem;
}
.pt-issue-card__meta-icon {
  width: 0.75rem;
  height: 0.75rem;
}
.pt-issue-detail__comments {
  margin-top: 1.25rem;
  padding-top: 1.25rem;
  border-top: 1px solid var(--color-surface-3);
}
.pt-issue-comments {
  display: flex;
  flex-direction: column;
  gap: 0.875rem;
  container-type: inline-size;
}
.pt-issue-comments__channel {
  display: flex;
  align-items: center;
  gap: 0.625rem;
  flex-wrap: wrap;
}
.pt-issue-comments__channel-label {
  font-size: 0.75rem;
  font-weight: 500;
  color: var(--color-text-secondary);
}
.pt-issue-comments__channel-trigger {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  max-width: 100%;
  padding: 0.3rem 0.625rem;
  border: 1px solid var(--color-surface-3);
  border-radius: var(--radius-md, 0.5rem);
  background: var(--color-surface);
  cursor: pointer;
}
@container (max-width: 22rem) {
  .pt-issue-comments__channel {
    flex-direction: column;
    align-items: stretch;
    gap: 0.375rem;
  }
  .pt-issue-comments__channel-trigger {
    justify-content: space-between;
    width: 100%;
  }
}
.pt-issue-comments__channel-trigger:hover {
  background: var(--color-surface-2, #f1f5f9);
}
.pt-issue-comments__channel-body {
  display: inline-flex;
  align-items: center;
  gap: 0.375rem;
  min-width: 0;
}
.pt-issue-comments__channel-role {
  font-size: 0.75rem;
  color: var(--color-text-secondary);
}
.pt-issue-comments__channel-name {
  font-size: 0.8125rem;
  font-weight: 600;
  color: var(--color-text-primary);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.pt-issue-comments__channel-option {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  width: 100%;
  min-width: 14rem;
  padding: 0.4rem 0.625rem;
  background: transparent;
  border: 0;
  cursor: pointer;
  text-align: left;
}
.pt-issue-comments__channel-option:hover {
  background: var(--color-surface-2, #f1f5f9);
}
.pt-issue-comments__channel .pt-dropdown__menu {
  left: 0;
  right: auto;
  max-width: min(20rem, 80vw);
}
.pt-issue-comments__channel-count {
  font-size: 0.75rem;
  color: var(--color-text-secondary);
  background: var(--color-surface-2, #f1f5f9);
  border-radius: 999px;
  padding: 0.05rem 0.45rem;
}
.pt-issue-comments__panel.is-hidden {
  display: none;
}
.pt-issue-comments__visibility {
  margin-bottom: 0.5rem;
  color: var(--color-text-secondary);
  font-size: 0.75rem;
}
.pt-issue-comments__list {
  display: flex;
  flex-direction: column;
  gap: 0;
}
.pt-issue-comments__empty {
  color: var(--color-text-secondary);
  font-size: 0.8125rem;
  padding: 0.5rem 0;
}
.pt-issue-comment {
  display: flex;
  gap: 0.625rem;
  padding: 0.5rem 0 0.125rem;
  --comment-date-gutter: 7.5rem;
}
.pt-issue-comment__avatar {
  flex: 0 0 auto;
  width: 1.75rem;
}
.pt-issue-comment__body {
  flex: 1 1 auto;
  min-width: 0;
  position: relative;
}
.pt-issue-comment__author {
  display: block;
  padding-right: var(--comment-date-gutter);
  font-size: 0.8125rem;
  font-weight: 600;
  color: var(--color-text-primary);
}
.pt-issue-comment__date {
  position: absolute;
  top: 0;
  right: 0;
  font-size: 0.6875rem;
  color: var(--color-text-secondary);
  white-space: nowrap;
}
.pt-issue-comment__text {
  font-size: 0.8125rem;
  color: var(--color-text-primary);
}
.pt-issue-comment__text p {
  margin: 0;
}
.pt-issue-comment__text p + p {
  margin-top: 0.35em;
}
.pt-issue-comment--grouped {
  padding-top: 0.125rem;
}
.pt-issue-comment--grouped .pt-issue-comment__avatar {
  display: none;
}
.pt-issue-comment--grouped .pt-issue-comment__body {
  margin-left: 2.375rem;
}
.pt-issue-comment--grouped .pt-issue-comment__author {
  display: none;
}
.pt-issue-comment--grouped .pt-issue-comment__text {
  padding-right: var(--comment-date-gutter);
}
.pt-issue-comment.is-page-leader.pt-issue-comment--grouped {
  padding-top: 0.5rem;
}
.pt-issue-comment.is-page-leader.pt-issue-comment--grouped .pt-issue-comment__avatar {
  display: block;
}
.pt-issue-comment.is-page-leader.pt-issue-comment--grouped .pt-issue-comment__body {
  margin-left: 0;
}
.pt-issue-comment.is-page-leader.pt-issue-comment--grouped .pt-issue-comment__author {
  display: block;
}
.pt-issue-comment.is-page-leader.pt-issue-comment--grouped .pt-issue-comment__text {
  padding-right: 0;
}
.pt-issue-comment.is-paged-out {
  display: none;
}
.pt-issue-comments__pagination {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  padding-top: 0.5rem;
  margin-top: 0.25rem;
  border-top: 1px solid var(--color-surface-2, #f1f5f9);
}
.pt-issue-comments__page-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1.5rem;
  height: 1.5rem;
  border: 1px solid var(--color-surface-3);
  border-radius: var(--radius-sm, 0.25rem);
  background: var(--color-surface);
  color: var(--color-text-primary);
  cursor: pointer;
  line-height: 1;
}
.pt-issue-comments__page-btn:hover:not(:disabled) {
  background: var(--color-surface-2, #f1f5f9);
}
.pt-issue-comments__page-btn:disabled {
  opacity: 0.4;
  cursor: default;
}
.pt-issue-comments__page-info {
  font-size: 0.75rem;
  color: var(--color-text-secondary);
  min-width: 2.5rem;
  text-align: center;
}
.pt-issue-comments__form {
  margin-top: 0.25rem;
}
.pt-issue-comments__compose {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.375rem 0.5rem;
  border: 1px solid var(--color-surface-3);
  border-radius: var(--radius-md, 0.5rem);
  background: var(--color-surface);
}
.pt-issue-comments__compose:focus-within {
  border-color: var(--color-primary, #2563eb);
}
.pt-issue-comments__compose-avatar {
  flex: 0 0 auto;
  display: flex;
  align-items: center;
}
.pt-issue-comments__input {
  flex: 1 1 auto;
  resize: none;
  border: 0;
  outline: none;
  background: transparent;
  font-size: 0.8125rem;
  line-height: 1.4;
  color: var(--color-text-primary);
  max-height: 8rem;
  padding: 0.25rem 0;
}
.pt-issue-comments__input:focus, .pt-issue-comments__input:focus-visible {
  outline: none;
  box-shadow: none;
}
.pt-issue-comments__submit {
  flex: 0 0 auto;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1.875rem;
  height: 1.875rem;
  border-radius: 999px;
  border: 0;
  background: var(--color-surface-3);
  color: #fff;
  cursor: not-allowed;
  transition: background-color 0.15s ease;
}
.pt-issue-comments__submit.is-active {
  background: var(--color-primary, #2563eb);
  cursor: pointer;
}
.pt-issue-history__entry {
  display: flex;
  flex-direction: column;
  gap: 0.375rem;
}
.pt-issue-history__head {
  display: flex;
  align-items: center;
  gap: 0.5rem;
}
.pt-issue-history__sentence {
  margin: 0;
  font-size: 0.875rem;
  color: var(--color-text-primary);
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 0.375rem;
}
.pt-issue-history .pt-timeline__entry:not(:last-child)::before {
  left: calc(0.375rem - 1px);
}
.pt-issue-history .pt-timeline__entry:not(:last-child):not(.is-last-visible)::after {
  content: "";
  position: absolute;
  left: 0.375rem;
  top: 50%;
  transform: translate(-50%, -50%);
  width: 0;
  height: 0;
  border-left: 5px solid transparent;
  border-right: 5px solid transparent;
  border-top: 8px solid var(--color-border);
}
.pt-issue-history .pt-timeline__entry.is-last-visible::before, .pt-issue-history .pt-timeline__entry.is-last-visible::after {
  display: none;
}
.pt-issue-history .pt-timeline__entry.is-last-visible.has-more-below::before {
  content: "";
  display: block;
  position: absolute;
  left: calc(0.375rem - 1px);
  top: 1.25rem;
  bottom: 0;
  width: 2px;
  background: var(--color-border);
}
.pt-issue-history .pt-timeline__entry.is-paged-out {
  display: none;
}
.pt-issue-history__more {
  position: relative;
  height: 1.5rem;
}
.pt-issue-history__more::before {
  content: "";
  position: absolute;
  left: calc(0.375rem - 1px);
  width: 2px;
  top: 0;
  bottom: 0;
  background: var(--color-border);
}
.pt-issue-history__more::after {
  content: "";
  position: absolute;
  left: 0.375rem;
  top: 50%;
  transform: translate(-50%, -50%);
  width: 0;
  height: 0;
  border-left: 5px solid transparent;
  border-right: 5px solid transparent;
  border-top: 8px solid var(--color-border);
}
.pt-issue-history__pagination {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  padding-top: 0.5rem;
  margin-top: 0.25rem;
  border-top: 1px solid var(--color-surface-2, #f1f5f9);
}
.pt-issue-history__page-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1.5rem;
  height: 1.5rem;
  border: 1px solid var(--color-surface-3);
  border-radius: var(--radius-sm, 0.25rem);
  background: var(--color-surface);
  color: var(--color-text-primary);
  cursor: pointer;
  line-height: 1;
}
.pt-issue-history__page-btn:hover:not(:disabled) {
  background: var(--color-surface-2, #f1f5f9);
}
.pt-issue-history__page-btn:disabled {
  opacity: 0.4;
  cursor: default;
}
.pt-issue-history__page-info {
  font-size: 0.75rem;
  color: var(--color-text-secondary);
  min-width: 2.5rem;
  text-align: center;
}
.pt-issue-history__changes {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
}
.pt-issue-history__change {
  display: flex;
  align-items: center;
  gap: 0.375rem;
  font-size: 0.8125rem;
  color: var(--color-text-secondary);
}
.pt-issue-history__change-label {
  font-weight: 500;
  color: var(--color-text-primary);
}
.pt-issue-history__change-value {
  color: var(--color-text-secondary);
}
.pt-issue-history__clarification {
  margin: 0;
  font-size: 0.75rem;
  font-style: italic;
  color: var(--color-text-secondary);
}
.pt-issue-history__empty {
  margin: 0;
  padding: 1rem 0;
  font-size: 0.875rem;
  color: var(--color-text-secondary);
}
.pt-issue-form-modal .pt-modal__container {
  max-width: none;
  width: 100%;
}
.pt-issue-form {
  display: contents;
}
.pt-issue-form-modal .pt-modal__body {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}
.pt-issue-form__severity {
  display: inline-flex;
  gap: 0;
  border: 1px solid var(--color-surface-3);
  border-radius: var(--radius-md, 0.5rem);
  overflow: hidden;
}
.pt-severity-toggle {
  appearance: none;
  border: 0;
  border-right: 1px solid var(--color-surface-3);
  background: var(--color-surface);
  padding: 0.4375rem 0.875rem;
  font-size: 0.8125rem;
  font-weight: 600;
  color: var(--color-text-secondary);
  cursor: pointer;
}
.pt-severity-toggle:last-child {
  border-right: 0;
}
.pt-severity-toggle.is-active {
  color: #fff;
}
.pt-severity-toggle--danger.is-active {
  background: var(--color-danger, #dc2626);
}
.pt-severity-toggle--warning.is-active {
  background: var(--color-warning, #d97706);
}
.pt-severity-toggle--info.is-active {
  background: var(--color-info, #0ea5e9);
}
.pt-severity-toggle--default.is-active {
  background: var(--color-text-secondary);
}
.pt-issue-counters {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  margin-bottom: 1rem;
}
.pt-issue-counters__stat {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  min-width: 4.5rem;
  padding: 0.5rem 0.75rem;
  border: 1px solid var(--color-surface-3);
  border-radius: var(--radius-md, 0.5rem);
  background: var(--color-surface);
  border-left-width: 3px;
}
.pt-issue-counters__stat--default {
  border-left-color: var(--color-text-secondary);
}
.pt-issue-counters__stat--warning {
  border-left-color: var(--color-warning);
}
.pt-issue-counters__stat--info {
  border-left-color: var(--color-info, #0ea5e9);
}
.pt-issue-counters__stat--success {
  border-left-color: var(--color-success);
}
.pt-issue-counters__stat--danger {
  border-left-color: var(--color-danger, #dc2626);
}
.pt-issue-counters__count {
  font-size: 1.25rem;
  font-weight: 700;
  line-height: 1.1;
  color: var(--color-text-primary);
}
.pt-issue-counters__label {
  font-size: 0.6875rem;
  color: var(--color-text-secondary);
}
.pt-issues-toolbar {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.75rem;
  margin-bottom: 0.75rem;
}
.pt-issues-toolbar__search {
  position: relative;
  display: inline-flex;
  align-items: center;
  flex: 1 1 14rem;
  min-width: 12rem;
}
.pt-issues-toolbar__search-icon {
  position: absolute;
  left: 0.625rem;
  width: 1rem;
  height: 1rem;
  color: var(--color-text-secondary);
  pointer-events: none;
}
.pt-issues-toolbar__search-input {
  width: 100%;
  padding: 0.4375rem 0.75rem 0.4375rem 2rem;
  font-size: 0.8125rem;
  border: 1px solid var(--color-surface-3);
  border-radius: var(--radius-md, 0.5rem);
  background: var(--color-surface);
  color: var(--color-text-primary);
}
.pt-issues-toolbar__search-input:focus {
  outline: 2px solid var(--color-primary, #2563eb);
  outline-offset: -1px;
}
.pt-issues-toolbar__filters {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
}
.pt-issues-toolbar__group {
  display: inline-flex;
  gap: 0.25rem;
  margin: 0;
  padding: 0;
  border: 0;
}
.pt-issues-toolbar__export {
  display: inline-flex;
  align-items: center;
}
.pt-issues-toolbar__export .pt-btn--secondary {
  background: transparent;
}
.pt-issues-toolbar__export .pt-btn--secondary:hover {
  background: var(--color-surface-2);
}
.pt-issues-toolbar__count {
  margin-left: auto;
  font-size: 0.6875rem;
  color: var(--color-text-secondary);
  white-space: nowrap;
}
.pt-issues-layout {
  display: grid;
  grid-template-columns: minmax(0, 60fr) minmax(0, 40fr);
  grid-template-rows: auto 1fr;
  grid-template-areas: "toolbar toolbar" "main    detail";
  gap: 0.75rem 1rem;
  align-items: start;
}
.pt-issues-layout__toolbar {
  grid-area: toolbar;
  min-width: 0;
}
.pt-issues-layout__main {
  grid-area: main;
  min-width: 0;
}
.pt-issues-layout__detail {
  grid-area: detail;
  align-self: start;
  position: sticky;
  top: 1rem;
  max-height: calc(100vh - 2rem);
  overflow-y: auto;
  scrollbar-width: thin;
  scrollbar-color: transparent transparent;
}
.pt-issues-layout__detail:hover {
  scrollbar-color: var(--color-surface-3) transparent;
}
.pt-issues-layout__detail::-webkit-scrollbar {
  width: 6px;
}
.pt-issues-layout__detail::-webkit-scrollbar-track {
  background: transparent;
}
.pt-issues-layout__detail::-webkit-scrollbar-thumb {
  background: transparent;
  border-radius: 3px;
}
.pt-issues-layout__detail:hover::-webkit-scrollbar-thumb {
  background: var(--color-surface-3);
}
.pt-issues-list {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}
@media (max-width: 60rem) {
  .pt-issues-layout {
    display: flex;
    flex-direction: column;
  }
  .pt-issues-layout__detail {
    order: 1;
    position: static;
    width: 100%;
    max-height: none;
    overflow-y: visible;
  }
  .pt-issues-layout__toolbar {
    order: 2;
  }
  .pt-issues-layout__main {
    order: 3;
  }
}
.pt-issue-detail-frame {
  display: block;
}
.pt-issue-detail {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  padding: 1.25rem;
  background: var(--color-surface);
  border: 1px solid var(--color-surface-3);
  border-radius: var(--radius-md, 0.5rem);
}
.pt-issue-detail__head-row {
  display: flex;
  align-items: flex-start;
  gap: 1rem;
}
.pt-issue-detail__head-main {
  flex: 1;
  min-width: 0;
}
.pt-issue-detail__head-actions {
  display: flex;
  align-items: center;
  gap: 0.375rem;
  flex-shrink: 0;
}
.pt-issue-detail__title {
  font-size: 1rem;
  font-weight: 700;
  color: var(--color-text-primary);
  margin: 0;
  overflow-wrap: anywhere;
}
.pt-issue-detail__reference {
  font-size: 0.75rem;
  color: var(--color-text-secondary);
  margin-top: 0.125rem;
}
.pt-issue-detail__section-title {
  font-size: 0.75rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.03em;
  color: var(--color-text-secondary);
  margin: 0 0 0.375rem;
}
.pt-issue-detail__creator {
  display: inline-flex;
  align-items: center;
  gap: 0.375rem;
}
.pt-issue-detail__meta .pt-description-list--horizontal .pt-description-list__item {
  align-items: center;
}
.pt-issue-detail__actions {
  border-top: 1px solid var(--color-surface-3);
  padding-top: 1rem;
}
.pt-issue-detail__actions-group {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 0.5rem;
}
.pt-issue-detail__actions-group form {
  display: inline-flex;
  margin: 0;
}
.pt-issue-detail__title[data-inline-edit-target="display"], .pt-issue-detail__severity-display {
  cursor: pointer;
  border-radius: var(--radius-sm, 0.25rem);
  transition: background 0.12s ease;
}
.pt-issue-detail__title[data-inline-edit-target="display"] {
  display: inline-flex;
  align-items: center;
  width: fit-content;
  max-width: 100%;
}
.pt-issue-detail__title[data-inline-edit-target="display"]:hover, .pt-issue-detail__severity-display:hover {
  background: var(--color-surface-2, #f1f5f9);
}
.pt-issue-detail__edit-pencil {
  display: none;
  margin-left: 0.375rem;
  color: var(--color-text-secondary);
  vertical-align: middle;
}
.pt-issue-detail__title[data-inline-edit-target="display"]:hover .pt-issue-detail__edit-pencil, .pt-issue-detail__severity-display:hover .pt-issue-detail__edit-pencil {
  display: inline-flex;
}
.pt-issue-inline-form {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  margin: 0.25rem 0;
}
.pt-issue-detail__title-edit {
  width: 100%;
}
.pt-issue-inline-form--title, .pt-issue-inline-form--title .pt-input {
  width: 100%;
}
.pt-issue-inline-form--severity {
  align-items: flex-start;
}
.pt-issue-inline-form--severity .pt-issue-form__severity {
  display: inline-flex;
  width: fit-content;
}
.pt-issue-detail__comments .pt-tabs__panel:not([hidden]) {
  animation: pt-issue-tab-fade 0.18s ease;
}
@keyframes pt-issue-tab-fade {
  from {
    opacity: 0;
    transform: translateY(4px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}
.pt-invitations-page {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}
.pt-invitations-page__section-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  margin-bottom: 0.25rem;
}
.pt-invitations-page__section-header .pt-table-columns-menu {
  flex-shrink: 0;
}
.pt-invitations-grid.pt-ag-grid-container {
  height: clamp(32rem, calc(100vh - 16rem), 52rem);
  min-height: 28rem;
}
.pt-invitations-grid .ag-cell {
  display: flex;
  align-items: center;
}
.pt-invitations-grid__cell {
  display: inline-flex;
  align-items: center;
  min-height: 100%;
  width: 100%;
}
.pt-invitations-grid__link {
  color: var(--color-brand);
  font-weight: 500;
  text-decoration: none;
}
.pt-invitations-grid__link:hover {
  text-decoration: underline;
}
.pt-invitations-grid__text {
  color: var(--color-text-primary);
}
.pt-invitations-grid__subject {
  display: inline-flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 0.25rem;
}
.pt-invitations-grid__subject-prefix {
  color: var(--color-text-secondary);
}
.pt-invitations-grid__subject-roles {
  color: var(--color-text-primary);
  font-weight: 600;
}
.pt-invitations-grid__expired {
  color: var(--color-danger);
  font-weight: 600;
}
.pt-invitations-grid__empty-overlay {
  color: var(--color-text-secondary);
}
.pt-invitation-rsvp-panel {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
  margin-bottom: 1.25rem;
}
.pt-invitation-rsvp-box {
  border: 1px solid var(--color-border);
  border-radius: 0.25rem;
  background: var(--color-surface, #fff);
  box-shadow: 0 1px 2px oklch(0% 0 0 / 4%), 0 10px 24px oklch(0% 0 0 / 6%);
  overflow: hidden;
}
.pt-invitation-rsvp-box__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  padding: 0.875rem 1rem;
  border-bottom: 1px solid var(--color-border-subtle, rgba(15, 23, 42, 0.08));
  background: var(--color-surface-2, oklch(97.5% 0.01 250));
}
.pt-invitation-rsvp-box__title-row {
  display: flex;
  align-items: center;
  min-width: 0;
  gap: 0.5rem;
}
.pt-invitation-rsvp-box__icon {
  width: 1rem;
  height: 1rem;
  flex-shrink: 0;
  color: var(--color-brand);
}
.pt-invitation-rsvp-box__title {
  margin: 0;
  font-size: 1rem;
  font-weight: 700;
  color: var(--color-text-primary);
}
.pt-invitation-rsvp-box__expiry {
  margin: 0;
  color: var(--color-danger);
  font-size: 0.875rem;
  font-weight: 600;
  white-space: nowrap;
}
.pt-invitation-rsvp-box__body {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
  padding: 1rem;
}
.pt-invitation-rsvp-box__subtitle {
  margin: 0;
  color: var(--color-text-secondary);
  line-height: 1.5;
}
.pt-invitation-rsvp-box__roles-label {
  font-size: 0.8125rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}
.pt-invitation-rsvp-box__rows {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}
.pt-invitation-rsvp-box__row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: 0.75rem;
  border: 1px solid var(--color-border-subtle, rgba(15, 23, 42, 0.08));
  border-radius: 0.25rem;
  background: var(--color-surface, #fff);
}
.pt-invitation-rsvp-box__row:first-child {
  border-top: 1px solid var(--color-border-subtle, rgba(15, 23, 42, 0.08));
}
.pt-invitation-rsvp-box__role-block {
  min-width: 0;
}
.pt-invitation-rsvp-box__role-label {
  margin-bottom: 0.125rem;
  color: var(--color-text-tertiary, var(--color-text-secondary));
  font-size: 0.75rem;
  font-weight: 600;
  line-height: 1.2;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}
.pt-invitation-rsvp-box__role {
  font-weight: 600;
  color: var(--color-text-primary);
  line-height: 1.35;
}
.pt-invitation-rsvp-box__actions {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  flex-shrink: 0;
}
.pt-invitation-rsvp-box__actions .pt-btn {
  width: 7.25rem;
  min-width: 7.25rem;
  height: 2.25rem;
  justify-content: center;
  border-radius: 0.25rem;
  text-align: center;
}
.pt-invitation-rsvp-box__actions .pt-btn__label {
  width: 100%;
  text-align: center;
}
.pt-invitation-rsvp-box__state {
  display: inline-flex;
  align-items: center;
  gap: 0.375rem;
  font-weight: 600;
}
.pt-invitation-rsvp-box__state--accepted {
  color: var(--color-success);
}
.pt-invitation-rsvp-box__state--declined {
  color: var(--color-danger);
}
.pt-invitation-rsvp-panel__modal-body .panel-wrapper {
  margin-bottom: 0.75rem;
}
.pt-invitation-rsvp-panel__upgrade p {
  margin: 0;
  color: var(--color-text-primary);
}
.pt-invitation-modal__header {
  display: flex;
  flex-direction: column;
  gap: 0.375rem;
}
.pt-invitation-modal__title {
  margin: 0;
  font-size: 1rem;
  font-weight: 700;
  color: var(--color-text-primary);
}
.pt-invitation-modal__subtitle {
  margin: 0;
  color: var(--color-text-secondary);
}
.pt-invitation-modal__form {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}
.pt-invitation-modal__body {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}
.pt-invitation-modal__footer {
  display: flex;
  justify-content: flex-end;
  align-items: center;
  gap: 0.625rem;
  padding-top: 0.25rem;
}
.pt-invitation-modal__warning {
  margin: 0;
  color: var(--color-danger);
  font-size: 0.875rem;
  font-weight: 600;
}
.pt-invitation-accept-modal__table-wrap {
  overflow: auto;
  border: 1px solid var(--color-border-subtle, rgba(15, 23, 42, 0.08));
  border-radius: 0.25rem;
}
.pt-invitation-accept-modal__table {
  width: 100%;
  border-collapse: collapse;
}
.pt-invitation-accept-modal__table th {
  background: var(--color-surface-2, oklch(97.5% 0.01 250));
  color: var(--color-text-secondary);
  font-size: 0.75rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}
.pt-invitation-accept-modal__table th, .pt-invitation-accept-modal__table td {
  padding: 0.625rem 0.75rem;
  text-align: left;
  border-bottom: 1px solid var(--color-border-subtle, rgba(15, 23, 42, 0.08));
}
.pt-invitation-accept-modal__table tr:last-child td {
  border-bottom: none;
}
.pt-invitation-accept-modal__cell--role {
  min-width: 220px;
}
.pt-invitation-accept-modal__select-wrap {
  position: relative;
  width: 100%;
}
.pt-invitation-accept-modal__role-select {
  width: 100%;
  min-width: 200px;
  min-height: 2.375rem;
  padding: 0.5rem 2.25rem 0.5rem 0.75rem;
  border: 1px solid var(--color-border);
  border-radius: 0.25rem;
  background-color: var(--color-surface, #fff);
  color: var(--color-text-primary);
  font-size: 0.875rem;
  line-height: 1.25rem;
  box-shadow: 0 1px 1px oklch(0% 0 0 / 3%);
  transition: border-color 120ms ease, box-shadow 120ms ease;
}
.pt-invitation-accept-modal__role-select:focus {
  border-color: var(--color-brand);
  outline: none;
  box-shadow: 0 0 0 3px color-mix(in srgb, oklch(45% 0.18 250) 18%, transparent);
  @supports (color: color-mix(in lab, red, red)) {
    box-shadow: 0 0 0 3px color-mix(in oklch, var(--color-brand) 18%, transparent);
  }
}
.pt-invitation-decline-modal__reasons {
  display: flex;
  flex-direction: column;
  gap: 0.625rem;
}
.pt-invitation-decline-modal__reason {
  display: flex;
  align-items: flex-start;
  gap: 0.75rem;
  padding: 0.75rem;
  border: 1px solid var(--color-border-subtle, rgba(15, 23, 42, 0.08));
  border-radius: 0.25rem;
  background: var(--color-surface, #fff);
  color: var(--color-text-primary);
  cursor: pointer;
  transition: border-color 120ms ease, background 120ms ease, box-shadow 120ms ease;
}
.pt-invitation-decline-modal__reason:hover {
  border-color: var(--color-border);
  background: var(--color-surface-2, oklch(98% 0.005 250));
}
.pt-invitation-decline-modal__reason input[type="radio"] {
  width: 1rem;
  height: 1rem;
  margin-top: 0.125rem;
  accent-color: var(--color-brand);
}
.pt-invitation-decline-modal__reason-text {
  display: flex;
  flex-direction: column;
  gap: 0.125rem;
  line-height: 1.4;
}
.pt-invitation-decline-modal__reason-text small {
  color: var(--color-text-secondary);
  font-size: 0.75rem;
  font-style: italic;
}
.pt-invitation-decline-modal__other {
  margin-top: 0.25rem;
}
.pt-invitation-decline-modal__textarea {
  width: 100%;
  min-height: 7rem;
  resize: vertical;
  padding: 0.75rem;
  border: 1px solid var(--color-border);
  border-radius: 0.25rem;
  background: var(--color-surface, #fff);
  color: var(--color-text-primary);
  line-height: 1.5;
  transition: border-color 120ms ease, box-shadow 120ms ease;
}
.pt-invitation-decline-modal__textarea:focus {
  border-color: var(--color-brand);
  outline: none;
  box-shadow: 0 0 0 3px color-mix(in srgb, oklch(45% 0.18 250) 18%, transparent);
  @supports (color: color-mix(in lab, red, red)) {
    box-shadow: 0 0 0 3px color-mix(in oklch, var(--color-brand) 18%, transparent);
  }
}
.pt-invitation-pre-accept-modal__grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.75rem;
}
@media (max-width: 720px) {
  .pt-invitations-page__section-header, .pt-invitation-rsvp-box__header, .pt-invitation-rsvp-box__row {
    align-items: stretch;
    flex-direction: column;
  }
  .pt-invitation-rsvp-box__expiry {
    white-space: normal;
  }
  .pt-invitation-rsvp-box__actions {
    width: 100%;
  }
  .pt-invitation-rsvp-box__actions .pt-btn {
    flex: 1;
    width: auto;
    min-width: 0;
  }
  .pt-invitation-modal__footer {
    justify-content: stretch;
  }
  .pt-invitation-modal__footer .pt-btn {
    flex: 1;
  }
  .pt-invitation-pre-accept-modal__grid {
    grid-template-columns: 1fr;
  }
}
@media (max-width: 768px) {
  .pt-invitation-rsvp-box__row {
    flex-direction: column;
    align-items: flex-start;
  }
  .pt-invitation-rsvp-box__actions {
    width: 100%;
    flex-wrap: wrap;
  }
  .pt-invitation-pre-accept-modal__grid {
    grid-template-columns: 1fr;
  }
}
.pt-link-project-modal, .pt-link-project-modal .pt-modal__container, .pt-link-project-modal .pt-modal__body {
  overflow: visible;
}
.pt-link-project-modal {
  max-height: none;
}
.pt-link-project-form {
  display: flex;
  flex-direction: column;
  font-family: var(--font-sans);
  color: var(--color-text-primary);
}
.pt-link-project-form__intro {
  margin: 0 0 1.75rem;
  font-size: var(--text-sm);
  color: var(--color-text-secondary);
}
.pt-link-project-form__error {
  display: flex;
  align-items: flex-start;
  gap: 0.5rem;
  margin: 0 0 1rem;
  padding: 0.75rem;
  border-radius: 0.375rem;
  font-size: var(--text-sm);
  background: var(--color-danger-soft, #fef2f2);
  color: var(--color-danger-strong, #b91c1c);
  border: 1px solid var(--color-danger, #ef4444);
}
.pt-link-project-form__error svg {
  flex-shrink: 0;
  margin-top: 0.0625rem;
}
.pt-link-project-result {
  display: flex;
  flex-direction: column;
  gap: 0.875rem;
  font-family: var(--font-sans);
  color: var(--color-text-primary);
}
.pt-link-project-result__message {
  display: flex;
  align-items: flex-start;
  gap: 0.5rem;
  margin: 0;
  padding: 0.75rem;
  border-radius: 0.375rem;
  font-size: var(--text-sm);
  background: var(--color-success-soft, #ecfdf5);
  color: var(--color-success-strong, #047857);
  border: 1px solid var(--color-success, #10b981);
}
.pt-link-project-result__message svg {
  flex-shrink: 0;
  margin-top: 0.0625rem;
}
.pt-link-project-result__footer {
  display: flex;
  justify-content: flex-end;
}
.pt-link-project-form__rows {
  display: flex;
  flex-direction: column;
  gap: 0.625rem;
}
.pt-link-project-row {
  display: grid;
  grid-template-columns: minmax(0, 2.2fr) 4.5rem minmax(0, 1fr) auto;
  align-items: stretch;
  gap: 0.5rem;
}
.pt-link-project-row[hidden] {
  display: none;
}
.pt-link-project-row__field {
  min-width: 0;
}
.pt-link-project-row__field--quantity .pt-input {
  height: 100%;
}
.pt-link-project-row__remove {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  align-self: center;
  width: 2rem;
  height: 2rem;
  flex-shrink: 0;
  color: var(--color-text-secondary);
  background: transparent;
  border: 0;
  border-radius: var(--radius-md);
  cursor: pointer;
}
.pt-link-project-row__remove:hover, .pt-link-project-row__remove:focus {
  color: oklch(55% 0.22 25);
  background: oklch(95% 0.04 25);
}
.pt-link-project-form__add-row {
  margin-top: 1rem;
}
@media (max-width: 32rem) {
  .pt-link-project-row {
    grid-template-columns: minmax(0, 1fr) auto;
    grid-template-areas: "project remove" "quantity remove" "unit remove";
  }
  .pt-link-project-row__field--project {
    grid-area: project;
  }
  .pt-link-project-row__field--quantity {
    grid-area: quantity;
  }
  .pt-link-project-row__field--unit {
    grid-area: unit;
  }
  .pt-link-project-row__remove {
    grid-area: remove;
    align-self: start;
  }
}
.pt-map-viewer {
  position: relative;
  border-radius: var(--radius-lg);
  overflow: hidden;
  border: 1px solid var(--color-border);
  background: var(--color-surface-alt);
  height: 100%;
}
.pt-card__body > .pt-map-viewer[data-map-viewer-mode-value="single"] {
  border-top: 0;
  border-left: 0;
  border-right: 0;
  border-top-left-radius: 0;
  border-top-right-radius: 0;
  border-bottom-left-radius: 0.25rem;
  border-bottom-right-radius: 0.25rem;
}
.pt-map-viewer__map {
  width: 100%;
  min-height: 200px;
  z-index: 0;
}
.pt-project-blank-view {
  min-height: 28rem;
}
.pt-project-blank-view > .pt-map-viewer {
  width: 100%;
  min-height: 24rem;
}
.pt-project-blank-view:not([data-view="map"]) > .pt-map-viewer {
  display: none;
}
.pt-project-blank-view:not([data-view="charts"]) > .pt-projects-breakdown {
  display: none;
}
.pt-project-blank-view:not([data-view="charts"]) > .pt-company-projects-breakdown {
  display: none;
}
.pt-project-blank-view .pt-map-viewer__map {
  height: 100% !important;
}
.pt-map-viewer .leaflet-container {
  font-family: var(--font-sans);
  font-size: 0.8125rem;
}
.pt-map-viewer .leaflet-popup-content-wrapper {
  border-radius: var(--radius-md);
  box-shadow: 0 4px 16px oklch(0% 0 0 / 12%);
}
.pt-map-viewer .leaflet-popup-content {
  margin: 0.75rem 1rem;
  font-family: var(--font-sans);
  font-size: 0.875rem;
  line-height: 1.5;
}
.pt-map-viewer__map:empty::after {
  content: "Loading map…";
  display: flex;
  align-items: center;
  justify-content: center;
  height: 100%;
  color: var(--color-muted);
  font-family: var(--font-sans);
  font-size: 0.875rem;
}
.pt-map-viewer .leaflet-control-layers-list label {
  display: flex;
  align-items: center;
  gap: 0.4rem;
}
.pt-map-viewer .leaflet-control-layers-list label input[type="radio"], .pt-map-viewer .leaflet-control-layers-list label input[type="checkbox"] {
  margin: 0;
  flex-shrink: 0;
}
.pt-map-viewer .leaflet-control-layers-list label > span {
  line-height: 1;
}
.pt-map-viewer .leaflet-control-layers-toggle {
  background-image: url("https://unpkg.com/leaflet@1.9.4/dist/images/layers.png") !important;
  background-size: 18px 18px !important;
  background-position: center !important;
  background-repeat: no-repeat !important;
  width: 30px !important;
  height: 30px !important;
}
.pt-map-viewer .leaflet-retina .leaflet-control-layers-toggle {
  background-image: url("https://unpkg.com/leaflet@1.9.4/dist/images/layers-2x.png") !important;
}
.pt-map-viewer .leaflet-control-zoom a {
  font-family: ui-sans-serif, system-ui, sans-serif;
  font-weight: 400;
  font-size: 1.25rem;
  line-height: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0;
}
.pt-map-viewer .leaflet-control-zoom a > span {
  display: block;
  line-height: 1;
}
.leaflet-control-zoom-fullscreen, .leaflet-fullscreen-icon {
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23333' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><path d='M3 9V5a2 2 0 0 1 2-2h4'/><path d='M21 9V5a2 2 0 0 0-2-2h-4'/><path d='M3 15v4a2 2 0 0 0 2 2h4'/><path d='M21 15v4a2 2 0 0 1-2 2h-4'/></svg>") !important;
  background-repeat: no-repeat !important;
  background-position: center !important;
  background-size: 18px 18px !important;
}
.leaflet-control-locate a {
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23333' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><circle cx='12' cy='12' r='9'/><circle cx='12' cy='12' r='3' fill='%23333'/><line x1='12' y1='1' x2='12' y2='4'/><line x1='12' y1='20' x2='12' y2='23'/><line x1='1' y1='12' x2='4' y2='12'/><line x1='20' y1='12' x2='23' y2='12'/></svg>") !important;
  background-repeat: no-repeat !important;
  background-position: center !important;
  background-size: 18px 18px !important;
}
.pt-map-viewer__map .pt-map-geocoder {
  position: absolute;
  top: 10px;
  right: 10px;
  width: 240px;
  max-width: calc(100% - 20px);
  z-index: 1000;
}
.pt-map-viewer[data-map-viewer-mode-value="cluster"] .leaflet-top.leaflet-right {
  top: 60px;
}
.pt-map-marker__wrapper {
  background: transparent;
  border: 0;
}
.pt-map-marker {
  width: 36px;
  height: 36px;
  border-radius: 50%;
  background: oklch(99% 0 0);
  border: 2px solid var(--pt-status-color, oklch(45% 0 0));
  box-shadow: 0 4px 10px oklch(0% 0 0 / 18%);
  display: flex;
  align-items: center;
  justify-content: center;
  transition: transform 120ms ease, box-shadow 120ms ease;
  color: oklch(28% 0 0);
}
.pt-map-marker:hover {
  transform: translateY(-2px) scale(1.05);
  box-shadow: 0 6px 14px oklch(0% 0 0 / 24%);
  z-index: 1000;
}
.pt-map-marker__inner {
  display: flex;
  width: 18px;
  height: 18px;
  align-items: center;
  justify-content: center;
}
.pt-map-marker__inner .pt-icon {
  width: 100%;
  height: 100%;
  stroke-width: 2;
}
.pt-map-geocoder {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  box-shadow: 0 2px 8px oklch(0% 0 0 / 10%);
  width: 240px;
  max-width: 50vw;
}
.pt-map-geocoder__input {
  width: 100%;
  padding: 0.5rem 0.75rem;
  border: 0;
  border-radius: var(--radius-md);
  font-family: inherit;
  font-size: 0.875rem;
  outline: none;
  background: transparent;
  color: var(--color-text);
}
.pt-map-geocoder__input::placeholder {
  color: var(--color-muted);
}
.pt-map-geocoder__results {
  list-style: none;
  margin: 0;
  padding: 0.25rem 0;
  border-top: 1px solid var(--color-border);
  background: var(--color-surface);
  max-height: 16rem;
  overflow-y: auto;
}
.pt-map-geocoder__results[hidden] {
  display: none;
}
.pt-map-geocoder__result {
  padding: 0.5rem 0.75rem;
  font-size: 0.8125rem;
  color: var(--color-text);
  cursor: pointer;
  white-space: normal;
}
.pt-map-geocoder__result:hover {
  background: var(--color-surface-alt);
}
.pt-map-popup .leaflet-popup-content-wrapper {
  padding: 0;
  border-radius: 1rem;
  overflow: hidden;
}
.pt-map-popup .leaflet-popup-content {
  margin: 0;
  width: 240px !important;
}
.pt-map-popup .pt-project-card__actions {
  display: none;
}
.pt-map-popup .pt-project-card {
  transform: none !important;
  box-shadow: none;
  border-radius: 0;
  height: auto;
}
.pt-map-popup .pt-project-card__content {
  padding: 0.65rem 0.85rem 0.75rem;
  gap: 0.35rem;
}
.pt-map-popup .pt-project-card__body, .pt-map-popup .pt-project-card__footer {
  padding: 0;
  gap: 0.35rem;
  min-height: 0;
  display: flex;
  flex-direction: column;
}
.pt-map-popup .pt-project-card__footer {
  border-top: 0;
  background: transparent;
}
.pt-map-popup .pt-project-card__title, .pt-map-popup .pt-project-card__title a, .pt-map-popup .pt-project-card__title-link {
  color: oklch(22% 0 0);
  text-decoration: none;
}
.pt-map-popup .pt-project-card__title {
  font-size: 0.95rem;
  line-height: 1.25;
  margin: 0;
}
.pt-map-popup .pt-project-card__meta {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 0.25rem;
  font-size: 0.8125rem;
}
.pt-map-popup .pt-project-card__meta-type {
  margin-left: 0;
}
.pt-map-popup .pt-project-card__dates {
  min-height: 0;
  gap: 0.25rem;
  font-size: 0.8125rem;
  margin: 0;
}
.pt-map-popup .pt-project-card__body {
  min-height: 0;
  margin: 0;
}
.pt-map-popup .pt-project-card__sectors-row {
  min-height: 0;
}
.pt-map-popup .pt-project-card__title {
  margin: 0;
}
.pt-map-popup .pt-project-card__footer {
  border-top: 0;
  background: transparent;
  margin-top: 0;
}
.pt-map-popup .pt-sector-icon[data-tooltip]::after, .pt-map-popup .pt-metric-pill[data-tooltip]::after {
  left: 0;
  right: auto;
  transform: translateX(0) translateY(4px);
}
.pt-map-popup .pt-sector-icon[data-tooltip]:hover::after, .pt-map-popup .pt-metric-pill[data-tooltip]:hover::after {
  transform: translateX(0) translateY(0);
}
.pt-company-map-marker__wrapper {
  background: transparent;
  border: 0;
}
.pt-company-map-marker {
  width: 42px;
  height: 42px;
  border-radius: 50%;
  background: #ffffff;
  border: 3px solid var(--color-brand, #1d4ed8);
  box-shadow: 0 6px 16px oklch(0% 0 0 / 24%);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--color-brand, #1d4ed8);
}
.pt-company-map-marker__inner {
  width: 24px;
  height: 24px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.pt-company-map-marker__icon {
  width: 100%;
  height: 100%;
  display: block;
}
.pt-notifications .pt-directory-filters {
  position: relative;
}
.pt-page-header__count {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 1.375rem;
  height: 1.375rem;
  margin-left: 0.5rem;
  padding: 0 0.4375rem;
  border-radius: var(--radius-full);
  background: var(--color-accent);
  color: var(--color-text-inverse);
  font-size: 0.75rem;
  font-weight: 700;
  line-height: 1.375rem;
  vertical-align: middle;
}
.pt-page-header__count[hidden] {
  display: none;
}
.pt-notifications-grid {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}
.pt-notif-refinements {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.5rem;
}
.pt-notif-refinements__chips {
  display: inline-flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.5rem;
}
.pt-notif-chip {
  display: inline-flex;
  align-items: center;
  gap: 0.3rem;
  background: oklch(45% 0.18 250 / 10%);
  border: 1px solid oklch(45% 0.18 250 / 25%);
  border-radius: 99px;
  padding: 0.2rem 0.5rem 0.2rem 0.65rem;
  font-size: 0.75rem;
  color: oklch(30% 0.12 250);
}
.pt-notif-chip__label {
  font-weight: 500;
  color: oklch(45% 0 0);
}
.pt-notif-chip__delete {
  display: inline-flex;
  align-items: center;
  padding: 0;
  border: none;
  background: none;
  color: oklch(45% 0.18 250);
  font-size: 0.8rem;
  line-height: 1;
  cursor: pointer;
}
.pt-notif-chip__delete:hover {
  color: oklch(30% 0 0);
}
.pt-notif-refinements__clear {
  padding: 0.3125rem 0.75rem;
  border: 1px solid oklch(88% 0 0);
  border-radius: 0.25rem;
  background: transparent;
  color: oklch(20% 0.01 250);
  font-size: 0.8125rem;
  font-weight: 500;
  line-height: 1.2;
  cursor: pointer;
}
.pt-notif-refinements__clear:hover {
  background: oklch(96% 0 0);
}
.pt-notifications-grid__table {
  height: clamp(32rem, calc(100vh - 13rem), 72rem);
  border-radius: 0.25rem;
  --ag-wrapper-border-radius: 0.25rem;
}
.pt-notifications-grid__table .ag-root-wrapper {
  border-radius: 0.25rem;
}
.pt-notifications-grid__table .ag-header-cell-text {
  font-size: 0.6875rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.03em;
}
.pt-notifications-grid__table .ag-cell {
  display: flex;
  align-items: center;
  line-height: 1.3;
}
.pt-notifications-grid__project-link {
  font-weight: 600;
  color: var(--color-text-primary);
  text-decoration: none;
}
.pt-notifications-grid__project-link:hover {
  text-decoration: underline;
}
.pt-notifications-grid__date-cell {
  justify-content: center;
  color: var(--color-text-secondary);
}
.pt-notifications-grid__notif {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  flex: 1;
  width: 100%;
  min-width: 0;
}
.pt-notifications-grid__notif-line {
  order: 0;
  flex: 1;
  min-width: 0;
  overflow: hidden;
  white-space: nowrap;
  text-overflow: ellipsis;
}
.pt-notifications-grid__notif-line br {
  display: none;
}
.pt-notifications-grid__notif-line p, .pt-notifications-grid__notif-line ul, .pt-notifications-grid__notif-line li, .pt-notifications-grid__notif-line div, .pt-notifications-grid__notif-line span {
  display: inline;
}
.pt-notifications-grid__notif-line a {
  color: var(--color-brand);
  text-decoration: none;
}
.pt-notifications-grid__notif-line a:hover {
  text-decoration: underline;
}
.pt-notifications-grid__details-badge {
  order: 1;
  flex-shrink: 0;
  margin-left: auto;
  display: inline-flex;
  align-items: center;
  padding: 0.0625rem 0.375rem;
  border-radius: var(--radius-sm);
  background: var(--color-surface-3);
  color: var(--color-text-secondary);
  font-size: 0.6875rem;
  font-weight: 600;
  white-space: nowrap;
}
.pt-notifications-grid__notif-chevron {
  order: 2;
  flex-shrink: 0;
  width: 1rem;
  height: 1rem;
  color: var(--color-text-secondary);
}
.pt-notifications-grid__notif-chevron svg {
  width: 1rem;
  height: 1rem;
  display: block;
}
.pt-notifications-grid__table .ag-row {
  cursor: pointer;
}
.pt-notifications-grid__table .ag-row.ag-row-selected, .pt-notifications-grid__table .ag-row.ag-row-selected .ag-cell {
  background-color: var(--color-brand-subtle);
}
.pt-notifications-grid__table .ag-row.pt-notif-row--unread:not(.ag-row-selected), .pt-notifications-grid__table .ag-row.pt-notif-row--unread:not(.ag-row-selected) .ag-cell {
  background-color: color-mix(in srgb, oklch(45% 0.18 250) 7%, transparent);
  @supports (color: color-mix(in lab, red, red)) {
    background-color: color-mix(in oklch, var(--color-brand) 7%, transparent);
  }
}
.pt-notifications-grid__table .ag-row.pt-notif-row--unread {
  box-shadow: inset 3px 0 0 var(--color-brand);
  font-weight: 500;
}
.pt-notifications-grid__pagination {
  display: flex;
  justify-content: center;
}
.pt-pagination {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.25rem;
  margin: 0;
  padding: 0;
  list-style: none;
}
.pt-pagination__item {
  display: inline-flex;
}
.pt-pagination__link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 2rem;
  height: 2rem;
  padding: 0 0.5rem;
  border: 1px solid var(--color-surface-3);
  border-radius: var(--radius-sm);
  background: var(--color-surface);
  color: var(--color-text-primary);
  font-size: 0.8125rem;
  text-decoration: none;
  cursor: pointer;
  transition: background 150ms, border-color 150ms, color 150ms;
}
.pt-pagination__link:hover {
  background: var(--color-surface-2);
  border-color: var(--color-brand-light);
}
.pt-pagination__item--current .pt-pagination__link {
  background: var(--color-brand);
  border-color: var(--color-brand);
  color: var(--color-text-inverse);
  cursor: default;
}
.pt-notif-detail {
  font-size: 0.9375rem;
  line-height: 1.6;
  color: var(--color-text-primary);
}
.pt-notif-detail a {
  color: var(--color-brand);
  text-decoration: none;
}
.pt-notif-detail a:hover {
  text-decoration: underline;
}
.pt-notif-detail__changeset {
  margin-top: 0.75rem;
  padding: 0.625rem 0.75rem;
  background: var(--color-surface-2);
  border: 1px solid var(--color-surface-3);
  border-radius: var(--radius-sm);
  font-size: 0.875rem;
}
.pt-notif-detail__changeset ul {
  margin: 0;
  padding-left: 1.1rem;
  list-style: disc;
}
.pt-notifications-filters {
  display: flex;
  flex-direction: column;
}
.pt-notifications-filters__clear {
  position: absolute;
  top: 0.5rem;
  right: 0.625rem;
  z-index: 1;
  display: inline-flex;
  align-items: center;
  gap: 0.25rem;
  padding: 0.1875rem 0.4375rem;
  border: 1px solid var(--color-surface-3);
  border-radius: var(--radius-sm);
  background: var(--color-surface);
  color: var(--color-text-secondary);
  font-size: 0.6875rem;
  font-weight: 600;
  font-family: inherit;
  line-height: 1;
  cursor: pointer;
  transition: background 150ms, color 150ms;
}
.pt-notifications-filters__clear:hover {
  background: var(--color-surface-2);
  color: var(--color-text-primary);
}
.pt-notifications-filters__clear-icon {
  width: 0.75rem;
  height: 0.75rem;
}
.pt-notifications-filters .pt-date-range:not(:has(.pt-date-range__subtitle)) .pt-date-range__separator {
  padding-top: 0;
}
.pt-notifications-filters__input {
  width: 100%;
  height: 2.25rem;
  padding: 0 0.625rem;
  border: 1px solid var(--color-surface-3);
  border-radius: var(--radius-sm);
  background: var(--color-surface);
  color: var(--color-text-primary);
  font-size: 0.8125rem;
}
.pt-notifications-filters__input:focus {
  outline: none;
  border-color: var(--color-brand);
}
.pt-notifications-filters__types {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}
.pt-notifications-filters__dates {
  margin-top: 0.625rem;
}
.pt-notifications-filters__dates[hidden] {
  display: none;
}
.pt-notifications-filters .pt-date-picker__input, .pt-notifications-filters .pt-date-picker__placeholder {
  font-size: 0.6875rem;
}
.pt-notifications-filters .pt-date-range .pt-date-picker__input, .pt-notifications-filters .pt-date-range .pt-date-picker__placeholder {
  font-size: 0.75rem;
}
.pt-notifications-filters .pt-date-range .pt-date-picker__input {
  padding-left: 26px;
}
.pt-notifications-filters .pt-date-range .pt-date-picker--sm .pt-date-picker__input {
  padding-right: 1.25rem;
}
.pt-notifications-filters .pt-date-range .pt-date-picker__clear {
  padding: 0;
}
.pt-notifications-filters .pt-date-range .pt-date-picker__placeholder {
  left: 26px;
}
.pt-notifications-filters input[type="search"]::-webkit-search-cancel-button {
  -webkit-appearance: none;
  appearance: none;
}
.pt-notifications-filters .pt-search-input__clear {
  color: var(--color-text-primary);
}
.pt-projects-breakdown {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  padding: 1rem 0;
}
.pt-projects-breakdown__row {
  display: flex;
  gap: 1rem;
  flex-wrap: wrap;
}
.pt-projects-breakdown__row--pies > .pt-projects-breakdown__panel {
  flex: 1 1 320px;
  min-width: 0;
}
.pt-projects-breakdown__row:not(.pt-projects-breakdown__row--pies) > .pt-projects-breakdown__panel {
  flex: 1 1 100%;
  min-width: 0;
}
.pt-projects-breakdown__panel {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: 0.85rem 1rem 1rem;
  box-shadow: 0 1px 3px oklch(0% 0 0 / 4%);
}
.pt-projects-breakdown__title {
  margin: 0 0 0.5rem;
  font-size: 0.95rem;
  font-weight: 700;
  color: var(--color-text);
}
.pt-projects-breakdown .pt-ag-chart text {
  font-family: var(--font-sans) !important;
}
.pt-participant-section {
  background: var(--color-surface);
  border: 1px solid var(--color-surface-3);
  border-radius: var(--radius-md, 0.5rem);
  overflow: hidden;
}
.pt-participant-section__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  padding: 0.75rem 1rem;
  border: none;
  background: transparent;
  cursor: pointer;
  font-family: inherit;
  transition: background 150ms;
}
.pt-participant-section__header:hover {
  background: var(--color-surface-2);
}
.pt-participant-section__header-left {
  display: flex;
  align-items: center;
  gap: 0.5rem;
}
.pt-participant-section__icon {
  width: 1.125rem;
  height: 1.125rem;
  color: var(--color-text-secondary);
}
.pt-participant-section__title {
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--color-text-primary);
  margin: 0;
}
.pt-participant-section__count {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 1.375rem;
  height: 1.375rem;
  padding: 0 0.375rem;
  border-radius: var(--radius-full, 9999px);
  background: var(--color-surface-3);
  color: var(--color-text-secondary);
  font-size: 0.6875rem;
  font-weight: 600;
}
.pt-participant-section__chevron {
  transition: transform 200ms ease;
}
.pt-participant-section__chevron-icon {
  width: 1rem;
  height: 1rem;
  color: var(--color-border-strong);
}
.pt-participant-section[data-expanded="false"] .pt-participant-section__body {
  display: none;
}
.pt-participant-section[data-expanded="false"] .pt-participant-section__chevron {
  transform: rotate(-90deg);
}
.pt-participant-section__body {
  border-top: 1px solid var(--color-surface-3);
  padding: 0.75rem 1rem;
}
.pt-participants-page {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}
.pt-participants-actionbar {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-start;
  gap: 0.5rem;
}
.pt-participants-actionbar .pt-btn__icon {
  width: 1rem;
  height: 1rem;
}
.pt-participants-actionbar .pt-btn--secondary {
  background: transparent;
}
.pt-participants-actionbar .pt-btn--secondary:hover {
  background: oklch(90% 0 0);
}
.pt-participants-actionbar .pt-btn--secondary:active {
  background: oklch(85% 0 0);
}
.pt-participants-subpage {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}
.pt-participants-subpage__title {
  margin: 0;
  font-size: 1.125rem;
  font-weight: 700;
  color: var(--color-text-primary);
}
.pt-participants-subpage__placeholder {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  padding: 3rem 1rem;
  text-align: center;
  background: var(--color-surface);
  border: 1px solid var(--color-surface-3);
  border-radius: 0.25rem;
  color: var(--color-text-secondary);
}
.pt-participants-subpage__placeholder-icon {
  width: 2.5rem;
  height: 2.5rem;
  color: var(--color-text-secondary);
}
.pt-participants-subpage__placeholder-title {
  margin: 0;
  font-weight: 600;
  color: var(--color-text-primary);
}
.pt-participants-subpage__placeholder-text {
  margin: 0;
  font-size: 0.875rem;
}
.pt-participants-grid-section {
  background: var(--color-surface);
  border: 1px solid var(--color-surface-3);
  border-radius: 0.25rem;
  overflow: hidden;
}
.pt-participants-grid-section__header {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  width: 100%;
  padding: 0.75rem 1rem;
  border: none;
  background: transparent;
  cursor: pointer;
  font-family: inherit;
  text-align: left;
  transition: background 150ms;
}
.pt-participants-grid-section__header:hover {
  background: var(--color-surface-2);
}
.pt-participants-grid-section__icon {
  width: 1.125rem;
  height: 1.125rem;
  color: var(--color-text-secondary);
  flex-shrink: 0;
}
.pt-participants-grid-section__title {
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--color-text-primary);
  margin: 0;
}
.pt-participants-grid-section__count {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 1.375rem;
  height: 1.375rem;
  padding: 0 0.375rem;
  border-radius: var(--radius-full);
  background: var(--color-surface-3);
  color: var(--color-text-secondary);
  font-size: 0.6875rem;
  font-weight: 600;
}
.pt-participants-grid-section__chevron {
  width: 1rem;
  height: 1rem;
  margin-left: auto;
  color: var(--color-text-secondary);
  transition: transform 200ms ease;
  flex-shrink: 0;
}
.pt-participants-grid-section__body {
  display: grid;
  grid-template-rows: 1fr;
  transition: grid-template-rows 220ms ease;
}
.pt-participants-grid-section[data-expanded="false"] .pt-participants-grid-section__body {
  grid-template-rows: 0fr;
}
.pt-participants-grid-section__body-inner {
  overflow: hidden;
  min-height: 0;
}
.pt-participants-grid-section[data-expanded="false"] .pt-participants-grid-section__chevron {
  transform: rotate(-90deg);
}
.pt-participants-grid {
  padding: 0.75rem;
  border-top: 1px solid var(--color-surface-3);
}
.pt-participants-grid .pt-ag-grid-container {
  height: auto;
  min-height: 0;
  border-radius: 0.25rem;
  box-shadow: none;
  border-color: var(--color-surface-3);
}
.pt-participants-grid .pt-ag-grid-container .ag-root-wrapper {
  border-radius: 0.25rem;
}
.pt-participants-grid .ag-theme-quartz {
  --ag-row-hover-color: var(--color-surface-2);
}
.pt-participants-grid .ag-row-hover {
  background-color: var(--color-surface-2);
}
.pt-participants-grid .ag-header-cell-text {
  font-size: 0.6875rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.03em;
}
.pt-participants-grid .ag-cell {
  display: flex;
  align-items: center;
}
.pt-participants-grid .ag-row, .pt-participants-grid .ag-cell {
  cursor: default;
}
.pt-participants-grid .pt-participants-grid__bold {
  font-weight: 600;
}
.pt-participants-grid .pt-participants-grid__cell {
  display: flex;
  align-items: center;
  height: 100%;
}
.pt-participants-grid__name-cell {
  display: flex;
  align-items: center;
  gap: 0.25rem;
  height: 100%;
}
.pt-participants-grid__name-label {
  display: flex;
  align-items: center;
  min-width: 0;
}
.pt-participants-grid__expand {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1.125rem;
  height: 1.125rem;
  padding: 0;
  border: none;
  background: transparent;
  color: var(--color-text-primary);
  cursor: pointer;
  line-height: 1;
  flex-shrink: 0;
}
.pt-participants-grid__expand-icon {
  display: block;
  width: 1.125rem;
  height: 1.125rem;
  stroke-width: 2.25;
}
.pt-participants-grid__expand-spacer {
  display: inline-block;
  width: 1.125rem;
  flex-shrink: 0;
}
.pt-participants-cell {
  display: flex;
  align-items: center;
  gap: 0.5rem;
}
.pt-participants-cell__indent {
  display: inline-block;
  width: 1.25rem;
  flex-shrink: 0;
}
.pt-participants-cell__name {
  font-weight: 400;
  color: var(--color-text-primary);
  text-decoration: none;
  cursor: pointer;
}
.pt-participants-cell__name--company {
  font-weight: 600;
}
.pt-participants-cell__name:hover {
  text-decoration: underline;
}
.pt-participants-cell__you {
  color: var(--color-text-secondary);
  font-weight: 400;
  margin-left: 0.25rem;
}
.pt-participants-cell__actions {
  display: flex;
  align-items: center;
  gap: 0.375rem;
  height: 100%;
}
.pt-participants-cell__action {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1.75rem;
  height: 1.75rem;
  padding: 0;
  border: none;
  border-radius: 0.25rem;
  background: transparent;
  color: var(--color-text-secondary);
  cursor: pointer;
  transition: background 150ms, color 150ms;
}
.pt-participants-cell__action svg {
  width: 1rem;
  height: 1rem;
}
.pt-participants-cell__action:hover {
  background: var(--color-surface-3);
  color: var(--color-text-primary);
}
.pt-participants-cell__action[data-participant-action="remove"]:hover, .pt-participants-cell__action[data-participant-action="user-remove"]:hover {
  color: var(--color-danger);
}
.pt-participants-grid__empty {
  color: var(--color-text-secondary);
  font-size: 0.875rem;
}
.pt-participants-popover {
  position: fixed;
  z-index: 1100;
  pointer-events: none;
}
.pt-participants-popover[hidden] {
  display: none;
}
.pt-participants-tooltip {
  background: oklch(20% 0 0);
  color: var(--color-text-inverse);
  padding: 0.5rem 0.75rem;
  border-radius: 0.25rem;
  font-size: 0.75rem;
  line-height: 1.4;
  max-width: 18rem;
  box-shadow: 0 0.25rem 0.75rem oklch(20% 0 0 / 25%);
}
.pt-participants-tooltip__row {
  display: block;
}
.pt-participants-tooltip__row--name, .pt-participants-tooltip__row--key {
  font-weight: 700;
}
.pt-participants-modal__subtitle {
  color: var(--color-text-secondary);
  margin-bottom: 0.75rem;
}
.pt-participants-modal__form {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}
.pt-participants-modal__reasons {
  display: flex;
  flex-direction: column;
  gap: 0.375rem;
  border: none;
  padding: 0;
  margin: 0;
}
.pt-participants-modal__reasons legend {
  font-weight: 600;
  margin-bottom: 0.25rem;
}
.pt-participants-modal__textarea {
  width: 100%;
}
.pt-participants-modal__field {
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
}
.pt-participants-modal__field-label {
  font-weight: 600;
}
.pt-participants-modal__footer {
  display: flex;
  justify-content: flex-end;
  gap: 0.5rem;
  margin-top: 0.5rem;
}
.pt-participants-invite {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}
.pt-participants-invite__search {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 0.5rem;
}
.pt-participants-invite__search .pt-input {
  width: 100%;
  max-width: 24rem;
}
.pt-participants-invite__filter {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.5rem;
  width: 100%;
}
.pt-participants-invite__filter .pt-select {
  flex: 0 0 auto;
  min-width: 14rem;
}
.pt-participants-invite__filter .pt-input {
  flex: 1 1 16rem;
  max-width: 24rem;
}
.pt-participants-invite__available {
  max-height: 20rem;
  overflow-y: auto;
  background: var(--color-surface);
  border: 1px solid var(--color-surface-3);
  border-radius: 0.25rem;
}
.pt-participants-invite__no-results {
  margin: 0;
  padding: 1rem;
  text-align: center;
  color: var(--color-text-secondary);
  font-size: 0.875rem;
}
.pt-participants-invite__no-results[hidden] {
  display: none;
}
.pt-participants-invite__option {
  display: flex;
  align-items: center;
  gap: 0.625rem;
  padding: 0.5rem 0.75rem;
  border-bottom: 1px solid var(--color-surface-3);
  transition: background 150ms;
}
.pt-participants-invite__option:last-child {
  border-bottom: none;
}
.pt-participants-invite__option:hover {
  background: var(--color-surface-2);
}
.pt-participants-invite__option[hidden] {
  display: none;
}
.pt-participants-invite__option-body {
  display: flex;
  flex-direction: column;
  min-width: 0;
  flex: 1 1 auto;
}
.pt-participants-invite__option-name {
  font-weight: 600;
  color: var(--color-text-primary);
}
.pt-participants-invite__option-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 0.25rem 0.5rem;
  font-size: 0.8125rem;
  color: var(--color-text-secondary);
}
.pt-participants-invite__option-addr::before {
  content: "·";
  margin-right: 0.5rem;
}
.pt-participants-invite__option-select {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  width: 1.75rem;
  height: 1.75rem;
  padding: 0;
  border: 1px solid var(--color-border);
  border-radius: 0.25rem;
  background: var(--color-surface);
  color: var(--color-brand);
  cursor: pointer;
  transition: background 150ms, color 150ms, border-color 150ms;
}
.pt-participants-invite__option-select svg {
  width: 1rem;
  height: 1rem;
}
.pt-participants-invite__option-select:hover {
  background: var(--color-brand);
  border-color: var(--color-brand);
  color: var(--color-text-inverse);
}
.pt-participants-invite__panes {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
  align-items: flex-start;
}
.pt-participants-invite__selected-panel {
  flex: 2 1 18rem;
}
.pt-participants-invite__roles-panel {
  flex: 1 1 14rem;
}
.pt-participants-invite__deadline-panel {
  flex: 1 1 14rem;
}
.pt-participants-invite__panel-title {
  margin: 0 0 0.5rem;
  font-size: 0.875rem;
  font-weight: 700;
  color: var(--color-text-primary);
}
.pt-participants-invite__selected {
  display: flex;
  flex-direction: column;
  gap: 0.375rem;
  min-height: 6rem;
  padding: 0.5rem;
  background: var(--color-surface);
  border: 1px solid var(--color-surface-3);
  border-radius: 0.25rem;
}
.pt-participants-invite__empty {
  margin: auto;
  text-align: center;
  color: var(--color-text-secondary);
  font-size: 0.875rem;
}
.pt-participants-invite__empty[hidden] {
  display: none;
}
.pt-participants-invite__selected-row {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.375rem 0.5rem;
  background: var(--color-surface-2);
  border: 1px solid var(--color-surface-3);
  border-radius: 0.25rem;
}
.pt-participants-invite__selected-name {
  flex: 1 1 auto;
  min-width: 0;
  font-weight: 500;
  color: var(--color-text-primary);
}
.pt-participants-invite__remove {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  width: 1.5rem;
  height: 1.5rem;
  padding: 0;
  border: none;
  border-radius: 0.25rem;
  background: transparent;
  color: var(--color-text-secondary);
  cursor: pointer;
  transition: background 150ms, color 150ms;
}
.pt-participants-invite__remove svg {
  width: 0.875rem;
  height: 0.875rem;
}
.pt-participants-invite__remove:hover {
  background: var(--color-danger-subtle);
  color: var(--color-danger);
}
.pt-participants-invite__roles {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  margin: 0;
  padding: 0.75rem;
  border: 1px solid var(--color-surface-3);
  border-radius: 0.25rem;
  background: var(--color-surface);
}
.pt-participants-invite__deadline-panel .pt-date-picker {
  padding: 0.75rem;
  border: 1px solid var(--color-surface-3);
  border-radius: 0.25rem;
  background: var(--color-surface);
}
.pt-participants-invite__selected-icon {
  flex-shrink: 0;
  width: 1rem;
  height: 1rem;
  color: var(--color-text-secondary);
}
.pt-participants-invite__email-prompt {
  display: flex;
  align-items: center;
  gap: 0.625rem;
  padding: 0.75rem 0.875rem;
  background: var(--color-surface);
  border-radius: 0.25rem;
  font-size: var(--text-sm);
  color: var(--color-text-secondary);
}
.pt-participants-invite__email-prompt-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  width: 2rem;
  height: 2rem;
  border-radius: var(--radius-full);
  background: var(--color-brand-subtle);
  color: var(--color-brand);
}
.pt-participants-invite__email-prompt-text {
  color: var(--color-text-secondary);
}
.pt-participants-invite__email-link {
  flex-shrink: 0;
  margin-left: auto;
  padding: 0.375rem 0.75rem;
  border: 1px solid var(--color-brand);
  border-radius: 0.25rem;
  background: transparent;
  color: var(--color-brand);
  font-weight: 400;
  font-size: var(--text-sm);
  cursor: pointer;
  transition: background 150ms ease, color 150ms ease;
}
.pt-participants-invite__email-link:hover {
  background: var(--color-brand);
  color: var(--color-on-brand);
}
.pt-participants-invite__email-desc {
  margin: 0 0 0.75rem;
  font-size: 0.875rem;
  color: var(--color-text-secondary);
}
.pt-participants-invite__email-fields {
  display: flex;
  flex-direction: column;
  gap: 0.625rem;
}
.pt-participants-invite__email-label {
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
  font-size: 0.8125rem;
  font-weight: 600;
  color: var(--color-text-primary);
}
.pt-participants-invite__email-label .pt-input {
  width: 100%;
}
.pt-participants-invite__email-result:empty {
  display: none;
}
.pt-participants-invite__email-result {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.5rem;
  margin-top: 0.75rem;
  padding: 0.5rem 0.625rem;
  background: var(--color-surface-2);
  border: 1px solid var(--color-surface-3);
  border-radius: 0.25rem;
}
.pt-participants-invite__email-result-name {
  min-width: 0;
  font-weight: 500;
  color: var(--color-text-primary);
}
.pt-participants-invite__email-error {
  margin: 0.75rem 0 0;
  font-size: 0.8125rem;
  color: var(--color-danger);
}
.pt-participants-invite__deadline-fields {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  padding: 0.75rem;
  border: 1px solid var(--color-surface-3);
  border-radius: 0.25rem;
  background: var(--color-surface);
}
.pt-participants-invite__deadline-fields .pt-date-picker {
  flex: 1 1 10rem;
  min-width: 9rem;
}
.pt-participants-invite__due-date {
  flex: 1 1 10rem;
  min-width: 9rem;
}
.pt-participants-invite__due-date[hidden] {
  display: none;
}
.pt-participants-invite__deadline-panel .pt-participants-invite__deadline-fields .pt-date-picker {
  padding: 0;
  border: none;
  background: transparent;
}
.pt-participants-invite__actions {
  display: flex;
  justify-content: flex-end;
  gap: 0.5rem;
  padding-top: 0.5rem;
}
.pt-questionnaire-builder {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-xl);
}
.pt-questionnaire-builder__header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: var(--spacing-lg);
  flex-wrap: wrap;
}
.pt-questionnaire-builder__title-form {
  flex: 1 1 20rem;
  min-width: 0;
}
.pt-questionnaire-builder__title-input {
  width: 100%;
  border: 1px solid transparent;
  background: transparent;
  font-size: var(--text-2xl);
  font-weight: 700;
  color: var(--color-text-primary);
  padding: 0.25rem 0.5rem;
  border-radius: var(--radius-md);
}
.pt-questionnaire-builder__title-input:hover {
  border-color: var(--color-border);
}
.pt-questionnaire-builder__title-input:focus {
  outline: none;
  border-color: var(--color-brand);
  background: var(--color-surface);
}
.pt-questionnaire-builder__meta {
  display: flex;
  align-items: center;
  gap: var(--spacing-md);
  flex-wrap: wrap;
  margin-top: var(--spacing-xs);
}
.pt-questionnaire-builder__actions {
  display: flex;
  align-items: center;
  gap: var(--spacing-sm);
  flex-wrap: wrap;
}
.pt-questionnaire-builder__tags {
  display: flex;
  align-items: center;
  gap: var(--spacing-sm);
  flex-wrap: wrap;
}
.pt-builder-toggle-all__state {
  display: inline-flex;
  align-items: center;
  gap: 0.375rem;
}
.pt-builder-toggle-all__state[hidden] {
  display: none;
}
.pt-section-list {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-lg);
}
.pt-section-list__add {
  align-self: stretch;
}
.pt-add-btn.pt-btn {
  display: flex;
  width: 100%;
  justify-content: center;
  border: 1px dashed var(--color-border-strong, var(--color-border));
  background: transparent;
  color: var(--color-text-secondary);
  font-weight: 600;
}
.pt-add-btn.pt-btn:hover {
  border-color: var(--color-brand);
  color: var(--color-brand);
  background: var(--color-brand-subtle, var(--color-surface-2));
}
.pt-section-editor {
  display: block;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  background: var(--color-surface);
  box-shadow: var(--shadow-card);
}
.pt-section-editor--sub {
  box-shadow: none;
  border-color: var(--color-surface-3);
}
.pt-section-editor--sub .pt-section-editor__bar {
  background: var(--color-surface);
}
.pt-section-editor__bar {
  display: flex;
  align-items: center;
  gap: var(--spacing-sm);
  padding: var(--spacing-sm) var(--spacing-lg);
  border-bottom: 1px solid var(--color-border);
  background: var(--color-surface-2);
  border-radius: var(--radius-lg) var(--radius-lg) 0 0;
}
.pt-section-editor__toggle {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--color-text-muted);
  border: none;
  background: transparent;
  padding: 0.25rem;
  border-radius: var(--radius-sm);
  cursor: pointer;
  transition: transform 0.15s ease, color 0.15s ease;
}
.pt-section-editor__toggle:hover {
  color: var(--color-text-primary);
  background: var(--color-surface-3);
}
.pt-section-editor__toggle[aria-expanded="true"] {
  transform: rotate(180deg);
}
.pt-section-editor[data-disclosure-open="false"] .pt-section-editor__bar {
  border-bottom: none;
  border-radius: var(--radius-lg);
}
.pt-section-editor__body {
  padding: var(--spacing-md) var(--spacing-lg);
  display: flex;
  flex-direction: column;
  gap: var(--spacing-md);
}
.pt-section-editor__fields {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-sm);
  padding: var(--spacing-md) var(--spacing-lg);
}
.pt-section-editor__title-input {
  flex: 1 1 auto;
  min-width: 0;
  border: 1px solid transparent;
  background: transparent;
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--color-text-primary);
  padding: 0.25rem 0.5rem;
  border-radius: var(--radius-sm);
}
.pt-section-editor__title-input::placeholder {
  color: var(--color-text-muted);
  font-weight: 400;
}
.pt-section-editor__title-input:hover {
  border-color: var(--color-border);
}
.pt-section-editor__title-input:focus {
  outline: none;
  border-color: var(--color-brand);
  background: var(--color-surface);
}
.pt-section-editor__questions {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-sm);
  padding-left: var(--spacing-md);
  border-left: 2px solid var(--color-surface-3);
}
.pt-section-editor__subsections {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-sm);
  margin-left: var(--spacing-md);
  padding-left: var(--spacing-md);
  border-left: 2px dashed var(--color-border);
  min-height: var(--spacing-lg);
}
.pt-section-editor__questions:not(:has(> *)) {
  border-left: none;
  padding-left: 0;
}
.pt-section-editor__subsections:not(:has(> *)) {
  border-left: none;
  min-height: 0;
  margin-left: 0;
  padding-left: 0;
}
.pt-section-editor__number, .pt-question-editor__number {
  font-variant-numeric: tabular-nums;
  font-size: var(--text-xs);
  font-weight: 700;
  color: var(--color-text-muted);
  background: var(--color-surface-3);
  border-radius: var(--radius-sm);
  padding: 0.0625rem 0.375rem;
  flex: 0 0 auto;
}
.pt-question-editor__required {
  flex: 0 0 auto;
}
.pt-section-editor__label, .pt-question-editor__label {
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--color-text-secondary);
}
.pt-section-editor__footer, .pt-question-editor__footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--spacing-sm);
  flex-wrap: wrap;
}
.pt-question-editor__footer {
  padding: var(--spacing-md);
  border-top: 1px solid var(--color-border);
}
.pt-drag-handle {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--color-text-muted);
  cursor: grab;
  border: none;
  background: transparent;
  padding: 0.25rem;
  border-radius: var(--radius-sm);
  touch-action: none;
}
.pt-drag-handle:hover {
  color: var(--color-text-primary);
  background: var(--color-surface-3);
}
.pt-drag-handle:active {
  cursor: grabbing;
}
.pt-sortable-ghost {
  opacity: 0.5;
}
.pt-sortable-drag {
  box-shadow: var(--shadow-modal);
}
.pt-question-editor {
  display: block;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  background: var(--color-surface);
}
.pt-question-editor__bar {
  display: flex;
  align-items: center;
  gap: var(--spacing-sm);
  padding: var(--spacing-xs) var(--spacing-md);
  background: var(--color-surface-2);
  border-radius: var(--radius-md) var(--radius-md) 0 0;
  flex-wrap: wrap;
}
[data-disclosure-open="false"] .pt-question-editor__bar {
  border-radius: var(--radius-md);
}
[data-disclosure-open="true"] .pt-question-editor__bar {
  border-bottom: 1px solid var(--color-border);
}
.pt-question-editor__toggle {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--color-text-muted);
  border: none;
  background: transparent;
  padding: 0.25rem;
  border-radius: var(--radius-sm);
  cursor: pointer;
  transition: transform 0.15s ease, color 0.15s ease;
}
.pt-question-editor__toggle:hover {
  color: var(--color-text-primary);
  background: var(--color-surface-3);
}
[data-disclosure-open="true"] .pt-question-editor__toggle {
  transform: rotate(180deg);
}
.pt-question-editor__label-input {
  flex: 1 1 12rem;
  min-width: 8rem;
  border: 1px solid transparent;
  background: transparent;
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--color-text-primary);
  padding: 0.25rem 0.5rem;
  border-radius: var(--radius-sm);
}
.pt-question-editor__label-input::placeholder {
  color: var(--color-text-muted);
  font-weight: 400;
}
.pt-question-editor__label-input:hover {
  border-color: var(--color-border);
}
.pt-question-editor__label-input:focus {
  outline: none;
  border-color: var(--color-brand);
  background: var(--color-surface);
}
.pt-question-editor__type, .pt-question-editor__category {
  flex: 0 1 9rem;
  min-width: 7rem;
}
.pt-question-editor__type .pt-select, .pt-question-editor__category .pt-select, .pt-question-editor__type .pt-select__input, .pt-question-editor__category .pt-select__input {
  width: 100%;
}
.pt-question-editor__body {
  padding: var(--spacing-md);
  display: flex;
  flex-direction: column;
  gap: var(--spacing-md);
}
.pt-question-editor__field--full {
  width: 100%;
}
.pt-question-editor__toggles {
  display: flex;
  align-items: center;
  gap: var(--spacing-xl);
  flex-wrap: wrap;
}
.pt-section-editor__status, .pt-question-editor__status {
  margin-left: auto;
  flex: 0 0 auto;
  min-width: 5.5rem;
  display: flex;
  justify-content: flex-end;
}
.pt-question-settings {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-md);
}
.pt-question-settings__group {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: var(--spacing-md);
  padding: var(--spacing-md);
  border: 1px dashed var(--color-border);
  border-radius: var(--radius-md);
  background: var(--color-surface-2);
}
.pt-question-settings__group--cols-3 {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}
.pt-question-settings__hint {
  font-size: var(--text-sm);
  color: var(--color-text-muted);
}
.pt-option-list {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-sm);
  padding: var(--spacing-md);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  background: var(--color-surface-2);
}
.pt-option-list__heading {
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--color-text-secondary);
}
.pt-option-row {
  display: flex;
  align-items: center;
  gap: var(--spacing-sm);
}
.pt-option-row__input {
  flex: 1 1 auto;
}
.pt-curation-status {
  display: inline-flex;
  align-items: center;
  gap: 0.375rem;
  font-size: var(--text-xs);
  color: var(--color-text-muted);
  min-height: 1.25rem;
}
.pt-curation-status[data-state="saving"] {
  color: var(--color-warning-hover);
}
.pt-curation-status[data-state="saved"] {
  color: var(--color-success);
}
.pt-curation-status[data-state="error"] {
  color: var(--color-danger);
}
.pt-questionnaire-comparison {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-lg);
}
.pt-questionnaire-comparison__toolbar {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-end;
  gap: var(--spacing-md);
}
.pt-questionnaire-comparison__view, .pt-questionnaire-comparison__sections, .pt-questionnaire-comparison__bidders, .pt-questionnaire-comparison__search {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-2xs, 0.25rem);
}
.pt-questionnaire-comparison__view {
  flex: 0 0 auto;
}
.pt-questionnaire-comparison__sections, .pt-questionnaire-comparison__bidders {
  flex: 0 1 16rem;
  min-width: 13rem;
}
.pt-questionnaire-comparison__search {
  flex: 0 1 20rem;
  min-width: 12rem;
}
.pt-questionnaire-comparison__sections .pt-checkbox-dropdown, .pt-questionnaire-comparison__bidders .pt-checkbox-dropdown, .pt-questionnaire-comparison__sections .pt-checkbox-dropdown__trigger, .pt-questionnaire-comparison__bidders .pt-checkbox-dropdown__trigger {
  width: 100%;
}
.pt-questionnaire-comparison__sections .pt-checkbox-dropdown__trigger, .pt-questionnaire-comparison__bidders .pt-checkbox-dropdown__trigger {
  justify-content: space-between;
}
.pt-questionnaire-comparison__search .pt-search-input__field {
  height: 1.875rem;
  padding-top: 0;
  padding-bottom: 0;
  line-height: 1;
}
.pt-segmented {
  display: inline-flex;
  align-self: flex-start;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  overflow: hidden;
  background: var(--color-surface);
}
.pt-segmented__btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.375rem 0.75rem;
  font-size: 0.8125rem;
  font-weight: 500;
  line-height: 1.2;
  color: var(--color-text-secondary);
  background: transparent;
  border: none;
  cursor: pointer;
  transition: background 120ms ease, color 120ms ease;
}
.pt-segmented__btn--icon {
  padding: 0.4375rem 0.625rem;
}
.pt-segmented__btn + .pt-segmented__btn {
  border-left: 1px solid var(--color-border);
}
.pt-segmented__btn:hover {
  background: var(--color-surface-2);
}
.pt-segmented__btn--active, .pt-segmented__btn--active:hover {
  background: var(--color-brand);
  color: #fff;
}
.pt-questionnaire-comparison__label {
  font-size: 0.75rem;
  font-weight: 600;
  color: var(--color-text-muted, #64748b);
}
.pt-questionnaire-comparison__export {
  flex: 0 0 auto;
  margin-left: auto;
}
.pt-questionnaire-comparison__grid {
  width: 100%;
  height: 600px;
}
.pt-questionnaire-comparison__question {
  display: inline-flex;
  align-items: center;
  gap: 0.375rem;
  line-height: 1.3;
}
.pt-questionnaire-comparison__number {
  flex: 0 0 auto;
  font-variant-numeric: tabular-nums;
  font-weight: 600;
  color: var(--color-text-muted, #64748b);
}
.pt-questionnaire-comparison__required {
  color: var(--color-danger, #dc2626);
  font-weight: 700;
}
.pt-questionnaire-comparison__pill {
  flex: 0 0 auto;
}
.pt-questionnaire-comparison .ag-header {
  background: var(--color-surface-3, oklch(94% 0.005 250));
  border-bottom: 1px solid var(--color-border);
}
.pt-questionnaire-comparison .ag-header-cell.pt-qc-header {
  background: transparent;
  font-weight: 600;
  color: var(--color-text-primary);
}
.pt-questionnaire-comparison .pt-qc-bidder-header {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 0.25rem;
  padding: 0.25rem 0;
  line-height: 1.2;
}
.pt-questionnaire-comparison .pt-qc-bidder-header__name {
  font-weight: 600;
  white-space: normal;
  color: var(--color-text-primary);
}
.pt-questionnaire-comparison .ag-header-cell.pt-qc-bidder, .pt-questionnaire-comparison .ag-cell.pt-qc-bidder {
  border-left: 1px solid var(--color-border);
}
.pt-questionnaire-comparison .ag-row.pt-qc-row--odd {
  background: var(--color-surface-2, oklch(97% 0.005 250));
}
.pt-questionnaire-comparison .ag-row.pt-qc-row--even {
  background: var(--color-surface, #fff);
}
.pt-questionnaire-comparison .ag-cell.pt-qc-bidder--alt {
  background: rgba(15, 23, 42, 0.022);
}
.pt-questionnaire-comparison .ag-row.pt-qc-group--root {
  background: color-mix(in srgb, oklch(45% 0.18 250) 20%, oklch(99% 0 0));
  @supports (color: color-mix(in lab, red, red)) {
    background: color-mix(in oklch, var(--color-brand) 20%, var(--color-surface));
  }
  font-weight: 700;
}
.pt-questionnaire-comparison .ag-row.pt-qc-group--sub {
  background: color-mix(in srgb, oklch(45% 0.18 250) 9%, oklch(99% 0 0));
  @supports (color: color-mix(in lab, red, red)) {
    background: color-mix(in oklch, var(--color-brand) 9%, var(--color-surface));
  }
  font-weight: 600;
}
.pt-questionnaire-comparison .ag-row.pt-qc-group--root .ag-group-value, .pt-questionnaire-comparison .ag-row.pt-qc-group--sub .ag-group-value {
  color: var(--color-text-primary);
}
.pt-qc-group__label {
  margin-right: 0.5rem;
}
.pt-qc-group__count {
  vertical-align: middle;
  font-variant-numeric: tabular-nums;
}
.pt-pdf-viewer {
  --pdf-toolbar-bg: #f2f4f5;
  --pdf-toolbar-border: #d4dbe1;
  --pdf-toolbar-text: #7c8791;
  --pdf-toolbar-strong: #56616b;
  --pdf-control-bg: #ffffff;
  --pdf-control-border: #d7dde2;
  --pdf-control-hover: #e8edf1;
  --pdf-page-bg: #ffffff;
  --pdf-stage-bg: #eef1f3;
  --pdf-brand: var(--color-brand, #1262bd);
  --pdf-danger: var(--color-danger, #d13333);
  display: flex;
  flex-direction: column;
  min-height: 34rem;
  overflow: hidden;
  border: 1px solid var(--pdf-toolbar-border);
  border-radius: 0;
  background: var(--pdf-page-bg);
  color: var(--color-text-primary, #1f2933);
  font-family: var(--font-sans, Arial, sans-serif);
  box-shadow: none;
}
.pt-pdf-viewer__toolbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  min-height: 3.25rem;
  padding: 0 0.875rem;
  flex-shrink: 0;
  border-bottom: 1px solid var(--pdf-toolbar-border);
  background: var(--pdf-toolbar-bg);
  color: var(--pdf-toolbar-text);
  z-index: 10;
}
.pt-pdf-viewer__toolbar-leading, .pt-pdf-viewer__toolbar-controls, .pt-pdf-viewer__toolbar-section {
  display: flex;
  align-items: center;
}
.pt-pdf-viewer__toolbar-controls {
  justify-content: flex-end;
  gap: 0.8rem;
  margin-left: auto;
}
.pt-pdf-viewer__toolbar-section {
  gap: 0.35rem;
}
.pt-pdf-viewer__toolbar-label {
  color: var(--pdf-toolbar-text);
  font-size: 0.8125rem;
  font-weight: 500;
  line-height: 1;
  white-space: nowrap;
}
.pt-pdf-viewer__toolbar-pages {
  gap: 0.45rem;
}
.pt-pdf-viewer__toolbar-zoom {
  gap: 0.45rem;
}
.pt-pdf-viewer__toolbar-actions {
  gap: 0.05rem;
}
.pt-pdf-viewer__compare-control {
  display: inline-flex;
  align-items: center;
  gap: 0.65rem;
  padding: 0;
  border: 0;
  background: transparent;
  color: var(--pdf-toolbar-text);
  font-family: inherit;
  font-size: 0.8125rem;
  font-weight: 500;
  line-height: 1;
  cursor: pointer;
  transition: color 120ms ease;
}
.pt-pdf-viewer__compare-control:hover:not(:disabled) {
  color: var(--pdf-toolbar-strong);
}
.pt-pdf-viewer__compare-control:disabled {
  opacity: 0.72;
  cursor: default;
}
.pt-pdf-viewer__compare-checkbox {
  position: relative;
  display: inline-flex;
  width: 0.875rem;
  height: 0.875rem;
  flex-shrink: 0;
  border: 1px solid var(--pdf-control-border);
  border-radius: 1px;
  background: var(--pdf-control-bg);
}
.pt-pdf-viewer__compare-control[aria-pressed="true"] .pt-pdf-viewer__compare-checkbox {
  border-color: var(--pdf-brand);
  background: var(--pdf-brand);
}
.pt-pdf-viewer__compare-control[aria-pressed="true"] .pt-pdf-viewer__compare-checkbox::after {
  content: "";
  position: absolute;
  left: 0.25rem;
  top: 0.075rem;
  width: 0.22rem;
  height: 0.46rem;
  border-right: 1.5px solid #fff;
  border-bottom: 1.5px solid #fff;
  transform: rotate(40deg);
}
.pt-pdf-viewer__compare-text {
  white-space: nowrap;
}
.pt-pdf-viewer__page-input {
  width: 4.25rem;
  height: 2rem;
  padding: 0 0.5rem;
  border: 1px solid var(--pdf-control-border);
  border-radius: 0;
  background: var(--pdf-control-bg);
  color: #505b65;
  font-family: inherit;
  font-size: 0.8125rem;
  font-weight: 500;
  text-align: center;
  transition: border-color 120ms ease, box-shadow 120ms ease;
}
.pt-pdf-viewer__page-input:focus, .pt-pdf-viewer__zoom-select:focus, .pt-pdf-viewer__finder-input:focus {
  outline: none;
  border-color: var(--pdf-brand);
  @supports (color: color-mix(in lab, red, red)) {
    border-color: color-mix(in srgb, var(--pdf-brand) 55%, var(--pdf-control-border));
  }
  box-shadow: 0 0 0 2px var(--pdf-brand);
  @supports (color: color-mix(in lab, red, red)) {
    box-shadow: 0 0 0 2px color-mix(in srgb, var(--pdf-brand) 13%, transparent);
  }
}
.pt-pdf-viewer__page-divider, .pt-pdf-viewer__page-count {
  color: var(--pdf-toolbar-text);
  font-size: 0.8125rem;
  font-weight: 500;
}
.pt-pdf-viewer__page-count {
  min-width: 0.75rem;
}
.pt-pdf-viewer__zoom-select {
  width: 7.8rem;
  height: 2rem;
  padding: 0 2rem 0 0.7rem;
  border: 1px solid var(--pdf-control-border);
  border-radius: 0;
  background-color: var(--pdf-control-bg);
  color: #65717c;
  font-family: inherit;
  font-size: 0.8125rem;
  font-weight: 500;
  cursor: pointer;
}
.pt-pdf-viewer__btn, .pt-pdf-viewer__finder-btn, .pt-pdf-viewer__compare-page-btn, .pt-pdf-viewer__sync-btn, .pt-pdf-viewer__compare-mode-btn {
  font-family: inherit;
}
.pt-pdf-viewer__btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.05rem;
  min-width: 2.05rem;
  height: 2.05rem;
  padding: 0;
  border: 1px solid transparent;
  border-radius: 2px;
  background: transparent;
  color: var(--pdf-toolbar-text);
  cursor: pointer;
  transition: color 120ms ease, background 120ms ease, border-color 120ms ease;
}
.pt-pdf-viewer__btn:hover:not(:disabled) {
  border-color: #e0e5e9;
  background: var(--pdf-control-hover);
  color: var(--pdf-toolbar-strong);
}
.pt-pdf-viewer__btn:active:not(:disabled), .pt-pdf-viewer__btn--active {
  border-color: var(--pdf-brand);
  @supports (color: color-mix(in lab, red, red)) {
    border-color: color-mix(in srgb, var(--pdf-brand) 20%, var(--pdf-control-border));
  }
  background: var(--pdf-brand);
  @supports (color: color-mix(in lab, red, red)) {
    background: color-mix(in srgb, var(--pdf-brand) 8%, white);
  }
  color: var(--pdf-brand);
}
.pt-pdf-viewer__btn:disabled {
  opacity: 0.35;
  cursor: not-allowed;
}
.pt-pdf-viewer__btn--pin {
  margin-left: 0.15rem;
}
.pt-pdf-viewer__icon {
  display: block;
  width: 1.06rem;
  height: 1.06rem;
  stroke: currentColor;
  color: inherit;
}
.pt-pdf-viewer__btn--pin .pt-pdf-viewer__icon {
  width: 1.1rem;
  height: 1.1rem;
}
.pt-pdf-viewer__finder {
  display: flex;
  align-items: center;
  gap: 0.375rem;
  max-height: 3.25rem;
  padding: 0.5rem 0.875rem;
  flex-shrink: 0;
  overflow: hidden;
  border-bottom: 1px solid var(--pdf-toolbar-border);
  background: var(--pdf-toolbar-bg);
  opacity: 1;
  transition: max-height 160ms ease, opacity 160ms ease, padding 160ms ease;
}
.pt-pdf-viewer__finder--hidden {
  max-height: 0;
  padding-top: 0;
  padding-bottom: 0;
  border-bottom-width: 0;
  opacity: 0;
}
.pt-pdf-viewer__finder-input {
  width: min(20rem, 100%);
  height: 2rem;
  padding: 0 0.65rem;
  border: 1px solid var(--pdf-control-border);
  border-radius: 2px;
  background: var(--pdf-control-bg);
  color: #505b65;
  font-family: inherit;
  font-size: 0.8125rem;
}
.pt-pdf-viewer__finder-count {
  min-width: 4.5rem;
  color: var(--pdf-toolbar-text);
  font-size: 0.75rem;
  text-align: center;
}
.pt-pdf-viewer__finder-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1.9rem;
  height: 1.9rem;
  padding: 0;
  border: 1px solid transparent;
  border-radius: 2px;
  background: transparent;
  color: var(--pdf-toolbar-text);
  cursor: pointer;
}
.pt-pdf-viewer__finder-btn:hover {
  border-color: #e0e5e9;
  background: var(--pdf-control-hover);
  color: var(--pdf-toolbar-strong);
}
.pt-pdf-viewer__body {
  position: relative;
  display: flex;
  flex: 1;
  flex-direction: column;
  min-height: 0;
  overflow: hidden;
  background: var(--pdf-page-bg);
}
.pt-pdf-viewer__canvas-wrap {
  display: flex;
  flex: 1;
  flex-direction: column;
  align-items: center;
  min-height: 34rem;
  overflow: auto;
  padding: 1.25rem 1.25rem 3rem;
  background: var(--pdf-page-bg);
  scroll-behavior: smooth;
}
.pt-pdf-viewer__canvas-wrap--hidden {
  display: none;
}
.pt-pdf-viewer__canvas-wrap::-webkit-scrollbar, .pt-pdf-viewer__compare-overlay::-webkit-scrollbar, .pt-pdf-viewer__compare-left::-webkit-scrollbar, .pt-pdf-viewer__compare-right::-webkit-scrollbar {
  width: 8px;
  height: 8px;
}
.pt-pdf-viewer__canvas-wrap::-webkit-scrollbar-thumb, .pt-pdf-viewer__compare-overlay::-webkit-scrollbar-thumb, .pt-pdf-viewer__compare-left::-webkit-scrollbar-thumb, .pt-pdf-viewer__compare-right::-webkit-scrollbar-thumb {
  border-radius: 8px;
  background: #c4ccd3;
}
.pt-pdf-viewer__canvas-wrap::-webkit-scrollbar-track, .pt-pdf-viewer__compare-overlay::-webkit-scrollbar-track, .pt-pdf-viewer__compare-left::-webkit-scrollbar-track, .pt-pdf-viewer__compare-right::-webkit-scrollbar-track {
  background: transparent;
}
.pt-pdf-viewer__page-container {
  margin-bottom: 1rem;
  filter: drop-shadow(0 1px 5px rgb(15 23 42 / 10%));
}
.pt-pdf-viewer__page {
  position: relative;
  overflow: hidden;
  background: #fff;
}
.pt-pdf-viewer__canvas {
  position: absolute;
  top: 0;
  left: 0;
  display: block;
}
.pt-pdf-viewer__text-layer {
  position: absolute;
  top: 0;
  left: 0;
  overflow: hidden;
  user-select: none;
  pointer-events: none;
  line-height: 1;
}
.pt-pdf-viewer__text-layer span {
  position: absolute;
  color: transparent;
  white-space: pre;
  cursor: text;
  transform-origin: 0% 0%;
}
.pt-pdf-viewer__text-layer.pt-pdf-viewer__text-layer--selectable span {
  cursor: text;
}
.pt-pdf-viewer__highlight {
  border-radius: 2px;
  background: rgb(255 217 102 / 58%);
  mix-blend-mode: multiply;
}
.pt-pdf-viewer__overlay {
  position: absolute;
  top: 0;
  left: 0;
  z-index: 3;
  cursor: default;
}
.pt-pdf-viewer__loading, .pt-pdf-viewer__error {
  position: absolute;
  inset: 0;
  z-index: 100;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  background: rgb(255 255 255 / 97%);
  text-align: center;
}
.pt-pdf-viewer__loading {
  gap: 0.75rem;
}
.pt-pdf-viewer__loading--hidden, .pt-pdf-viewer__error--hidden {
  display: none;
}
.pt-pdf-viewer__spinner {
  width: 2rem;
  height: 2rem;
  border: 3px solid #e6eaed;
  border-top-color: var(--pdf-brand);
  border-radius: 50%;
  animation: pt-pdf-spin 0.75s linear infinite;
}
@keyframes pt-pdf-spin {
  to {
    transform: rotate(360deg);
  }
}
.pt-pdf-viewer__loading-text {
  color: var(--pdf-toolbar-text);
  font-size: 0.8125rem;
}
.pt-pdf-viewer__error {
  gap: 0.6rem;
  padding: 2rem;
  color: var(--pdf-danger);
}
.pt-pdf-viewer__error-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 2.6rem;
  height: 2.6rem;
  margin-bottom: 0.25rem;
  border: 1px solid #f0b7b7;
  border-radius: 50%;
  background: #fde7e7;
  color: var(--pdf-danger);
}
.pt-pdf-viewer__error-icon svg {
  width: 1.35rem;
  height: 1.35rem;
  stroke: currentColor;
}
.pt-pdf-viewer__error-title {
  margin: 0;
  color: var(--pdf-danger);
  font-size: 0.9375rem;
  font-weight: 700;
  line-height: 1.35;
}
.pt-pdf-viewer__error-message {
  max-width: 25rem;
  margin: 0;
  color: #717c86;
  font-size: 0.8125rem;
  line-height: 1.55;
}
.pt-pdf-viewer__compare-wrap {
  display: flex;
  flex: 1;
  flex-direction: column;
  min-height: 0;
  overflow: hidden;
}
.pt-pdf-viewer__compare-wrap--hidden {
  display: none;
}
.pt-pdf-viewer__compare-toolbar {
  display: flex;
  align-items: center;
  gap: 1rem;
  padding: 0.65rem 0.875rem;
  flex-shrink: 0;
  border-bottom: 1px solid var(--pdf-toolbar-border);
  background: var(--pdf-toolbar-bg);
}
.pt-pdf-viewer__compare-col {
  display: flex;
  flex: 1;
  align-items: center;
  gap: 0.5rem;
}
.pt-pdf-viewer__compare-col--center {
  justify-content: center;
}
.pt-pdf-viewer__compare-col--right {
  justify-content: flex-end;
}
.pt-pdf-viewer__compare-label {
  color: var(--pdf-toolbar-text);
  font-size: 0.75rem;
  font-weight: 600;
  white-space: nowrap;
}
.pt-pdf-viewer__compare-page-nav {
  display: inline-flex;
  align-items: center;
  gap: 0.3rem;
  color: var(--pdf-toolbar-text);
  font-size: 0.8125rem;
}
.pt-pdf-viewer__compare-page-btn {
  width: 1.7rem;
  height: 1.7rem;
  border: 1px solid transparent;
  background: transparent;
  color: var(--pdf-toolbar-text);
  cursor: pointer;
}
.pt-pdf-viewer__compare-page-btn:hover {
  border-color: var(--pdf-control-border);
  background: var(--pdf-control-hover);
}
.pt-pdf-viewer__compare-select {
  height: 2rem;
  max-width: 12rem;
  padding: 0 0.55rem;
  border: 1px solid var(--pdf-control-border);
  background: var(--pdf-control-bg);
  color: #56616b;
  font-family: inherit;
  font-size: 0.8125rem;
}
.pt-pdf-viewer__compare-mode-group {
  display: inline-flex;
  overflow: hidden;
  border: 1px solid var(--pdf-control-border);
  border-radius: 2px;
}
.pt-pdf-viewer__compare-mode-btn, .pt-pdf-viewer__sync-btn {
  height: 1.9rem;
  padding: 0 0.65rem;
  border: 0;
  background: var(--pdf-control-bg);
  color: var(--pdf-toolbar-text);
  font-size: 0.75rem;
  cursor: pointer;
}
.pt-pdf-viewer__compare-mode-btn + .pt-pdf-viewer__compare-mode-btn {
  border-left: 1px solid var(--pdf-control-border);
}
.pt-pdf-viewer__compare-mode-btn--active, .pt-pdf-viewer__compare-mode-btn.pt-pdf-viewer__btn--active, .pt-pdf-viewer__sync-btn.pt-pdf-viewer__btn--active {
  background: var(--pdf-brand);
  @supports (color: color-mix(in lab, red, red)) {
    background: color-mix(in srgb, var(--pdf-brand) 8%, white);
  }
  color: var(--pdf-brand);
}
.pt-pdf-viewer__sync-btn {
  border: 1px solid var(--pdf-control-border);
  border-radius: 2px;
}
.pt-pdf-viewer__btn--hidden {
  display: none;
}
.pt-pdf-viewer__compare-overlay, .pt-pdf-viewer__compare-sidebyside {
  display: flex;
  flex: 1;
  align-items: flex-start;
  justify-content: center;
  min-height: 0;
  overflow: auto;
  padding: 1.25rem;
  background: var(--pdf-stage-bg);
}
.pt-pdf-viewer__compare-pane--hidden {
  display: none;
}
.pt-pdf-viewer__compare-sidebyside {
  gap: 0;
  padding: 0;
}
.pt-pdf-viewer__compare-left, .pt-pdf-viewer__compare-right {
  display: flex;
  flex: 1;
  flex-direction: column;
  align-items: center;
  height: 100%;
  overflow: auto;
  padding: 1.25rem;
  background: var(--pdf-stage-bg);
}
.pt-pdf-viewer__compare-left {
  border-right: 1px solid var(--pdf-toolbar-border);
}
.pt-pdf-viewer__diff-canvas, .pt-pdf-viewer__compare-page-canvas {
  display: block;
  max-width: 100%;
  background: #fff;
  filter: drop-shadow(0 2px 8px rgb(15 23 42 / 12%));
}
.pt-pdf-viewer__issue-tooltip, .pt-pdf-viewer__context-menu {
  position: fixed;
  z-index: 9999;
  border: 1px solid var(--pdf-control-border);
  border-radius: 4px;
  background: #fff;
  box-shadow: 0 10px 30px rgb(15 23 42 / 16%);
  font-family: inherit;
}
.pt-pdf-viewer__issue-tooltip {
  min-width: 11.5rem;
  max-width: 17.5rem;
  padding: 0.7rem 0.875rem;
}
.pt-pdf-viewer__issue-tooltip-title {
  margin-right: 1.25rem;
  margin-bottom: 0.4rem;
  color: #27313a;
  font-size: 0.8125rem;
  font-weight: 600;
}
.pt-pdf-viewer__issue-tooltip-meta {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  color: #717c86;
  font-size: 0.75rem;
}
.pt-pdf-viewer__issue-tooltip-close {
  position: absolute;
  top: 0.45rem;
  right: 0.5rem;
  padding: 0.1rem 0.25rem;
  border: 0;
  background: transparent;
  color: #87919a;
  cursor: pointer;
}
.pt-pdf-viewer__issue-badge {
  display: inline-flex;
  align-items: center;
  padding: 0.12rem 0.4rem;
  border-radius: 999px;
  font-size: 0.6875rem;
  font-weight: 600;
  text-transform: capitalize;
}
.pt-pdf-viewer__issue-badge--open {
  background: #e1f6e8;
  color: #18743c;
}
.pt-pdf-viewer__issue-badge--closed {
  background: #e9edf0;
  color: #65717c;
}
.pt-pdf-viewer__issue-badge--pending {
  background: #fff1d8;
  color: #9a6200;
}
.pt-pdf-viewer__context-menu {
  min-width: 10rem;
  padding: 0.25rem;
}
.pt-pdf-viewer__context-item {
  display: block;
  width: 100%;
  padding: 0.45rem 0.625rem;
  border: 0;
  border-radius: 3px;
  background: transparent;
  color: #27313a;
  font-family: inherit;
  font-size: 0.8125rem;
  text-align: left;
  cursor: pointer;
}
.pt-pdf-viewer__context-item:hover {
  background: var(--pdf-control-hover);
}
.pt-pdf-viewer__context-item--muted {
  color: #717c86;
}
@media (max-width: 960px) {
  .pt-pdf-viewer__toolbar {
    align-items: flex-start;
    flex-direction: column;
    padding: 0.65rem;
  }
  .pt-pdf-viewer__toolbar-controls {
    flex-wrap: wrap;
    justify-content: flex-start;
    margin-left: 0;
  }
  .pt-pdf-viewer__compare-toolbar {
    align-items: flex-start;
    flex-direction: column;
  }
  .pt-pdf-viewer__compare-col, .pt-pdf-viewer__compare-col--right {
    flex-wrap: wrap;
    justify-content: flex-start;
  }
}
.pt-photo-uploader {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}
.pt-photo-uploader__grid {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(11rem, 1fr));
  gap: 0.75rem;
}
.pt-photo-uploader__file-input {
  position: absolute;
  width: 1px;
  height: 1px;
  margin: -1px;
  padding: 0;
  border: 0;
  clip: rect(0, 0, 0, 0);
  overflow: hidden;
}
.pt-photo-uploader__error {
  margin: 0;
  font-size: var(--text-sm);
  color: var(--color-danger);
}
.pt-photo-uploader__error[hidden] {
  display: none;
}
.pt-photo-tile {
  position: relative;
  display: flex;
  flex-direction: column;
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: 0.25rem;
  overflow: hidden;
  aspect-ratio: 4 / 3;
}
.pt-photo-tile--main {
  border-color: var(--color-brand);
  box-shadow: 0 0 0 2px var(--color-brand-subtle);
}
.pt-photo-tile__media {
  flex: 1 1 auto;
  overflow: hidden;
  background: var(--color-surface-2);
}
.pt-photo-tile__image {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.pt-photo-tile__controls {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.5rem;
  padding: 0.375rem 0.5rem;
  border-top: 1px solid var(--color-border);
}
.pt-photo-tile__main.pt-radio {
  font-size: var(--text-xs);
  color: var(--color-text-secondary);
}
.pt-photo-tile--main .pt-photo-tile__main .pt-radio__label {
  color: var(--color-brand);
  font-weight: 600;
}
.pt-photo-tile__delete {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1.5rem;
  height: 1.5rem;
  padding: 0;
  border: 0;
  background: transparent;
  color: var(--color-text-secondary);
  cursor: pointer;
  border-radius: 0.25rem;
  transition: background 120ms ease, color 120ms ease;
}
.pt-photo-tile__delete:hover {
  background: var(--color-danger-subtle);
  color: var(--color-danger);
}
.pt-photo-tile--picker {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 0.375rem;
  background: var(--color-surface);
  border: 1px dashed var(--color-border-strong);
  color: var(--color-text-secondary);
  cursor: pointer;
  transition: border-color 120ms ease, background 120ms ease, color 120ms ease;
}
.pt-photo-tile--picker:hover, .pt-photo-tile--picker:focus-visible {
  border-color: var(--color-brand);
  background: var(--color-brand-subtle);
  color: var(--color-brand);
  outline: none;
}
.pt-photo-tile--picker[hidden] {
  display: none;
}
.pt-photo-tile__picker-icon {
  width: 1.5rem;
  height: 1.5rem;
}
.pt-photo-tile__picker-label {
  font-size: var(--text-sm);
  font-weight: 500;
}
.pt-project-attributes-editor {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}
.pt-project-attributes-editor__data {
  display: none;
}
.pt-project-attributes-editor__rows {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}
.pt-project-attributes-editor__rows:empty {
  display: none;
}
.pt-project-attributes-editor__row {
  display: grid;
  grid-template-columns: minmax(8rem, 14rem) minmax(0, 1fr) auto;
  gap: 0.75rem;
  align-items: center;
}
.pt-project-attributes-editor__row-name {
  font-size: var(--text-sm);
  font-weight: 500;
  color: var(--color-text-primary);
}
.pt-project-attributes-editor__row-value {
  min-width: 0;
}
.pt-project-attributes-editor__row-remove {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1.75rem;
  height: 1.75rem;
  padding: 0;
  border: 0;
  background: transparent;
  color: var(--color-text-secondary);
  cursor: pointer;
  border-radius: 0.25rem;
  transition: background 120ms ease, color 120ms ease;
}
.pt-project-attributes-editor__row-remove:hover {
  background: var(--color-danger-subtle);
  color: var(--color-danger);
}
.pt-project-attributes-editor__picker {
  display: grid;
  grid-template-columns: minmax(8rem, 14rem) minmax(0, 1fr) auto;
  gap: 0.5rem;
  align-items: center;
  padding-top: 0.25rem;
}
.pt-project-attributes-editor__picker-attr, .pt-project-attributes-editor__picker-value {
  min-width: 0;
}
.pt-project-attributes-editor__picker-value:empty {
  min-height: 2rem;
}
.pt-project-attributes-editor__value-multi {
  width: 100%;
}
.pt-project-destroy-modal {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  font-family: var(--font-sans);
  color: var(--color-text-primary);
}
.pt-project-destroy-modal__lead {
  margin: 0;
  font-size: var(--text-sm);
  color: var(--color-text-secondary);
}
.pt-project-destroy-modal__lead strong {
  color: var(--color-text-primary);
  font-weight: 600;
}
.pt-project-destroy-modal__blocking {
  padding: 0.625rem 0.75rem;
  background: var(--color-surface-2);
  border-radius: 0.25rem;
  border: 1px solid var(--color-border);
}
.pt-project-destroy-modal__blocking-title {
  margin: 0 0 0.375rem;
  font-size: var(--text-xs);
  font-weight: 600;
  color: var(--color-text-secondary);
  text-transform: uppercase;
  letter-spacing: 0.02em;
}
.pt-project-destroy-modal__blocking-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 0.125rem;
}
.pt-project-destroy-modal__blocking-item {
  display: inline-flex;
  align-items: center;
  gap: 0.375rem;
  font-size: var(--text-sm);
  color: var(--color-text-secondary);
}
.pt-project-destroy-modal__blocking-icon {
  color: var(--color-text-tertiary);
  flex-shrink: 0;
}
.pt-project-destroy-modal__blocking-hint {
  margin: 0.5rem 0 0;
  font-size: var(--text-xs);
  color: var(--color-text-tertiary);
}
.pt-project-destroy-modal__form {
  display: flex;
  flex-direction: column;
  gap: 0.875rem;
}
.pt-project-destroy-modal__phases {
  border: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 0.375rem;
}
.pt-project-destroy-modal__phases-legend {
  padding: 0;
  font-size: var(--text-xs);
  font-weight: 600;
  color: var(--color-text-secondary);
  text-transform: uppercase;
  letter-spacing: 0.02em;
  margin-bottom: 0.25rem;
}
.pt-project-destroy-modal__phase, .pt-project-destroy-modal__option {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  font-size: var(--text-sm);
  cursor: pointer;
  user-select: none;
}
.pt-project-destroy-modal__phase-checkbox {
  flex-shrink: 0;
}
.pt-project-destroy-modal__confirmation {
  display: contents;
}
.pt-project-destroy-modal__confirmation[hidden] {
  display: none;
}
.pt-project-destroy-modal__footer {
  display: flex;
  justify-content: flex-end;
  gap: 0.5rem;
  margin-top: 0.25rem;
}
.pt-project-form {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}
.pt-project-form__section {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
  padding: 1rem 1.25rem;
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: 0.25rem;
}
.pt-project-form__section-title {
  margin: 0;
  font-size: var(--text-base);
  font-weight: 600;
  color: var(--color-text-primary);
}
.pt-project-form__row-2 {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 2rem;
}
.pt-project-form__row-sections {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1rem;
  align-items: start;
}
.pt-project-form__pair {
  display: flex;
  gap: 0.5rem;
  align-items: stretch;
}
.pt-project-form__pair .pt-input {
  flex: 1 1 auto;
  min-width: 0;
}
.pt-project-form__pair .pt-select {
  flex: 0 0 5rem;
}
.pt-project-form__map-hint {
  margin: 0;
  text-align: center;
  font-size: var(--text-sm);
  color: var(--color-text-secondary);
}
.pt-project-form__actions {
  display: flex;
  justify-content: flex-end;
  gap: 0.5rem;
  padding-top: 0.25rem;
}
.pt-project-form__actions .pt-btn {
  box-sizing: border-box;
}
.pt-project-form__actions .pt-btn--secondary {
  background: transparent;
  color: var(--color-text-primary);
}
.pt-project-form__actions .pt-btn--secondary:hover {
  background: var(--color-border);
}
@media (max-width: 60rem) {
  .pt-project-form__row-2, .pt-project-form__row-sections {
    grid-template-columns: 1fr;
  }
}
.pt-project-location-picker {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}
.pt-project-location-picker__search-wrap {
  position: relative;
}
.pt-project-location-picker__results {
  list-style: none;
  margin: 0;
  padding: 0.25rem 0;
  position: absolute;
  top: calc(100% + 0.25rem);
  left: 0;
  right: 0;
  z-index: 1010;
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: 0.25rem;
  box-shadow: var(--shadow-card);
  max-height: 16rem;
  overflow-y: auto;
}
.pt-project-location-picker__results[hidden] {
  display: none;
}
.pt-project-location-picker__result {
  padding: 0.375rem 0.625rem;
  font-size: var(--text-sm);
  color: var(--color-text-primary);
  cursor: pointer;
  user-select: none;
}
.pt-project-location-picker__result:hover {
  background: var(--color-surface-2);
}
.pt-project-location-picker__map {
  width: 100%;
  border: 1px solid var(--color-border);
  border-radius: 0.25rem;
  overflow: hidden;
  min-height: 12rem;
}
.pt-project-location-picker__map .leaflet-control-zoom a {
  display: flex;
  align-items: center;
  justify-content: center;
  line-height: 1;
}
.pt-project-documents-page {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}
.pt-project-documents-page__content {
  display: flex;
  flex-direction: column;
}
.pt-documents-summary {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 1.5rem;
  padding: 1.125rem 1.25rem;
  border: 1px solid var(--color-surface-3);
  border-radius: var(--radius-md, 0.5rem);
  background: var(--color-surface);
}
.pt-documents-summary__left {
  display: flex;
  align-items: baseline;
  gap: 0.75rem;
  min-width: 0;
}
.pt-documents-summary__title {
  margin: 0;
  color: var(--color-text-primary);
  font-size: 1rem;
  font-weight: 700;
  line-height: 1.25;
  letter-spacing: 0.01em;
  text-transform: uppercase;
}
.pt-documents-summary__label {
  color: var(--color-text-secondary);
  font-size: 0.8125rem;
  font-weight: 500;
}
.pt-documents-summary__right {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: flex-end;
  gap: 0.625rem;
}
.pt-documents-summary__right .pt-status-badge {
  min-height: 1.45rem;
  padding: 0.175rem 0.6rem;
  font-size: 0.75rem;
  font-weight: 700;
}
.pt-documents-summary__meta {
  color: var(--color-text-secondary);
  font-size: 0.8125rem;
  font-weight: 500;
}
.pt-documents-list {
  border: 1px solid var(--color-surface-3);
  border-radius: var(--radius-md, 0.5rem);
  overflow: hidden;
  background: var(--color-surface);
  box-shadow: 0 1px 2px rgb(15 23 42 / 4%);
}
.pt-documents-list__toolbar-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 1rem;
  min-height: 3.75rem;
  padding: 0.75rem 1rem;
  background: var(--color-surface-2);
  border-bottom: 1px solid var(--color-surface-3);
}
.pt-documents-list__toolbar-left {
  display: inline-flex;
  align-items: center;
  gap: 0.55rem;
  white-space: nowrap;
}
.pt-documents-list__toolbar-right {
  display: flex;
  justify-content: flex-end;
  min-width: 0;
  flex: 1;
}
.pt-documents-list__select-label {
  color: var(--color-text-primary);
  font-size: 0.8125rem;
  font-weight: 600;
}
.pt-documents-list__checkbox {
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.pt-documents-list__checkbox input {
  width: 1rem;
  height: 1rem;
  accent-color: var(--color-brand);
}
.pt-documents-toolbar {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 0.625rem;
  width: 100%;
}
.pt-documents-toolbar__filters, .pt-documents-toolbar__controls, .pt-documents-toolbar__bulk {
  display: flex;
  align-items: center;
  gap: 0.5rem;
}
.pt-documents-toolbar__controls {
  flex-wrap: wrap;
  justify-content: flex-end;
}
.pt-documents-toolbar__select {
  min-width: 9.5rem;
  height: 2.25rem;
  padding: 0 0.625rem;
  border: 1px solid var(--color-surface-3);
  border-radius: var(--radius-sm, 0.25rem);
  background: var(--color-surface);
  color: var(--color-text-primary);
  font-size: 0.8125rem;
  font-weight: 500;
}
.pt-documents-toolbar__select:hover, .pt-documents-toolbar__select:focus {
  border-color: color-mix(in srgb, oklch(45% 0.18 250) 40%, oklch(94% 0.005 250));
  @supports (color: color-mix(in lab, red, red)) {
    border-color: color-mix(in srgb, var(--color-brand) 40%, var(--color-surface-3));
  }
}
.pt-documents-toolbar__select--actions {
  min-width: 7.75rem;
}
.pt-documents-toolbar__bulk-submit {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.25rem;
  height: 2.25rem;
  border: 1px solid var(--color-surface-3);
  border-radius: var(--radius-sm, 0.25rem);
  background: var(--color-surface);
  color: var(--color-text-primary);
}
.pt-documents-toolbar__bulk-submit:not(:disabled):hover {
  border-color: var(--color-brand);
  color: var(--color-brand);
}
.pt-documents-toolbar__bulk-submit:disabled {
  opacity: 0.42;
  cursor: not-allowed;
}
.pt-documents-toolbar__bulk-icon {
  width: 1rem;
  height: 1rem;
}
.pt-documents-list__rows {
  display: flex;
  flex-direction: column;
}
.pt-documents-row {
  display: grid;
  grid-template-columns: 1.75rem minmax(0, 1fr) auto;
  align-items: center;
  gap: 0.875rem;
  min-height: 4.45rem;
  padding: 0.75rem 1rem;
  background: var(--color-surface);
  border-top: 1px solid var(--color-surface-3);
  transition: background-color 120ms ease;
}
.pt-documents-row:first-child {
  border-top: 0;
}
.pt-documents-row:hover {
  background: color-mix(in srgb, oklch(45% 0.18 250) 3.5%, oklch(99% 0 0));
  @supports (color: color-mix(in lab, red, red)) {
    background: color-mix(in srgb, var(--color-brand) 3.5%, var(--color-surface));
  }
}
.pt-documents-row--selected {
  background: color-mix(in srgb, oklch(45% 0.18 250) 8%, oklch(99% 0 0));
  @supports (color: color-mix(in lab, red, red)) {
    background: color-mix(in srgb, var(--color-brand) 8%, var(--color-surface));
  }
}
.pt-documents-row__body {
  min-width: 0;
}
.pt-documents-row__title-link {
  display: inline-block;
  color: var(--color-brand);
  font-size: 0.9375rem;
  font-weight: 650;
  line-height: 1.3;
  word-break: break-word;
}
.pt-documents-row__title-link:hover {
  text-decoration: underline;
}
.pt-documents-row__meta-line {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.45rem;
  margin-top: 0.375rem;
}
.pt-documents-row__meta-line .pt-status-badge {
  min-height: 1.35rem;
  padding: 0.125rem 0.55rem;
  font-size: 0.6875rem;
  font-weight: 700;
}
.pt-documents-row__meta-item {
  position: relative;
  color: var(--color-text-secondary);
  font-size: 0.8125rem;
  font-weight: 500;
  line-height: 1.35;
}
.pt-documents-row__meta-item:not(:first-of-type)::before {
  content: "|";
  margin-right: 0.45rem;
  color: var(--color-text-muted);
}
.pt-documents-row__actions {
  display: inline-flex;
  align-items: center;
  justify-content: flex-end;
  gap: 0.375rem;
}
.pt-documents-row__action-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.125rem;
  height: 2.125rem;
  border: 1px solid var(--color-surface-3);
  border-radius: var(--radius-sm, 0.25rem);
  background: var(--color-surface-2);
  color: var(--color-text-secondary);
  transition: border-color 120ms ease, color 120ms ease, background-color 120ms ease;
}
.pt-documents-row__action-btn:not(:disabled):hover {
  border-color: var(--color-brand);
  background: var(--color-surface);
  color: var(--color-brand);
}
.pt-documents-row__action-btn:disabled, .pt-documents-row__action-btn.is-disabled {
  opacity: 0.42;
  pointer-events: none;
}
.pt-documents-row__action-icon {
  width: 1rem;
  height: 1rem;
}
.pt-documents-row__menu {
  min-width: 7rem;
  margin: 0;
  padding: 0.3rem;
  list-style: none;
}
.pt-documents-row__menu-link {
  display: block;
  padding: 0.45rem 0.625rem;
  border-radius: var(--radius-sm, 0.25rem);
  color: var(--color-text-primary);
  font-size: 0.8125rem;
  font-weight: 500;
}
.pt-documents-row__menu-link:hover {
  background: var(--color-surface-2);
}
.pt-project-documents-empty {
  display: flex;
  min-height: 14rem;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  border: 1px solid var(--color-surface-3);
  border-radius: var(--radius-md, 0.5rem);
  background: var(--color-surface);
  color: var(--color-text-secondary);
}
.pt-project-documents-empty__icon {
  width: 2rem;
  height: 2rem;
  color: var(--color-text-muted);
}
@media (max-width: 1200px) {
  .pt-documents-list__toolbar-row {
    align-items: flex-start;
    flex-direction: column;
  }
  .pt-documents-list__toolbar-right, .pt-documents-toolbar {
    justify-content: flex-start;
  }
}
@media (max-width: 960px) {
  .pt-documents-summary {
    flex-direction: column;
    align-items: flex-start;
  }
  .pt-documents-summary__right {
    justify-content: flex-start;
  }
  .pt-documents-toolbar {
    align-items: stretch;
    flex-direction: column;
  }
  .pt-documents-toolbar__controls, .pt-documents-toolbar__bulk {
    flex-direction: column;
    align-items: stretch;
  }
  .pt-documents-toolbar__select {
    width: 100%;
  }
  .pt-documents-row {
    grid-template-columns: 1.75rem minmax(0, 1fr);
    grid-template-areas: "select body" "select actions";
  }
  .pt-documents-row__select {
    grid-area: select;
  }
  .pt-documents-row__body {
    grid-area: body;
  }
  .pt-documents-row__actions {
    grid-area: actions;
    justify-content: flex-start;
  }
}
.pt-milestones {
  --label-w: 15rem;
  --row-h: 2.75rem;
  --bar-h: 1.35rem;
  --marker-d: var(--bar-h);
  width: 100%;
  container-type: inline-size;
  container-name: milestones;
  font-size: var(--text-sm);
}
.pt-milestones__chart {
  position: relative;
}
.pt-milestones__grid {
  position: absolute;
  left: var(--label-w);
  right: 0;
  top: 0;
  bottom: 0;
  z-index: 0;
  pointer-events: none;
}
.pt-milestones__gridlines {
  position: absolute;
  inset: 0;
}
.pt-milestones__gridline {
  position: absolute;
  left: var(--x);
  top: 0;
  bottom: 0;
  width: 1px;
  background: var(--color-border);
  opacity: 0.6;
}
.pt-milestones__now {
  position: absolute;
  left: var(--x);
  top: 0;
  bottom: 0;
  width: 9px;
  transform: translateX(-50%);
  pointer-events: auto;
  background-image: repeating-linear-gradient(to bottom, #64748b 0 4px, transparent 4px 8px);
  background-position: center;
  background-size: 1px 100%;
  background-repeat: no-repeat;
}
.pt-milestones__rows {
  position: relative;
  z-index: 1;
  pointer-events: none;
}
.pt-milestones__row {
  display: grid;
  grid-template-columns: var(--label-w) 1fr;
  align-items: center;
  min-height: var(--row-h);
}
.pt-milestones__label {
  padding-right: 0.75rem;
  text-align: right;
  line-height: 1.3;
  font-size: var(--text-xs);
  color: var(--color-text-secondary);
}
.pt-milestones__track {
  position: relative;
  height: var(--row-h);
  pointer-events: none;
}
.pt-milestones__track::before {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  top: 50%;
  height: 1px;
  background: var(--color-border);
  opacity: 0.6;
}
.pt-milestones__bar {
  position: absolute;
  left: var(--x);
  width: var(--w);
  top: 50%;
  height: var(--bar-h);
  transform: translateY(-50%);
  border-radius: calc(var(--bar-h) / 2);
  background: #edeff3;
  pointer-events: auto;
  transition: box-shadow 0.12s ease;
}
.pt-milestones__bar:hover {
  box-shadow: 0 0 0 4px rgba(100, 116, 139, 0.25);
}
.pt-milestones__bar-fill {
  display: block;
  width: var(--fill);
  height: 100%;
  border-radius: calc(var(--bar-h) / 2) 0 0 calc(var(--bar-h) / 2);
  background: #0684d7;
}
.pt-milestones__bar--done .pt-milestones__bar-fill {
  border-radius: calc(var(--bar-h) / 2);
  background: #00a57a;
}
.pt-milestones__marker {
  position: absolute;
  left: var(--x);
  top: 50%;
  width: var(--marker-d);
  height: var(--marker-d);
  transform: translate(-50%, -50%);
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  background: #94a3b8;
  pointer-events: auto;
  transition: box-shadow 0.12s ease;
}
.pt-milestones__marker--past, .pt-milestones__marker--current {
  background: #00a57a;
}
.pt-milestones__marker--future {
  background: #94a3b8;
}
.pt-milestones__marker:hover {
  box-shadow: 0 0 0 4px rgba(100, 116, 139, 0.25);
}
.pt-milestones__check {
  width: 70%;
  height: 70%;
  color: #fff;
  stroke-width: 2.75;
}
.pt-milestones__axis {
  display: grid;
  grid-template-columns: var(--label-w) 1fr;
  margin-top: 0.5rem;
}
.pt-milestones__axis-track {
  position: relative;
  height: 1.25rem;
}
.pt-milestones__tick {
  position: absolute;
  left: var(--x);
  transform: translateX(-50%);
  font-size: var(--text-xs);
  color: var(--color-text-secondary);
  white-space: nowrap;
}
.pt-milestones__marker[data-tooltip]::after, .pt-milestones__bar[data-tooltip]::after, .pt-milestones__now[data-tooltip]::after {
  content: attr(data-tooltip);
  position: absolute;
  bottom: calc(100% + 0.5rem);
  left: 50%;
  transform: translateX(-50%);
  z-index: 10;
  white-space: nowrap;
  padding: 0.35rem 0.6rem;
  border: 1px solid var(--color-border);
  border-radius: 0.375rem;
  background: #fff;
  box-shadow: 0 2px 10px rgba(15, 23, 42, 0.14);
  font-size: var(--text-xs);
  line-height: 1.2;
  color: var(--color-text-primary);
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.12s ease;
  pointer-events: none;
}
.pt-milestones__marker[data-tooltip]::before, .pt-milestones__bar[data-tooltip]::before, .pt-milestones__now[data-tooltip]::before {
  content: "";
  position: absolute;
  bottom: calc(100% + 0.5rem - 0.21rem);
  left: 50%;
  z-index: 11;
  width: 0.5rem;
  height: 0.5rem;
  margin-left: -0.25rem;
  transform: rotate(45deg);
  background: #fff;
  border-right: 1px solid var(--color-border);
  border-bottom: 1px solid var(--color-border);
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.12s ease;
  pointer-events: none;
}
.pt-milestones__now[data-tooltip]::after {
  left: auto;
  right: calc(50% - 0.25rem - 6px);
  transform: none;
}
.pt-milestones__now[data-tooltip]::before {
  left: auto;
  right: 50%;
  margin-left: 0;
  margin-right: -0.25rem;
}
.pt-milestones__marker:hover::after, .pt-milestones__marker:hover::before, .pt-milestones__bar:hover::after, .pt-milestones__bar:hover::before, .pt-milestones__now:hover::after, .pt-milestones__now:hover::before {
  opacity: 1;
  visibility: visible;
}
@container milestones (max-width: 640px) {
  .pt-milestones {
    --label-w: 8rem;
    font-size: var(--text-xs);
  }
  .pt-milestones__label {
    padding-right: 0.625rem;
  }
}
.pt-project-participants {
  display: flex;
  flex-direction: column;
  gap: 1.25rem;
  --pt-participant-drawer-bg: oklch(98.5% 0.001 237.357);
}
.pt-participants-block {
  position: relative;
}
.pt-participants-section__toggle-all {
  display: inline-flex;
  align-items: center;
  gap: 0.375rem;
  padding: 0 1.25rem 0 0;
  border: 0;
  background: transparent;
  cursor: pointer;
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--color-brand);
  white-space: nowrap;
}
.pt-participants-section__toggle-all:hover {
  color: var(--color-brand-hover);
}
.pt-participants-section__toggle-all:focus-visible {
  outline: 2px solid var(--color-brand);
  outline-offset: 2px;
  border-radius: var(--radius-sm);
}
.pt-participants-section__toggle-all-chevron {
  transition: transform 0.18s ease;
}
.pt-participants-section__toggle-all--expanded .pt-participants-section__toggle-all-chevron {
  transform: rotate(180deg);
}
.pt-participants-list {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}
.pt-participant-card-unit {
  position: relative;
}
.pt-participant-card {
  position: relative;
  z-index: 1;
  display: flex;
  align-items: stretch;
  min-width: 0;
  background: var(--color-surface, white);
  border: 1px solid oklch(91% 0 0);
  border-radius: 0.75rem;
  box-shadow: 0 0.25rem 0.75rem oklch(20% 0 0 / 6%);
  cursor: pointer;
  transition: transform 120ms ease-out, box-shadow 120ms ease-out, border-color 120ms ease-out;
}
.pt-participant-card:hover {
  border-color: oklch(82% 0 0);
  box-shadow: 0 0.45rem 1rem oklch(20% 0 0 / 12%);
  transform: translateY(-1px);
}
.pt-participant-card__media {
  position: relative;
  flex: 0 0 7rem;
  max-width: 7rem;
  align-self: stretch;
  aspect-ratio: 1;
  overflow: hidden;
  border-radius: 0.6875rem 0 0 0.6875rem;
  background: #fff;
}
.pt-participant-card__media .pt-avatar {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  border-radius: 0;
}
.pt-participant-card__media .pt-avatar:has(img) {
  background: #fff;
}
.pt-participant-card__media .pt-avatar img {
  object-fit: contain;
  box-sizing: border-box;
}
.pt-participant-card__media .pt-avatar__initials {
  font-size: 1.5rem;
}
.pt-participant-card__body {
  flex: 1 1 auto;
  min-width: 0;
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 0.25rem;
  padding: 0.75rem 1rem;
}
.pt-participant-card__name {
  font-size: var(--text-base);
  font-weight: 700;
  color: var(--color-text-primary);
  line-height: 1.3;
}
.pt-participant-card__roles {
  font-size: var(--text-sm);
  color: var(--color-text-secondary);
  line-height: 1.4;
}
.pt-participant-card__meta {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 0.625rem;
  margin-top: 0.125rem;
}
.pt-participant-card__ongoing-link {
  font-size: var(--text-sm);
  font-weight: 500;
}
.pt-participant-card__contacts {
  cursor: default;
}
.pt-participant-card__contacts .pt-metric-pill__label {
  display: inline;
}
.pt-participant-card__aside {
  flex: 0 0 auto;
  display: flex;
  align-items: center;
  padding-right: 1rem;
}
.pt-participant-card__toggle {
  display: inline-flex;
  align-items: center;
  gap: 0.25rem;
  padding: 0.25rem;
  border: 0;
  background: transparent;
  cursor: pointer;
  font-size: var(--text-sm);
  font-weight: 500;
  color: var(--color-brand);
  white-space: nowrap;
}
.pt-participant-card__toggle:hover {
  color: var(--color-brand-hover);
}
.pt-participant-card__toggle:focus-visible {
  outline: 2px solid var(--color-brand);
  outline-offset: 2px;
  border-radius: var(--radius-sm);
}
.pt-participant-card__toggle-chevron {
  transition: transform 0.18s ease;
}
.pt-participant-card-unit--expanded .pt-participant-card__toggle-chevron {
  transform: rotate(180deg);
}
.pt-participant-card__drawer {
  max-height: 0;
  overflow: hidden;
  margin: -1px 1.25rem 0;
  border: 1px solid oklch(91% 0 0);
  border-top: 0;
  border-radius: 0 0 0.75rem 0.75rem;
  background: var(--pt-participant-drawer-bg);
  transition: max-height 0.3s ease;
}
.pt-participant-card-unit--expanded .pt-participant-card__drawer {
  max-height: 1600px;
}
.pt-participant-card__drawer-inner {
  container-type: inline-size;
  container-name: participants;
  padding: 1.1rem 1.25rem 1.25rem;
}
.pt-participant-card__columns {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1.5rem;
}
.pt-participant-detail__title {
  margin: 0 0 0.625rem;
  font-size: var(--text-xs);
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--color-text-muted);
}
.pt-participant-detail__list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 0.625rem;
}
.pt-participant-detail__item {
  display: flex;
  align-items: flex-start;
  gap: 0.5rem;
  font-size: var(--text-sm);
  color: var(--color-text-primary);
  line-height: 1.4;
}
.pt-participant-detail__icon {
  flex: 0 0 auto;
  margin-top: 0.125rem;
  color: var(--color-text-muted);
}
.pt-participant-detail__value {
  min-width: 0;
  word-break: break-word;
}
.pt-participant-detail__contacts {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}
.pt-contact-card {
  display: flex;
  align-items: flex-start;
  gap: 0.75rem;
  padding: 0.75rem;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  background: var(--color-surface);
}
.pt-contact-card__avatar {
  flex: 0 0 auto;
}
.pt-contact-card__body {
  flex: 1 1 auto;
  min-width: 0;
}
.pt-contact-card__name {
  font-size: var(--text-sm);
  font-weight: 700;
  color: var(--color-text-primary);
  line-height: 1.3;
}
.pt-contact-card__title {
  font-size: var(--text-xs);
  color: var(--color-text-secondary);
  margin-top: 0.0625rem;
}
.pt-contact-card__rows {
  list-style: none;
  margin: 0.5rem 0 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 0.3125rem;
}
.pt-contact-card__row {
  display: flex;
  align-items: center;
  gap: 0.4375rem;
  font-size: var(--text-xs);
  color: var(--color-text-primary);
  line-height: 1.3;
}
.pt-contact-card__row-icon {
  flex: 0 0 auto;
  color: var(--color-text-muted);
}
.pt-contact-card__row-value {
  min-width: 0;
  word-break: break-word;
}
@container participants (max-width: 560px) {
  .pt-participant-card__columns {
    grid-template-columns: 1fr;
    gap: 1.25rem;
  }
}
@media (max-width: 560px) {
  .pt-participant-card {
    flex-direction: column;
  }
  .pt-participant-card__media {
    flex-basis: auto;
    max-width: none;
    width: 100%;
    min-height: 7rem;
    border-radius: 0.6875rem 0.6875rem 0 0;
  }
  .pt-participant-card__aside {
    padding: 0 1rem 0.75rem;
  }
}
@media (prefers-reduced-motion: reduce) {
  .pt-participant-card, .pt-participant-card__drawer, .pt-participant-card__toggle-chevron, .pt-participants-section__toggle-all-chevron {
    transition: none;
  }
}
.pt-updates-timeline {
  width: 100%;
  container-type: inline-size;
  container-name: updates;
}
.pt-updates-timeline__track {
  position: relative;
  list-style: none;
  margin: 0;
  padding: 0;
}
.pt-updates-timeline__track::before {
  content: "";
  position: absolute;
  top: 0.5rem;
  bottom: 0.5rem;
  left: 50%;
  transform: translateX(-50%);
  width: 2px;
  background: #0684d7;
}
.pt-updates-row {
  position: relative;
  display: grid;
  grid-template-columns: 1fr 1fr;
  column-gap: 2.75rem;
  padding-top: 0.55rem;
  padding-bottom: 1.75rem;
}
.pt-updates-row:last-child {
  padding-bottom: 0;
}
.pt-updates-row--hidden {
  display: none;
}
.pt-updates-row__dot {
  position: absolute;
  left: 50%;
  top: 0.55rem;
  transform: translate(-50%, -50%);
  width: 0.875rem;
  height: 0.875rem;
  border-radius: var(--radius-full);
  background: #0684d7;
  box-shadow: 0 0 0 3px var(--color-surface);
  z-index: 1;
}
.pt-updates-row__date {
  grid-row: 1;
  align-self: start;
  transform: translateY(-50%);
  font-size: var(--text-xs);
  font-weight: 700;
  color: var(--color-text-secondary);
}
.pt-updates-row__cards {
  grid-row: 1;
  display: flex;
  flex-direction: column;
  gap: 0.625rem;
  min-width: 0;
  margin-top: -0.08rem;
}
.pt-updates-row--right .pt-updates-row__date {
  grid-column: 1;
  justify-self: end;
  text-align: right;
}
.pt-updates-row--right .pt-updates-row__cards {
  grid-column: 2;
}
.pt-updates-row--left .pt-updates-row__cards {
  grid-column: 1;
}
.pt-updates-row--left .pt-updates-row__date {
  grid-column: 2;
  justify-self: start;
  text-align: left;
}
.pt-update-card {
  position: relative;
  display: flex;
  align-items: flex-start;
  gap: 0.75rem;
  padding: 0.75rem 1rem;
  background: #f7f9fa;
  border: 1px solid #d1d2d3;
  border-radius: 0.5rem;
  transition: background-color 0.15s ease, border-color 0.15s ease;
}
.pt-update-card__icon {
  flex: 0 0 auto;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--color-text-secondary);
}
.pt-update-card__icon-glyph {
  width: 1.25rem;
  height: 1.25rem;
}
.pt-update-card__body {
  flex: 1 1 auto;
  min-width: 0;
}
.pt-update-card__text {
  margin: 0;
  font-size: var(--text-sm);
  line-height: 1.5;
  color: var(--color-text-primary);
}
.pt-update-card::before, .pt-update-card::after {
  content: "";
  position: absolute;
  top: -1px;
  width: 0;
  height: 0;
  border-left: 0.6rem solid transparent;
  border-right: 0.6rem solid transparent;
  border-top: 0.6rem solid #d1d2d3;
  transition: border-top-color 0.15s ease;
}
.pt-update-card::after {
  top: 0;
  border-top-color: #f7f9fa;
}
.pt-updates-row--right .pt-update-card {
  border-top-left-radius: 0;
}
.pt-updates-row--right .pt-update-card::before {
  left: -1px;
  transform: translateX(-50%);
}
.pt-updates-row--right .pt-update-card::after {
  left: 1px;
  transform: translateX(-50%);
}
.pt-updates-row--left .pt-update-card {
  border-top-right-radius: 0;
}
.pt-updates-row--left .pt-update-card::before {
  right: -1px;
  transform: translateX(50%);
}
.pt-updates-row--left .pt-update-card::after {
  right: 1px;
  transform: translateX(50%);
}
.pt-update-card:hover {
  background: #e9f5fc;
  border-color: rgba(6, 132, 215, 0.7);
}
.pt-update-card:hover::before {
  border-top-color: rgba(6, 132, 215, 0.7);
}
.pt-update-card:hover::after {
  border-top-color: #e9f5fc;
}
.pt-updates-row:has(.pt-update-card:hover) .pt-updates-row__dot {
  animation: pt-dot-pulse 0.9s ease-in-out infinite;
}
@keyframes pt-dot-pulse {
  0%, 100% {
    transform: translate(-50%, -50%) scale(0.9);
  }
  50% {
    transform: translate(-50%, -50%) scale(1.25);
  }
}
@media (prefers-reduced-motion: reduce) {
  .pt-updates-row:has(.pt-update-card:hover) .pt-updates-row__dot {
    animation: none;
  }
}
.pt-update-card__gallery {
  margin-top: 0.75rem;
}
.pt-update-card__photos {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
}
.pt-update-card__photo {
  position: relative;
  width: 4.5rem;
  height: 4.5rem;
  padding: 0;
  border: 0;
  border-radius: var(--radius-md);
  overflow: hidden;
  cursor: pointer;
  background: var(--color-surface-3);
}
.pt-update-card__photo-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 0.15s ease;
}
.pt-update-card__photo:hover .pt-update-card__photo-img, .pt-update-card__photo:focus-visible .pt-update-card__photo-img {
  transform: scale(1.05);
}
.pt-update-card__photo:focus-visible {
  outline: 2px solid var(--color-brand);
  outline-offset: 2px;
}
.pt-update-card__photo-more {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: var(--text-base);
  font-weight: 700;
  color: #fff;
  background: oklch(20% 0.01 250 / 55%);
}
.pt-updates-timeline__toggle {
  display: flex;
  justify-content: center;
  margin-top: 1.5rem;
}
.pt-updates-timeline__toggle-link {
  display: inline-flex;
  align-items: center;
  gap: 0.25rem;
  padding: 0;
  background: none;
  border: 0;
  cursor: pointer;
  font-size: var(--text-sm);
  font-weight: 600;
  color: #0684d7;
}
.pt-updates-timeline__toggle-link:hover {
  text-decoration: underline;
}
.pt-updates-timeline__toggle-link:focus-visible {
  outline: 2px solid #0684d7;
  outline-offset: 2px;
  border-radius: 2px;
}
.pt-updates-timeline__toggle-chevron {
  width: 1rem;
  height: 1rem;
  transition: transform 0.15s ease;
}
.pt-updates-timeline__toggle-link[aria-expanded="true"] .pt-updates-timeline__toggle-chevron {
  transform: rotate(180deg);
}
@container updates (max-width: 640px) {
  .pt-updates-timeline__track::before {
    left: 0.4375rem;
    transform: none;
  }
  .pt-updates-row {
    grid-template-columns: 1.25rem 1fr;
    grid-template-rows: auto auto;
    column-gap: 0.875rem;
  }
  .pt-updates-row__dot {
    left: 0.4375rem;
  }
  .pt-updates-row--right .pt-updates-row__date, .pt-updates-row--left .pt-updates-row__date {
    grid-column: 2;
    grid-row: 1;
    justify-self: start;
    text-align: left;
    margin-bottom: 0.5rem;
  }
  .pt-updates-row--right .pt-updates-row__cards, .pt-updates-row--left .pt-updates-row__cards {
    grid-column: 2;
    grid-row: 2;
    margin-top: 0;
  }
  .pt-updates-row--right .pt-update-card, .pt-updates-row--left .pt-update-card {
    border-radius: 0.5rem;
    border-top-left-radius: 0;
  }
  .pt-updates-row--left .pt-update-card::before, .pt-updates-row--right .pt-update-card::before {
    right: auto;
    left: -1px;
    transform: translateX(-50%);
  }
  .pt-updates-row--left .pt-update-card::after, .pt-updates-row--right .pt-update-card::after {
    right: auto;
    left: 1px;
    transform: translateX(-50%);
  }
}
.pt-product-form {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}
.pt-product-form__section {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
  padding: 1rem 1.25rem;
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: 0.25rem;
}
.pt-product-form__section-title {
  margin: 0;
  font-size: var(--text-base);
  font-weight: 600;
  color: var(--color-text-primary);
}
.pt-product-form__hint {
  margin: 0;
  font-size: var(--text-sm);
  color: var(--color-text-secondary);
}
.pt-product-form__row-2 {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 2rem;
}
.pt-product-form__document {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}
.pt-product-form__document-label {
  font-size: var(--text-sm);
  font-weight: 500;
  color: var(--color-text-primary);
}
.pt-product-form__document-current {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  margin: 0;
  font-size: var(--text-sm);
  color: var(--color-text-secondary);
}
.pt-product-form__document-name {
  font-weight: 500;
  color: var(--color-text-primary);
}
.pt-product-form__document-remove {
  display: inline-flex;
  align-items: center;
  gap: 0.375rem;
  cursor: pointer;
}
.pt-product-form__actions {
  display: flex;
  justify-content: flex-end;
  gap: 0.5rem;
  padding-top: 0.25rem;
}
.pt-product-form__actions .pt-btn {
  box-sizing: border-box;
}
.pt-product-form__actions .pt-btn--secondary {
  background: transparent;
  color: var(--color-text-primary);
}
.pt-product-form__actions .pt-btn--secondary:hover {
  background: var(--color-border);
}
.pt-product-aspects__rows {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}
.pt-product-aspects__rows:empty {
  display: none;
}
.pt-product-aspects__row {
  display: grid;
  grid-template-columns: minmax(8rem, 14rem) minmax(0, 1fr) auto;
  gap: 0.5rem;
  align-items: center;
}
.pt-product-aspects__remove {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1.75rem;
  height: 1.75rem;
  padding: 0;
  border: 0;
  background: transparent;
  color: var(--color-text-secondary);
  cursor: pointer;
  border-radius: 0.25rem;
  transition: background 120ms ease, color 120ms ease;
}
.pt-product-aspects__remove:hover {
  background: var(--color-danger-subtle);
  color: var(--color-danger);
}
.pt-product-aspects__add {
  padding-top: 0.25rem;
}
.pt-product-attributes-editor {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  margin-top: 0.5rem;
}
.pt-product-attributes-editor__data {
  display: none;
}
.pt-product-attributes-editor__rows {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}
.pt-product-attributes-editor__rows:empty {
  display: none;
}
.pt-product-attributes-editor__row {
  display: grid;
  grid-template-columns: minmax(16rem, 25rem) minmax(0, 1fr) auto;
  gap: 0.75rem;
  align-items: center;
}
.pt-product-attributes-editor__row-name {
  font-size: var(--text-sm);
  font-weight: 500;
  color: var(--color-text-primary);
}
.pt-product-attributes-editor__row-value {
  min-width: 0;
}
.pt-product-attributes-editor__row-remove {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1.75rem;
  height: 1.75rem;
  padding: 0;
  border: 0;
  background: transparent;
  color: var(--color-text-secondary);
  cursor: pointer;
  border-radius: 0.25rem;
  transition: background 120ms ease, color 120ms ease;
}
.pt-product-attributes-editor__row-remove:hover {
  background: var(--color-danger-subtle);
  color: var(--color-danger);
}
.pt-product-attributes-editor__picker {
  display: grid;
  grid-template-columns: minmax(16rem, 25rem) minmax(0, 1fr) auto;
  gap: 0.5rem;
  align-items: center;
  padding-top: 0.25rem;
}
.pt-product-attributes-editor__picker-attr, .pt-product-attributes-editor__picker-value {
  min-width: 0;
}
.pt-product-attributes-editor__picker-value:empty {
  min-height: 2rem;
}
.pt-product-attributes-editor__picker[hidden] {
  display: none;
}
.pt-product-attributes-editor__empty {
  font-size: var(--text-sm);
  color: var(--color-text-secondary);
  padding: 0.5rem 0;
}
.pt-product-attributes-editor__empty[hidden] {
  display: none;
}
@media (max-width: 60rem) {
  .pt-product-form__row-2 {
    grid-template-columns: 1fr;
  }
  .pt-product-aspects__row {
    grid-template-columns: 1fr;
  }
  .pt-product-attributes-editor__row {
    grid-template-columns: minmax(0, 1fr) auto;
    grid-template-areas: "name name" "value remove";
  }
  .pt-product-attributes-editor__row-name {
    grid-area: name;
  }
  .pt-product-attributes-editor__row-value {
    grid-area: value;
  }
  .pt-product-attributes-editor__row-remove {
    grid-area: remove;
  }
  .pt-product-attributes-editor__picker {
    grid-template-columns: minmax(0, 1fr) auto;
    grid-template-areas: "attr attr" "value add";
  }
  .pt-product-attributes-editor__picker-attr {
    grid-area: attr;
  }
  .pt-product-attributes-editor__picker-value {
    grid-area: value;
  }
  .pt-product-attributes-editor__picker > [data-product-attributes-editor-target="addButton"] {
    grid-area: add;
  }
}
.pt-product-import-modal {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  font-family: var(--font-sans);
  color: var(--color-text-primary);
}
.pt-product-import-modal__instructions {
  margin: 0;
  font-size: var(--text-sm);
  color: var(--color-text-secondary);
}
.pt-product-import-modal__form {
  display: flex;
  flex-direction: column;
  gap: 0.875rem;
}
.pt-product-import-modal__footer {
  display: flex;
  justify-content: flex-end;
  gap: 0.5rem;
  margin-top: 0.25rem;
}
.pt-product-import-modal__result {
  display: flex;
  flex-direction: column;
  gap: 0.875rem;
}
.pt-product-import-modal__message {
  display: flex;
  align-items: flex-start;
  gap: 0.5rem;
  margin: 0;
  padding: 0.75rem;
  border-radius: 0.375rem;
  font-size: var(--text-sm);
}
.pt-product-import-modal__message--success {
  background: var(--color-success-soft, #ecfdf5);
  color: var(--color-success-strong, #047857);
  border: 1px solid var(--color-success, #10b981);
}
.pt-product-import-modal__message--error {
  background: var(--color-danger-soft, #fef2f2);
  color: var(--color-danger-strong, #b91c1c);
  border: 1px solid var(--color-danger, #ef4444);
}
.pt-product-import-modal__message-icon {
  flex-shrink: 0;
  margin-top: 0.0625rem;
}
.pt-promo-card {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 1rem;
  text-align: center;
  padding: 1.25rem;
  min-height: 14.5rem;
  width: 100%;
  height: 100%;
  background: #22b68e;
  border-radius: var(--radius-lg);
  border: 1px solid #22b68e;
  box-shadow: 0 0.25rem 0.75rem oklch(40% 0.14 162 / 30%);
  color: var(--color-text-inverse);
  transition: box-shadow 0.15s ease, transform 0.15s ease;
  &:hover {
    box-shadow: 0 0.5rem 1.25rem oklch(40% 0.14 162 / 45%);
    transform: translateY(-1px);
  }
}
.pt-promo-card__visual {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 3.75rem;
  height: 3.75rem;
  background: oklch(100% 0 0);
  border-radius: 9999px;
  flex-shrink: 0;
  .pt-icon {
    width: 1.65rem;
    height: 1.65rem;
    color: oklch(25% 0 0);
    stroke-width: 1.25;
  }
}
.pt-promo-card__title {
  font-size: 1.05rem;
  font-weight: 700;
  line-height: 1.3;
  color: var(--color-text-inverse);
  margin: 0;
}
.pt-promo-card__message {
  font-size: 0.85rem;
  font-weight: 500;
  line-height: 1.5;
  color: oklch(95% 0 0);
  margin: 0;
  max-width: 24ch;
}
.pt-promo-card .pt-btn--secondary {
  background: oklch(100% 0 0);
  color: oklch(25% 0.01 162);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  font-size: 0.8rem;
  padding: 0.6rem 1.1rem;
  border-radius: var(--radius-md);
  white-space: nowrap;
  &:hover {
    background: oklch(95% 0 0);
    color: oklch(18% 0.01 162);
  }
}
.pt-company-hits--list .pt-company-grid__item > .pt-promo-card, .pt-product-hits--list .pt-product-grid__item > .pt-promo-card, .pt-project-hits--list .pt-project-grid__item > .pt-promo-card {
  min-height: 6.25rem;
  height: 100%;
}
.pt-company-hits--list .pt-promo-card, .pt-product-hits--list .pt-promo-card, .pt-project-hits--list .pt-promo-card {
  display: grid;
  grid-template-columns: 4rem minmax(0, 1fr) auto;
  grid-template-areas: "visual title button" "visual message button";
  align-items: center;
  column-gap: 1rem;
  row-gap: 0.2rem;
  text-align: left;
  padding: 0.95rem;
  min-width: 0;
}
.pt-company-hits--list .pt-promo-card__visual, .pt-product-hits--list .pt-promo-card__visual, .pt-project-hits--list .pt-promo-card__visual {
  grid-area: visual;
  align-self: center;
  justify-self: center;
  width: 3.75rem;
  height: 3.75rem;
  flex: none;
}
.pt-company-hits--list .pt-promo-card__visual .pt-icon, .pt-product-hits--list .pt-promo-card__visual .pt-icon, .pt-project-hits--list .pt-promo-card__visual .pt-icon {
  width: 1.55rem;
  height: 1.55rem;
}
.pt-company-hits--list .pt-promo-card__title, .pt-product-hits--list .pt-promo-card__title, .pt-project-hits--list .pt-promo-card__title {
  grid-area: title;
  align-self: end;
  min-width: 0;
  margin: 0;
  font-size: 1rem;
  line-height: 1.2;
  white-space: normal;
}
.pt-company-hits--list .pt-promo-card__message, .pt-product-hits--list .pt-promo-card__message, .pt-project-hits--list .pt-promo-card__message {
  grid-area: message;
  align-self: start;
  min-width: 0;
  max-width: 78ch;
  margin: 0;
  font-size: 0.82rem;
  line-height: 1.3;
  white-space: normal;
  overflow: hidden;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  line-clamp: 2;
  -webkit-box-orient: vertical;
}
.pt-company-hits--list .pt-promo-card .pt-btn--secondary, .pt-product-hits--list .pt-promo-card .pt-btn--secondary, .pt-project-hits--list .pt-promo-card .pt-btn--secondary {
  grid-area: button;
  align-self: center;
  justify-self: end;
  min-height: 2.35rem;
  padding: 0.7rem 1.2rem;
  font-size: 0.78rem;
  line-height: 1;
}
@media (max-width: 1100px) {
  .pt-company-hits--list .pt-company-grid__item > .pt-promo-card, .pt-product-hits--list .pt-product-grid__item > .pt-promo-card, .pt-project-hits--list .pt-project-grid__item > .pt-promo-card {
    min-height: auto;
  }
  .pt-company-hits--list .pt-promo-card, .pt-product-hits--list .pt-promo-card, .pt-project-hits--list .pt-promo-card {
    grid-template-columns: 1fr;
    grid-template-areas: "visual" "title" "message" "button";
    justify-items: center;
    text-align: center;
    row-gap: 0.7rem;
    padding: 1.25rem;
  }
  .pt-company-hits--list .pt-promo-card__title, .pt-product-hits--list .pt-promo-card__title, .pt-project-hits--list .pt-promo-card__title, .pt-company-hits--list .pt-promo-card__message, .pt-product-hits--list .pt-promo-card__message, .pt-project-hits--list .pt-promo-card__message {
    align-self: center;
    max-width: 32rem;
  }
  .pt-company-hits--list .pt-promo-card .pt-btn--secondary, .pt-product-hits--list .pt-promo-card .pt-btn--secondary, .pt-project-hits--list .pt-promo-card .pt-btn--secondary {
    justify-self: center;
  }
}
.pt-public-footer {
  background: oklch(20% 0.01 255);
  color: oklch(85% 0.01 255);
  border-top: 1px solid oklch(100% 0 0 / 10%);
}
.pt-public-footer__container {
  width: 100%;
  max-width: none;
  margin: 0;
  padding: 3.1rem 6.4rem 1.55rem;
}
.pt-public-footer__grid {
  display: grid;
  grid-template-columns: minmax(24rem, 2.05fr) minmax(10.5rem, 0.9fr) minmax(15.75rem, 1.25fr) minmax(8.25rem, 0.65fr) minmax(10rem, 0.7fr);
  column-gap: 3.25rem;
  row-gap: 1.5rem;
  align-items: start;
}
.pt-public-footer__brand {
  min-width: 0;
  padding-right: 1rem;
}
.pt-public-footer__column {
  min-width: 0;
  margin: 0;
  padding: 0;
  align-self: start;
}
.pt-public-footer__logo {
  display: block;
  height: 2.25rem;
  width: auto;
}
.pt-public-footer__description {
  margin: 1.25rem 0 0;
  max-width: 38rem;
  font-size: 0.95rem;
  line-height: 1.72;
  color: oklch(78% 0.01 255);
}
.pt-public-footer__socials {
  list-style: none;
  margin: 2.05rem 0 0;
  padding: 0;
  display: flex;
  align-items: center;
  gap: 0.9rem;
}
.pt-public-footer__social-link {
  color: oklch(80% 0.01 255);
  width: 2.45rem;
  height: 2.45rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  text-decoration: none;
  border-radius: 999px;
  border: 1px solid oklch(100% 0 0 / 20%);
  transition: color 120ms ease, border-color 120ms ease, background 120ms ease;
}
.pt-public-footer__social-link svg {
  width: 1.25rem;
  height: 1.25rem;
}
.pt-public-footer__social-link:hover {
  color: oklch(100% 0 0);
  border-color: oklch(100% 0 0 / 42%);
  background: oklch(100% 0 0 / 8%);
}
.pt-public-footer__security {
  display: block;
  margin-top: 2rem;
  max-width: 19.5rem;
  width: 100%;
  height: auto;
  opacity: 0.92;
}
.pt-public-footer__heading {
  margin: 0 0 1.15rem;
  font-size: 1.04rem;
  line-height: 1.25;
  color: oklch(96% 0 0);
  font-weight: 700;
}
.pt-public-footer__list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: 0.68rem;
}
.pt-public-footer__list a {
  color: oklch(82% 0.01 255);
  text-decoration: none;
  font-size: 0.95rem;
  line-height: 1.35;
  font-weight: 400;
}
.pt-public-footer__list a:hover {
  color: oklch(100% 0 0);
}
.pt-public-footer__language {
  margin-top: 3.6rem;
  font-size: 0.95rem;
  line-height: 1.5;
  color: oklch(75% 0.01 255);
}
.pt-public-footer__language a {
  color: oklch(90% 0.01 255);
  margin-left: 0.35rem;
  text-decoration: underline;
}
.pt-public-footer__bottom {
  margin-top: 2.05rem;
  padding-top: 1.25rem;
  border-top: 1px solid oklch(100% 0 0 / 16%);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
}
.pt-public-footer__legal {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 1rem;
  font-size: 0.9rem;
  line-height: 1.4;
}
.pt-public-footer__legal a {
  color: oklch(78% 0.01 255);
  text-decoration: none;
}
.pt-public-footer__legal a:hover {
  color: oklch(100% 0 0);
}
.pt-public-footer__copyright {
  color: oklch(71% 0.01 255);
}
.pt-public-footer__version {
  font-size: 0.9rem;
  line-height: 1.4;
  color: oklch(71% 0.01 255);
  text-align: right;
  white-space: nowrap;
}
@media (max-width: 1440px) {
  .pt-public-footer__container {
    padding-left: 4.5rem;
    padding-right: 4.5rem;
  }
  .pt-public-footer__grid {
    grid-template-columns: minmax(22rem, 1.85fr) minmax(9.5rem, 0.85fr) minmax(14rem, 1.15fr) minmax(7.75rem, 0.65fr) minmax(9.5rem, 0.7fr);
    column-gap: 2.6rem;
  }
}
@media (max-width: 1200px) {
  .pt-public-footer__container {
    padding-left: 2rem;
    padding-right: 2rem;
  }
  .pt-public-footer__grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    column-gap: 3rem;
    row-gap: 2rem;
  }
  .pt-public-footer__brand {
    grid-column: 1 / -1;
    padding-right: 0;
  }
  .pt-public-footer__description {
    max-width: 42rem;
  }
}
@media (max-width: 720px) {
  .pt-public-footer__container {
    padding: 2.25rem 1.25rem 1.5rem;
  }
  .pt-public-footer__grid {
    grid-template-columns: 1fr;
    row-gap: 1.6rem;
  }
  .pt-public-footer__description {
    max-width: none;
  }
  .pt-public-footer__language {
    margin-top: 2rem;
  }
  .pt-public-footer__bottom {
    flex-direction: column;
    align-items: flex-start;
  }
  .pt-public-footer__version {
    text-align: left;
    white-space: normal;
  }
}
.pt-public-header {
  position: sticky;
  top: 0;
  z-index: 45;
  background: oklch(22% 0.015 255);
  border-bottom: 1px solid oklch(100% 0 0 / 12%);
}
.pt-public-header__container {
  width: 100%;
  max-width: none;
  margin: 0;
  padding-inline: 1.25rem;
}
.pt-public-header__inner {
  min-height: 4.75rem;
  display: grid;
  grid-template-columns: minmax(220px, 1fr) auto minmax(320px, 1fr);
  align-items: center;
  gap: 0.75rem;
}
.pt-public-header__brand {
  justify-self: start;
}
.pt-public-header__logo-link {
  display: inline-flex;
  align-items: center;
}
.pt-public-header__logo {
  height: 2.25rem;
  width: auto;
}
.pt-public-header__menu {
  display: contents;
}
.pt-public-header__nav {
  justify-self: center;
  display: flex;
  align-items: center;
  gap: 0.2rem;
  min-width: 0;
}
.pt-public-header__separator {
  color: oklch(98% 0.01 255 / 55%);
  margin: 0 0.55rem;
  font-size: 1rem;
  line-height: 1;
}
.pt-public-header__link, .pt-public-header__solutions-button {
  border: 0;
  background: transparent;
  color: oklch(90% 0.01 255);
  text-decoration: none;
  padding: 0.5rem 0.625rem;
  border-radius: 0.375rem;
  font-size: 0.875rem;
  font-weight: 500;
  line-height: 1.2;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  white-space: nowrap;
}
.pt-public-header__nav .pt-public-header__link, .pt-public-header__nav .pt-public-header__solutions-button {
  text-transform: uppercase;
}
.pt-public-header__link:hover, .pt-public-header__solutions-button:hover {
  color: oklch(100% 0 0);
  background: oklch(100% 0 0 / 10%);
}
.pt-public-header__link.is-active, .pt-public-header__solutions-button.is-active {
  color: oklch(100% 0 0);
  background: oklch(100% 0 0 / 12%);
}
.pt-public-header__actions {
  justify-self: end;
  display: flex;
  align-items: center;
  gap: 0.5rem;
}
.pt-public-header__action-link {
  color: oklch(90% 0.01 255);
  text-decoration: none;
  font-size: 0.875rem;
  font-weight: 500;
  padding: 0.45rem 0.5rem;
}
.pt-public-header__action-link:hover {
  color: oklch(100% 0 0);
}
.pt-public-header__cta {
  text-decoration: none;
  border-radius: 0.4rem;
  padding: 0.52rem 0.78rem;
  font-size: 0.875rem;
  font-weight: 600;
  color: oklch(100% 0 0);
  line-height: 1;
  white-space: nowrap;
}
.pt-public-header__cta--primary {
  background: oklch(56% 0.19 250);
}
.pt-public-header__cta--accent {
  background: oklch(70% 0.16 150);
}
.pt-public-header__cta--primary:hover {
  background: oklch(50% 0.18 250);
}
.pt-public-header__cta--accent:hover {
  background: oklch(64% 0.14 150);
}
.pt-public-header__solutions {
  position: relative;
}
.pt-public-header__solutions-panel {
  position: absolute;
  top: calc(100% + 0.55rem);
  left: 0;
  width: min(40rem, calc(100vw - 2rem));
  background: oklch(100% 0 0);
  color: oklch(30% 0.01 255);
  border: 1px solid oklch(90% 0 0);
  border-radius: 0.6rem;
  box-shadow: 0 14px 36px oklch(0% 0 0 / 20%);
  padding: 1rem;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1rem;
}
.pt-public-header__solutions-heading {
  margin: 0 0 0.5rem;
  color: oklch(45% 0.01 255);
  font-size: 0.75rem;
  font-weight: 700;
  text-transform: uppercase;
}
.pt-public-header__solutions-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: 0.35rem;
}
.pt-public-header__solutions-link {
  display: flex;
  flex-direction: column;
  text-decoration: none;
  border-radius: 0.5rem;
  padding: 0.45rem 0.55rem;
}
.pt-public-header__solutions-link:hover {
  background: oklch(96% 0.01 255);
}
.pt-public-header__solutions-title {
  color: oklch(26% 0.015 255);
  font-size: 0.835rem;
  font-weight: 600;
  line-height: 1.2;
}
.pt-public-header__solutions-text {
  color: oklch(45% 0.01 255);
  font-size: 0.73rem;
  line-height: 1.3;
}
.pt-public-header__mobile-toggle {
  display: none;
  border: 0;
  background: transparent;
  padding: 0.35rem;
  border-radius: 0.35rem;
  justify-self: end;
}
.pt-public-header__mobile-toggle:hover {
  background: oklch(100% 0 0 / 10%);
}
.pt-public-header__mobile-toggle-line {
  display: block;
  width: 1.1rem;
  height: 2px;
  border-radius: 99px;
  background: oklch(95% 0 0);
  margin: 0.2rem 0;
}
@media (max-width: 1024px) {
  .pt-public-header__inner {
    min-height: 4.25rem;
    grid-template-columns: 1fr auto;
  }
  .pt-public-header__mobile-toggle {
    display: inline-flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
  }
  .pt-public-header__menu {
    grid-column: 1 / -1;
    display: none;
    padding: 0 0 1rem;
  }
  .pt-public-header.is-mobile-open .pt-public-header__menu {
    display: grid;
    gap: 0.85rem;
  }
  .pt-public-header__nav {
    justify-self: stretch;
    display: grid;
    gap: 0.2rem;
  }
  .pt-public-header__nav .pt-public-header__link, .pt-public-header__nav .pt-public-header__solutions-button {
    text-transform: none;
  }
  .pt-public-header__actions {
    justify-self: stretch;
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
  .pt-public-header__separator {
    display: none;
  }
  .pt-public-header__cta, .pt-public-header__action-link {
    text-align: center;
    justify-content: center;
    display: inline-flex;
    align-items: center;
    min-height: 2.1rem;
  }
  .pt-public-header__solutions-panel {
    position: static;
    width: 100%;
    margin-top: 0.5rem;
    grid-template-columns: 1fr;
  }
}
.pt-quick-search-shell {
  position: relative;
}
.pt-quick-search__label, .pt-quick-search__live {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}
.pt-quick-search__clear {
  position: absolute;
  top: 50%;
  right: 0.5rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1.75rem;
  height: 1.75rem;
  color: oklch(100% 0 0 / 72%);
  border-radius: var(--radius-full);
  transform: translateY(-50%);
  transition: color 140ms ease, background-color 140ms ease;
}
.pt-quick-search__clear:hover, .pt-quick-search__clear:focus-visible {
  color: var(--color-text-inverse);
  background: oklch(100% 0 0 / 14%);
}
.pt-quick-search__clear:focus-visible {
  outline: 2px solid oklch(100% 0 0 / 86%);
  outline-offset: 2px;
}
.pt-quick-search__clear[hidden] {
  display: none;
}
.pt-quick-search__input {
  padding-right: 2.5rem;
}
.pt-quick-search-lock {
  overflow: hidden;
}
.pt-quick-search-overlay {
  position: fixed;
  inset: 0 0 0 var(--pt-sidebar-width);
  z-index: var(--z-fixed);
  display: block;
  background: var(--color-surface);
  border-left: 1px solid var(--color-border);
}
.pt-sidebar--collapsed .pt-quick-search-overlay {
  left: var(--pt-sidebar-width-collapsed);
}
.pt-quick-search-overlay[hidden] {
  display: none;
}
.pt-quick-search-overlay__panel {
  display: flex;
  flex-direction: column;
  width: 100%;
  height: 100dvh;
  min-width: 0;
  min-height: 0;
  overflow: hidden;
  background: var(--color-surface);
}
.pt-quick-search-overlay__header {
  position: relative;
  z-index: var(--z-sticky);
  flex: 0 0 auto;
  padding: 0.875rem 1.25rem 1rem;
  color: var(--color-text-primary);
  background: linear-gradient( 135deg, var(--color-surface), var(--color-brand-subtle) ), var(--color-surface);
  border-bottom: 1px solid var(--color-border);
}
.pt-quick-search-overlay__header-content {
  width: 100%;
  max-width: none;
  margin: 0;
}
.pt-quick-search-overlay__eyebrow {
  margin: 0 0 0.45rem;
  font-size: 0.7rem;
  font-weight: 750;
  line-height: 1;
  letter-spacing: 0.09em;
  color: var(--color-brand);
  text-transform: uppercase;
}
.pt-quick-search-overlay__search {
  position: relative;
  display: flex;
  align-items: center;
  width: 100%;
  min-width: 0;
}
.pt-quick-search-overlay__search-icon {
  position: absolute;
  top: 50%;
  left: 0.9rem;
  z-index: 1;
  width: 1.35rem;
  height: 1.35rem;
  color: var(--color-brand);
  pointer-events: none;
  transform: translateY(-50%);
}
.pt-quick-search-overlay__input {
  width: 100%;
  height: 3rem;
  min-width: 0;
  padding: 0 3.75rem 0 3rem;
  margin: 0;
  font-size: 1.15rem;
  font-weight: 650;
  line-height: 1.35;
  color: var(--color-text-primary);
  background: var(--color-surface);
  border: 1px solid var(--color-border-strong);
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-card);
  appearance: none;
  outline: none;
  transition: border-color 140ms ease, box-shadow 140ms ease, background-color 140ms ease;
}
.pt-quick-search-overlay__input::placeholder {
  color: var(--color-text-secondary);
  opacity: 0.8;
}
.pt-quick-search-overlay__input:hover {
  border-color: var(--color-brand);
}
.pt-quick-search-overlay__input:focus {
  border-color: var(--color-brand);
  box-shadow: 0 0 0 3px color-mix( in oklch, oklch(45% 0.18 250) 18%, transparent ), var(--shadow-card);
  @supports (color: color-mix(in lab, red, red)) {
    box-shadow: 0 0 0 3px color-mix( in oklch, var(--color-brand) 18%, transparent ), var(--shadow-card);
  }
}
.pt-quick-search-overlay__input::-webkit-search-cancel-button {
  display: none;
}
.pt-quick-search-overlay__close {
  position: absolute;
  top: 50%;
  right: 0.45rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.2rem;
  height: 2.2rem;
  color: var(--color-text-secondary);
  background: transparent;
  border: 0;
  border-radius: var(--radius-lg);
  transform: translateY(-50%);
  transition: color 140ms ease, background-color 140ms ease;
}
.pt-quick-search-overlay__close:hover, .pt-quick-search-overlay__close:focus-visible {
  color: var(--color-text-primary);
  background: var(--color-surface-2);
}
.pt-quick-search-overlay__close:focus-visible {
  outline: 2px solid var(--color-brand);
  outline-offset: 1px;
}
.pt-quick-search-overlay__close-icon {
  width: 1.25rem;
  height: 1.25rem;
}
.pt-quick-search-overlay__body {
  position: relative;
  display: flex;
  flex: 1 1 auto;
  flex-direction: column;
  min-width: 0;
  min-height: 0;
  padding: 0.75rem 1.25rem 1rem;
  overflow-y: auto;
  background: linear-gradient( 180deg, var(--color-surface), var(--color-surface-2) );
}
.pt-quick-search-overlay__body:has(.pt-quick-search-status--empty:not([hidden])), .pt-quick-search-overlay__body:has(.pt-quick-search-status--error:not([hidden])) {
  justify-content: center;
}
.pt-quick-search-results {
  display: grid;
  flex: 0 0 auto;
  align-content: start;
  width: 100%;
  min-width: 0;
  gap: 0.75rem;
}
.pt-quick-search-section {
  display: grid;
  grid-auto-rows: auto;
  align-content: start;
  min-width: 0;
  overflow: hidden;
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-card);
}
.pt-quick-search-section__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  min-height: 1.85rem;
  gap: 1rem;
  padding: 0.4rem 0.85rem;
  background: var(--color-surface-2);
  border-bottom: 1px solid var(--color-border);
}
.pt-quick-search-section__title {
  min-width: 0;
  margin: 0;
  overflow: hidden;
  font-size: 0.72rem;
  font-weight: 650;
  line-height: 1.25;
  letter-spacing: 0.04em;
  color: var(--color-text-secondary);
  text-transform: uppercase;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.pt-quick-search-section__view-all {
  flex: 0 0 auto;
  font-size: 0.78rem;
  font-weight: 600;
  line-height: 1.25;
  color: var(--color-brand);
  text-decoration: none;
}
.pt-quick-search-section__view-all:hover, .pt-quick-search-section__view-all:focus-visible {
  color: var(--color-brand-hover);
  text-decoration: underline;
  text-underline-offset: 0.2em;
}
.pt-quick-search-section__view-all:focus-visible {
  outline: 2px solid var(--color-brand);
  outline-offset: 2px;
  border-radius: var(--radius-sm);
}
.pt-quick-search-result {
  position: relative;
  display: grid;
  grid-template-columns: 2.5rem minmax(0, 1fr);
  gap: 0.75rem;
  align-items: flex-start;
  width: 100%;
  min-width: 0;
  min-height: 3.5rem;
  padding: 0.5rem 0.85rem;
  color: inherit;
  text-decoration: none;
  border-bottom: 1px solid var(--color-border);
  transition: background-color 140ms ease, box-shadow 140ms ease;
}
.pt-quick-search-result:last-child {
  border-bottom: 0;
}
.pt-quick-search-result:hover, .pt-quick-search-result:focus-visible {
  background: var(--color-brand-subtle);
}
.pt-quick-search-result:focus-visible {
  z-index: 1;
  outline: 2px solid var(--color-brand);
  outline-offset: -2px;
}
.pt-quick-search-result__media {
  display: flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 2.5rem;
  width: 2.5rem;
  height: 2.5rem;
  overflow: hidden;
  background: var(--color-surface-3);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
}
.pt-quick-search-result__image {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.pt-quick-search-result[data-quick-search-category="products"] {
  min-height: 4rem;
}
.pt-quick-search-result[data-quick-search-category="products"] .pt-quick-search-result__image {
  object-fit: contain;
}
.pt-quick-search-result[data-quick-search-category="products"] .pt-quick-search-result__title, .pt-quick-search-result[data-quick-search-category="products"] .pt-quick-search-result__meta {
  display: -webkit-box;
  white-space: normal;
  overflow-wrap: anywhere;
  -webkit-box-orient: vertical;
}
.pt-quick-search-result[data-quick-search-category="products"] .pt-quick-search-result__title {
  -webkit-line-clamp: 2;
  line-clamp: 2;
}
.pt-quick-search-result[data-quick-search-category="products"] .pt-quick-search-result__meta {
  -webkit-line-clamp: 2;
  line-clamp: 2;
}
.pt-quick-search-result__placeholder {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
  color: var(--color-text-secondary);
  background: linear-gradient( 135deg, oklch(100% 0 0 / 60%), transparent ), var(--color-surface-3);
}
.pt-quick-search-result__placeholder--company {
  color: var(--color-on-brand);
  background: linear-gradient( 135deg, var(--color-brand), var(--color-brand-light) );
}
.pt-quick-search-result__initial {
  font-size: 0.8rem;
  font-weight: 650;
  line-height: 1;
}
.pt-quick-search-result__placeholder-icon {
  width: 1.15rem;
  height: 1.15rem;
}
.pt-quick-search-result__body {
  min-width: 0;
}
.pt-quick-search-result__title {
  display: block;
  overflow: hidden;
  font-size: 0.875rem;
  font-weight: 600;
  line-height: 1.35;
  color: var(--color-text-primary);
  text-overflow: ellipsis;
  white-space: nowrap;
}
.pt-quick-search-result__title em {
  padding-inline: 0.08rem;
  font-style: normal;
  color: var(--color-text-primary);
  background: color-mix( in oklch, oklch(97% 0.05 80), oklch(70% 0.15 80) 18% );
  @supports (color: color-mix(in lab, red, red)) {
    background: color-mix( in oklch, var(--color-warning-subtle), var(--color-warning) 18% );
  }
  border-radius: 0.18rem;
  box-decoration-break: clone;
}
.pt-quick-search-result__meta {
  display: block;
  margin-top: 0.1rem;
  overflow: hidden;
  font-size: 0.78rem;
  line-height: 1.3;
  color: var(--color-text-secondary);
  text-overflow: ellipsis;
  white-space: nowrap;
}
.pt-quick-search-section__error {
  padding: 1rem;
  font-size: 0.9rem;
  color: var(--color-danger);
  background: var(--color-danger-subtle);
}
.pt-quick-search-status {
  display: grid;
  flex: 1 1 auto;
  place-content: center;
  justify-items: center;
  gap: 0.35rem;
  min-height: 12rem;
  padding: 2rem 1rem;
  text-align: center;
  color: var(--color-text-secondary);
}
.pt-quick-search-status[hidden] {
  display: none;
}
.pt-quick-search-status--loading {
  flex: 0 0 auto;
  min-height: 0;
  padding: 0 1rem 0.65rem;
}
.pt-quick-search-status--loading .pt-quick-search-status__icon {
  display: none;
}
.pt-quick-search-status--loading .pt-quick-search-status__text {
  display: none;
}
.pt-quick-search-status__icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 3rem;
  height: 3rem;
  margin-bottom: 0.35rem;
  color: var(--color-brand);
  background: var(--color-brand-subtle);
  border-radius: var(--radius-xl);
}
.pt-quick-search-status__svg {
  width: 1.5rem;
  height: 1.5rem;
}
.pt-quick-search-status__title {
  margin: 0;
  font-weight: 750;
  color: var(--color-text-primary);
}
.pt-quick-search-status__text {
  max-width: 26rem;
  margin: 0;
  font-size: 0.92rem;
}
.pt-quick-search-skeleton {
  display: grid;
  grid-template-columns: 2.5rem minmax(0, 1fr);
  gap: 0.75rem;
  align-items: center;
  width: 100%;
  min-height: 3.5rem;
  padding: 0.45rem 0.85rem;
  border-bottom: 1px solid var(--color-border);
}
.pt-quick-search-skeleton:last-child {
  border-bottom: 0;
}
.pt-quick-search-skeleton__image, .pt-quick-search-skeleton__line {
  position: relative;
  overflow: hidden;
  background: var(--color-surface-3);
}
.pt-quick-search-skeleton__image::after, .pt-quick-search-skeleton__line::after {
  position: absolute;
  inset: 0;
  content: "";
  background: linear-gradient( 90deg, transparent, oklch(100% 0 0 / 55%), transparent );
  animation: pt-quick-search-shimmer 1.25s ease-in-out infinite;
  transform: translateX(-100%);
}
.pt-quick-search-skeleton__image {
  width: 2.5rem;
  height: 2.5rem;
  border-radius: var(--radius-md);
}
.pt-quick-search-skeleton__body {
  display: grid;
  gap: 0.55rem;
}
.pt-quick-search-skeleton__line {
  height: 0.75rem;
  border-radius: var(--radius-full);
}
.pt-quick-search-skeleton__line--title {
  width: min(22rem, 78%);
}
.pt-quick-search-skeleton__line--meta {
  width: min(30rem, 58%);
}
@keyframes pt-quick-search-shimmer {
  100% {
    transform: translateX(100%);
  }
}
@media (max-width: 48rem) {
  .pt-quick-search-overlay, .pt-sidebar--collapsed .pt-quick-search-overlay {
    left: var(--pt-sidebar-width-collapsed);
  }
  .pt-quick-search-overlay__header {
    padding: 0.75rem 0.75rem 0.85rem;
  }
  .pt-quick-search-overlay__body {
    padding: 0.65rem 0.75rem 1rem;
  }
  .pt-quick-search-overlay__input {
    font-size: 1rem;
  }
  .pt-quick-search-section__header {
    align-items: center;
  }
  .pt-quick-search-section__title {
    font-size: 0.7rem;
    white-space: nowrap;
  }
  .pt-quick-search-section__view-all {
    font-size: 0.76rem;
  }
  .pt-quick-search-result {
    grid-template-columns: 2.25rem minmax(0, 1fr);
    gap: 0.65rem;
    min-height: 3.25rem;
    padding-inline: 0.7rem;
  }
  .pt-quick-search-result__media, .pt-quick-search-skeleton__image {
    width: 2.25rem;
    height: 2.25rem;
  }
  .pt-quick-search-result__title {
    font-size: 0.85rem;
  }
  .pt-quick-search-result__meta {
    font-size: 0.76rem;
    white-space: nowrap;
  }
  .pt-quick-search-skeleton {
    grid-template-columns: 2.25rem minmax(0, 1fr);
    gap: 0.65rem;
    min-height: 3.25rem;
    padding-inline: 0.7rem;
  }
}
@media (prefers-reduced-motion: reduce) {
  .pt-quick-search__clear, .pt-quick-search-overlay__input, .pt-quick-search-overlay__close, .pt-quick-search-result {
    transition: none;
  }
  .pt-quick-search-skeleton__image::after, .pt-quick-search-skeleton__line::after {
    animation: none;
  }
}
.pt-saved-searches {
  display: block;
  padding: 0.5rem;
  border-bottom: 1px solid var(--color-border);
  background: var(--color-surface);
}
.pt-saved-searches .pt-dropdown, .pt-saved-searches .pt-dropdown__trigger {
  display: block;
}
.pt-saved-searches__trigger {
  width: 100%;
  justify-content: space-between;
  overflow: hidden;
  min-width: 0;
}
.pt-saved-searches__trigger .pt-btn__label {
  flex: 1;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  text-align: left;
}
.pt-saved-searches .pt-dropdown__menu {
  width: 100%;
  left: 0;
  right: auto;
  max-height: 22rem;
  overflow-y: auto;
}
.pt-saved-searches__list {
  list-style: none;
  margin: 0;
  padding: 0.25rem 0;
}
.pt-saved-searches__item {
  display: flex;
  align-items: center;
  gap: 0.25rem;
  padding: 0;
  min-width: 0;
}
.pt-saved-searches__item--active > .pt-saved-searches__link {
  background: var(--color-brand-subtle);
  color: var(--color-brand);
  font-weight: 600;
}
.pt-saved-searches__link {
  flex: 1;
  min-width: 0;
  display: flex;
  align-items: center;
  gap: 0.4rem;
  padding: 0.5rem 0.75rem;
  color: var(--color-text);
  font-size: 0.875rem;
  text-decoration: none;
  border-radius: var(--radius-sm);
  cursor: pointer;
  overflow: hidden;
}
.pt-saved-searches__link:hover {
  background: var(--color-surface-alt);
}
.pt-saved-searches__icon {
  flex-shrink: 0;
  color: var(--color-muted);
}
.pt-saved-searches__item--active > .pt-saved-searches__link .pt-saved-searches__icon {
  color: inherit;
}
.pt-saved-searches__label, .pt-saved-searches__name {
  flex: 1;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.pt-saved-searches__meta {
  color: var(--color-muted);
  font-size: 0.8125rem;
  flex-shrink: 0;
}
.pt-saved-searches__badge {
  font-size: 0.65rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  padding: 0.1rem 0.35rem;
  border-radius: var(--radius-full);
  background: var(--color-brand-subtle);
  color: var(--color-brand-hover);
  flex-shrink: 0;
}
.pt-saved-searches__divider {
  height: 1px;
  margin: 0.25rem 0;
  background: var(--color-border);
  list-style: none;
  font-size: 0;
  line-height: 1px;
  padding: 0;
}
.pt-saved-searches__edit {
  margin-right: 0.625rem;
  padding: 0.25rem 0.5rem;
  font-size: 0.75rem;
  color: var(--color-brand);
  text-decoration: none;
  border-radius: var(--radius-sm);
  flex-shrink: 0;
}
.pt-saved-searches__edit:hover {
  background: var(--color-brand-subtle);
  text-decoration: none;
}
#ng-login-modal .pt-modal__header {
  border-bottom: none;
}
#ng-login-modal .pt-modal__body {
  display: flex;
  justify-content: center;
}
#ng-login-modal .pt-auth-form-card {
  width: 100%;
  max-width: 22rem;
  text-align: center;
}
#ng-login-modal .pt-auth-form__field, #ng-login-modal .pt-auth-form__field-header, #ng-login-modal .pt-auth-form-footer {
  text-align: left;
}
.pt-saved-search-form-wrapper {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}
.pt-saved-search-form__intro {
  margin: 0;
  color: var(--color-text-secondary);
  font-size: 0.8125rem;
  line-height: 1.4;
}
.pt-saved-search-form {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}
.pt-saved-search-form__field {
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
}
.pt-saved-search-form__field .pt-input, .pt-saved-search-form__field .pt-select__input {
  width: 100%;
}
.pt-saved-search-form__actions {
  display: flex;
  justify-content: flex-end;
  align-items: center;
  gap: 0.5rem;
  margin-top: 0.5rem;
  padding-top: 0.75rem;
  border-top: 1px solid var(--color-border);
}
.pt-saved-search-form__actions > .pt-btn--danger:first-child {
  margin-right: auto;
}
.pt-saved-search-form__actions .pt-btn {
  padding: 0.375rem 0.875rem;
  font-size: 0.8125rem;
  border-radius: 0.375rem;
  font-weight: 500;
  transition: background-color 120ms ease;
}
.pt-saved-search-form__actions .pt-btn--primary:hover {
  background: var(--color-success-hover);
  color: var(--color-surface);
}
.pt-saved-search-form__visibility-trigger {
  width: 100%;
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  justify-content: flex-start;
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  color: var(--color-text);
  padding: 0.5rem 0.75rem;
  font-size: 0.875rem;
  font-weight: 400;
  cursor: pointer;
  transition: border-color 150ms ease, box-shadow 150ms ease;
}
.pt-saved-search-form__visibility-trigger:hover {
  border-color: var(--color-border-strong);
}
.pt-saved-search-form__visibility-trigger:focus-visible, .pt-dropdown[data-open="true"] .pt-saved-search-form__visibility-trigger {
  outline: none;
  border-color: var(--color-brand);
  box-shadow: 0 0 0 3px color-mix(in srgb, oklch(45% 0.18 250) 12%, transparent);
  @supports (color: color-mix(in lab, red, red)) {
    box-shadow: 0 0 0 3px color-mix(in oklch, var(--color-brand) 12%, transparent);
  }
}
.pt-saved-search-form__visibility-trigger .pt-saved-search-form__visibility-icon, .pt-saved-search-form__visibility-option .pt-icon-wrap, .pt-saved-search-form__visibility-option .pt-icon {
  flex-shrink: 0;
}
.pt-saved-search-form__visibility-trigger .pt-saved-search-form__visibility-label {
  flex: 1;
  text-align: left;
}
.pt-saved-search-form__visibility-trigger .pt-saved-search-form__visibility-chevron {
  flex-shrink: 0;
  margin-left: auto;
}
.pt-saved-search-form__visibility-menu {
  list-style: none;
  margin: 0;
  padding: 0.25rem 0;
  width: 100%;
  min-width: 14rem;
}
.pt-saved-search-form__visibility-option {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  width: 100%;
  border: none;
  background: none;
  padding: 0.5rem 0.75rem;
  color: var(--color-text);
  font-size: 0.875rem;
  text-align: left;
  cursor: pointer;
}
.pt-saved-search-form__visibility-option:hover {
  background: var(--color-surface-alt);
}
.pt-saved-search-form .pt-dropdown {
  display: block;
  width: 100%;
}
.pt-saved-search-form .pt-dropdown__menu {
  width: 100%;
  left: 0;
  right: auto;
  top: auto;
  bottom: calc(100% + 0.375rem);
}
.pt-saved-search-form .pt-dropdown[data-open="true"] .pt-saved-search-form__visibility-chevron {
  transform: rotate(180deg);
}
.pt-starters-gallery__grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(18rem, 1fr));
  gap: 1rem;
  align-items: stretch;
}
.pt-starters-gallery__grid .pt-card {
  display: flex;
  flex-direction: column;
}
.pt-starters-gallery__grid .pt-card__body {
  flex: 1 1 auto;
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}
.pt-starters-gallery__description {
  margin: 0;
  font-size: var(--text-sm);
  line-height: 1.45;
  color: var(--color-text-secondary);
}
.pt-starters-gallery__preview {
  font-size: var(--text-sm);
  color: var(--color-text-muted);
}
.pt-starters-gallery__grid .pt-card__footer {
  justify-content: stretch;
}
.pt-starters-gallery__grid .pt-card__footer form {
  width: 100%;
  margin: 0;
}
.pt-starters-gallery__grid .pt-card__footer .pt-btn {
  width: 100%;
  justify-content: center;
}
.pt-starters-gallery__grid .pt-card:has(.pt-starters-gallery__blank) {
  border-style: dashed;
  border-color: var(--color-border-strong);
  background: transparent;
  box-shadow: none;
}
.pt-starters-gallery__grid .pt-card:has(.pt-starters-gallery__blank):hover {
  border-color: var(--color-brand);
  background: var(--color-brand-subtle);
  box-shadow: none;
}
.pt-starters-gallery__blank {
  flex: 1 1 auto;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  min-height: 9rem;
  text-align: center;
  color: var(--color-text-secondary);
}
.pt-starters-gallery__grid .pt-card:has(.pt-starters-gallery__blank):hover .pt-starters-gallery__blank {
  color: var(--color-brand);
}
.pt-starters-gallery__blank-label {
  font-size: var(--text-base);
  font-weight: 600;
}
.pt-starters-gallery__blank-hint {
  font-size: var(--text-sm);
  color: var(--color-text-muted);
}
.pt-starters-gallery__choice {
  display: flex;
  margin: 0;
  cursor: pointer;
}
.pt-starters-gallery__choice .pt-card {
  flex: 1 1 auto;
}
.pt-starters-gallery__radio {
  position: absolute;
  width: 1px;
  height: 1px;
  overflow: hidden;
  clip: rect(0 0 0 0);
  clip-path: inset(50%);
  opacity: 0;
  pointer-events: none;
}
.pt-starters-gallery__choice:has(.pt-starters-gallery__radio:checked) .pt-card {
  border-color: var(--color-brand);
  box-shadow: 0 0 0 2px var(--color-brand-subtle);
}
.pt-starters-gallery__choice:has(.pt-starters-gallery__radio:focus-visible) .pt-card {
  outline: 2px solid var(--color-brand);
  outline-offset: 2px;
}
.pt-tender-card {
  position: relative;
  display: flex;
  flex-direction: row;
  align-items: stretch;
  min-width: 0;
  overflow: hidden;
  background: var(--color-surface, white);
  border-radius: 0.25rem;
  border: 1px solid oklch(91% 0 0);
  box-shadow: 0 0.25rem 0.75rem oklch(20% 0 0 / 6%);
  transition: transform 120ms ease-out, box-shadow 120ms ease-out, border-color 120ms ease-out;
  &:hover {
    border-color: oklch(82% 0 0);
    box-shadow: 0 0.45rem 1rem oklch(20% 0 0 / 12%);
    transform: translateY(-1px);
  }
}
.pt-tender-card__status-bar {
  flex: 0 0 1.625rem;
  width: 1.625rem;
  display: flex;
  align-items: center;
  justify-content: center;
  background: oklch(70% 0 0);
  overflow: hidden;
  flex-shrink: 0;
}
.pt-tender-card__status-label {
  writing-mode: vertical-rl;
  transform: rotate(180deg);
  font-size: 0.7rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: #fff;
  white-space: nowrap;
  user-select: none;
}
.pt-tender-card[data-tender-state="draft"] .pt-tender-card__status-bar {
  background: #647079;
}
.pt-tender-card[data-tender-state="pending"] .pt-tender-card__status-bar {
  background: #fe9038;
}
.pt-tender-card[data-tender-state="posted"] .pt-tender-card__status-bar {
  background: #305f82;
}
.pt-tender-card[data-tender-state="opened"] .pt-tender-card__status-bar {
  background: #fe9038;
}
.pt-tender-card[data-tender-state="on_hold"] .pt-tender-card__status-bar {
  background: #795f9c;
}
.pt-tender-card[data-tender-state="awarded"] .pt-tender-card__status-bar {
  background: #22b68e;
}
.pt-tender-card[data-tender-state="no_awarded"] .pt-tender-card__status-bar {
  background: #ee5b4e;
}
.pt-tender-card__media {
  flex: 0 0 13rem;
  max-width: 13rem;
  min-height: 10.5rem;
  overflow: hidden;
  background: oklch(94% 0 0);
}
.pt-tender-card__photo {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 300ms ease;
  .pt-tender-card:hover & {
    transform: scale(1.03);
  }
}
.pt-tender-card__photo-placeholder {
  width: 100%;
  height: 100%;
  min-height: 10.5rem;
  display: flex;
  align-items: center;
  justify-content: center;
  color: oklch(70% 0 0);
  svg {
    width: 2.5rem;
    height: 2.5rem;
  }
}
.pt-tender-card__content {
  display: flex;
  flex-direction: column;
  flex: 1 1 auto;
  min-width: 0;
}
.pt-tender-card__body {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 0.35rem;
  padding: 0.875rem 1.125rem 0.5rem;
}
.pt-tender-card__top {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 0.75rem;
}
.pt-tender-card__name-link {
  font-size: 1rem;
  font-weight: 700;
  color: oklch(18% 0 0);
  text-decoration: none;
  line-height: 1.35;
  flex: 1;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  &:hover {
    color: oklch(35% 0.18 250);
  }
  mark {
    background: oklch(94% 0.12 90);
    color: inherit;
    border-radius: 2px;
    padding: 0 1px;
  }
}
.pt-tender-card__project {
  display: flex;
  align-items: center;
  gap: 0.3rem;
  font-size: 0.8125rem;
  color: oklch(50% 0 0);
  margin: 0;
}
.pt-tender-card__project-link {
  position: relative;
  z-index: 1;
  color: var(--color-brand, oklch(50% 0.18 250));
  text-decoration: none;
  &:hover {
    text-decoration: underline;
  }
}
.pt-tender-card__footer {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.25rem 0;
  padding: 0.375rem 1.125rem 0.75rem;
  font-size: 0.8125rem;
  color: oklch(45% 0 0);
}
.pt-tender-card__meta {
  display: inline-flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 0;
  font-size: 0.8125rem;
  color: oklch(45% 0 0);
}
.pt-tender-card__meta-item {
  display: inline-flex;
  align-items: center;
  font-size: 0.8125rem;
  white-space: nowrap;
  & + .pt-tender-card__meta-item::before {
    content: "|";
    margin: 0 0.45rem;
    color: oklch(82% 0 0);
  }
}
.pt-tender-card__bids-link {
  color: var(--color-brand, #3196d1);
  text-decoration: none;
  font-size: 0.8125rem;
  font-weight: 500;
  margin-right: 0.2rem;
  &:hover {
    text-decoration: underline;
  }
}
.pt-tender-card__bids-nums {
  display: inline-flex;
  align-items: center;
  gap: 0.15rem;
  font-size: 0.8125rem;
  font-variant-numeric: tabular-nums;
}
.pt-tender-card__bids-submitted {
  color: #22b68e;
  font-weight: 600;
}
.pt-tender-card__bids-sep {
  color: oklch(78% 0 0);
  font-weight: 400;
}
.pt-tender-card__rfc-label {
  font-size: 0.8125rem;
  margin-right: 0.2rem;
}
.pt-tender-card__rfc-nums {
  display: inline-flex;
  align-items: center;
  gap: 0.15rem;
  font-size: 0.8125rem;
  font-variant-numeric: tabular-nums;
}
.pt-tender-card__rfc-closed {
  color: #22b68e;
}
.pt-tender-card__date-label {
  font-size: 0.8125rem;
  color: oklch(55% 0 0);
  margin-right: 0.25rem;
}
.pt-tender-card__rfc-closed--warn {
  color: #ee5b4e;
  font-weight: 600;
}
.pt-tender-card__meta-item .pt-tender-card__meta-icon {
  width: 0.75rem;
  height: 0.75rem;
  flex-shrink: 0;
  color: oklch(60% 0 0);
  margin-right: 0.2rem;
}
.pt-tender-card__name-link::after {
  content: "";
  position: absolute;
  inset: 0;
}
.pt-tender-card--docs-updated {
  border-color: oklch(72% 0.18 72);
}
.pt-tender-card__meta-icon {
  width: 0.75rem;
  height: 0.75rem;
  flex-shrink: 0;
}
.pt-tender-card__docset {
  display: flex;
  align-items: center;
  gap: 0.4rem;
  font-size: 0.8125rem;
  color: oklch(45% 0 0);
  flex-wrap: wrap;
}
.pt-tender-card__docset-label {
  color: oklch(55% 0 0);
}
.pt-tender-card__docset-version {
  font-weight: 500;
  color: oklch(40% 0 0);
}
.pt-tender-card__reviews {
  display: flex;
  align-items: center;
  gap: 0.4rem;
  font-size: 0.8125rem;
  flex-wrap: wrap;
}
.pt-tender-card__reviews-label {
  color: oklch(55% 0 0);
}
.pt-tender-card__review-item {
  padding: 0.125rem 0.4rem;
  border-radius: 0.2rem;
  font-size: 0.75rem;
  font-weight: 500;
}
.pt-tender-card__review-item--pending {
  background: oklch(96% 0.06 72);
  color: oklch(52% 0.18 72);
}
.pt-tender-card__review-item--ongoing {
  background: oklch(94% 0.06 250);
  color: oklch(42% 0.18 250);
}
.pt-tender-card__review-item--completed {
  background: oklch(94% 0.1 145);
  color: oklch(38% 0.16 145);
}
.pt-tender-card__meta-spacer {
  flex: 1;
}
.pt-tender-card__actions {
  display: flex;
  align-items: center;
  gap: 0.3rem;
  position: relative;
  z-index: 1;
  flex-shrink: 0;
}
.pt-tender-card__docs-warn-icon {
  display: inline-flex;
  align-items: center;
  cursor: help;
}
.pt-tender-card__docs-warn-svg {
  width: 1.125rem;
  height: 1.125rem;
  color: oklch(65% 0.2 55);
}
.pt-tenders-page .pt-tender-card__media {
  flex: 0 0 10.5rem;
  max-width: 10.5rem;
  min-height: 8.5rem;
}
.pt-tenders-page .pt-tender-card__photo-placeholder {
  min-height: 8.5rem;
}
.pt-tenders-page .pt-tender-card__body {
  padding: 0.625rem 0.875rem 0.375rem;
  gap: 0.25rem;
}
.pt-tenders-page .pt-tender-card__footer {
  padding: 0.25rem 0.875rem 0.625rem;
}
.pt-tenders-page .pt-tender-card__name-link {
  font-size: 0.9375rem;
}
.pt-tender-card__top-actions {
  display: flex;
  align-items: center;
  gap: 0.25rem;
  position: relative;
  z-index: 1;
  flex-shrink: 0;
}
.pt-tender-card__top-actions .pt-btn {
  width: 2rem;
  height: 2rem;
  padding: 0;
  flex-shrink: 0;
}
.pt-tender-card__icon-wrap {
  flex-shrink: 0;
  width: 2.75rem;
  height: 2.75rem;
  border-radius: var(--radius-sm, 0.25rem);
  background: var(--color-purple-subtle);
  display: flex;
  align-items: center;
  justify-content: center;
}
.pt-tender-card__icon {
  width: 1.375rem;
  height: 1.375rem;
  color: var(--color-purple-hover);
}
.pt-phase-content {
  flex: 1;
}
.pt-phase-tab__icon {
  width: 1rem;
  height: 1rem;
}
.pt-tender-form {
  display: flex;
  flex-direction: column;
  gap: 0;
  max-width: 60rem;
  margin-inline: auto;
  background: var(--color-surface, white);
  border: 1px solid oklch(91% 0 0);
  border-radius: 0.375rem;
  overflow: hidden;
}
.pt-tender-form__header {
  padding: 1rem 2rem;
  background: oklch(97.5% 0 0);
  border-bottom: 1px solid oklch(91% 0 0);
}
.pt-tender-form__header-title {
  font-size: 1rem;
  font-weight: 700;
  color: oklch(18% 0 0);
  margin: 0;
}
.pt-tender-form__section {
  padding: 1.75rem 2rem;
  border-bottom: 1px solid oklch(93% 0 0);
  display: flex;
  flex-direction: column;
  gap: 1.25rem;
  &:last-of-type {
    border-bottom: none;
  }
}
.pt-tender-form__section-title {
  font-size: 1.0625rem;
  font-weight: 700;
  color: oklch(18% 0 0);
  margin: 0;
  padding-bottom: 0.625rem;
  border-bottom: 1px solid oklch(91% 0 0);
}
.pt-tender-form__field-group {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}
.pt-tender-form__field-group-label {
  font-size: 0.75rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: oklch(45% 0 0);
  margin: 0;
  padding-bottom: 0.5rem;
  border-bottom: 1px solid oklch(91% 0 0);
}
.pt-tender-form .pt-form-group--inline > .pt-label {
  width: 12rem;
  min-width: 0;
  flex-shrink: 0;
}
.pt-tender-form__date-range-inputs {
  display: flex;
  align-items: flex-start;
  gap: 0.75rem;
  width: 100%;
}
.pt-tender-form__date-range-inputs .pt-date-picker {
  flex: 1 1 0;
  min-width: 0;
}
.pt-tender-form__date-separator {
  font-size: 0.875rem;
  color: oklch(50% 0 0);
  white-space: nowrap;
  flex-shrink: 0;
  padding-top: 0.5625rem;
}
.pt-tender-form__reference {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}
.pt-tender-form__reference-option {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  flex-wrap: wrap;
  .pt-radio {
    flex-shrink: 0;
  }
}
.pt-tender-form__area-input {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  max-width: 16rem;
}
.pt-tender-form__area-input .pt-input {
  flex: 1;
  min-width: 0;
}
.pt-tender-form__rule-row {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  flex-wrap: wrap;
  min-height: 2.25rem;
}
.pt-tender-form__rule-text {
  font-size: 0.9375rem;
  color: oklch(20% 0 0);
}
.pt-tender-form__rule-value {
  font-size: 0.9375rem;
  font-weight: 600;
  color: oklch(20% 0 0);
}
.pt-tender-form__checkboxes {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  margin-top: 0.25rem;
}
.pt-tender-form__fee-types {
  display: flex;
  flex-direction: column;
  gap: 0.625rem;
}
.pt-tender-form__fee-type-row {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  flex-wrap: wrap;
}
.pt-tender-form__fee-breakdown {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  max-width: 28rem;
}
.pt-tender-form__fee-row {
  display: flex;
  align-items: center;
  gap: 0.75rem;
}
.pt-tender-form__fee-row .pt-label {
  white-space: nowrap;
  flex-shrink: 0;
}
.pt-tender-form__fee-summary {
  padding-top: 0.5rem;
}
.pt-tender-form__fee-table {
  border-collapse: collapse;
  font-size: 0.9375rem;
  width: 100%;
  max-width: 22rem;
  td {
    padding: 0.25rem 0.75rem 0.25rem 0;
    vertical-align: middle;
    color: oklch(30% 0 0);
    &:first-child {
      width: 10rem;
    }
    &:last-child {
      font-variant-numeric: tabular-nums;
    }
  }
  tfoot td {
    font-weight: 700;
    border-top: 1px solid oklch(90% 0 0);
    padding-top: 0.5rem;
    color: oklch(18% 0 0);
  }
}
.pt-tender-form .pt-date-picker {
  max-width: 16rem;
}
.pt-tender-form__currency-group {
  max-width: 30rem;
}
.pt-tender-form__area-input .pt-select {
  min-width: 6rem;
}
.pt-tender-form__breakdown[hidden], .pt-tender-form__collection[hidden] {
  display: none;
}
.pt-tender-form__collection .pt-form-group {
  max-width: none;
}
.pt-tender-form__actions {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 0.75rem;
  padding: 1.25rem 2rem;
  background: oklch(97.5% 0 0);
  border-top: 1px solid oklch(91% 0 0);
}
.pt-vendor-grade-panel__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--pt-space-3, 0.75rem);
  width: 100%;
}
.pt-vendor-grade-panel__heading {
  display: flex;
  align-items: center;
  gap: var(--pt-space-2, 0.5rem);
}
.pt-vendor-grade-panel__header-icon {
  color: var(--pt-color-brand, #2563eb);
  width: 1.25rem;
  height: 1.25rem;
}
.pt-vendor-grade-panel__title {
  font-size: var(--pt-font-size-base, 1rem);
  font-weight: 600;
  color: var(--pt-color-text, #111827);
  margin: 0;
}
.pt-vendor-grade-panel__body {
  display: flex;
  flex-direction: column;
  gap: var(--pt-space-4, 1rem);
}
.pt-vendor-grade-panel__score {
  display: flex;
  flex-direction: column;
  gap: var(--pt-space-2, 0.5rem);
}
.pt-vendor-grade-panel__score-label {
  font-size: var(--pt-font-size-sm, 0.875rem);
  font-weight: 600;
  color: var(--pt-color-text, #111827);
}
.pt-vendor-grade-panel__sections {
  display: flex;
  flex-direction: column;
}
.pt-vendor-grade-panel__actions {
  display: flex;
  justify-content: flex-end;
  margin-top: var(--pt-space-4, 1rem);
  padding-top: var(--pt-space-4, 1rem);
  border-top: 1px solid var(--pt-color-border, #e5e7eb);
}
.pt-vendor-grade-panel__error {
  display: flex;
  align-items: center;
  gap: var(--pt-space-2, 0.5rem);
  padding: var(--pt-space-3, 0.75rem);
  border-radius: var(--pt-radius-md, 0.375rem);
  background: var(--pt-color-danger-subtle, #fef2f2);
  color: var(--pt-color-danger, #b91c1c);
  font-size: var(--pt-font-size-sm, 0.875rem);
}
.pt-vendor-grade-panel__error-icon {
  flex: 0 0 auto;
  color: var(--pt-color-danger, #b91c1c);
}
.pt-company-hits--list .pt-company-grid {
  grid-template-columns: 1fr;
  gap: 0.85rem;
}
.pt-company-hits--list .pt-company-card {
  display: grid;
  grid-template-columns: 10.5rem minmax(0, 1fr);
  grid-template-areas: "header body" "header footer";
  min-height: 10.5rem;
  height: auto;
  overflow: visible;
  transform: none;
  &:hover, &.pt-company-card--menu-open {
    transform: none;
  }
}
.pt-company-hits--list .pt-company-card__header {
  position: static;
  grid-area: header;
  display: block;
  min-height: 10.5rem;
  height: 100%;
  padding: 0;
  border-right: 1px solid oklch(91% 0 0);
}
.pt-company-hits--list .pt-company-card__logo-link {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
}
.pt-company-hits--list .pt-company-card__logo {
  width: 100%;
  height: 100%;
  min-height: 10.5rem;
  border: none;
  border-radius: 1rem 0 0 1rem;
  background: oklch(99% 0 0);
  img {
    max-width: 70%;
    max-height: 70%;
  }
}
.pt-company-hits--list .pt-company-card__actions {
  position: absolute;
  top: 0.85rem;
  right: 1rem;
  left: auto;
  z-index: 30;
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: 0.35rem;
}
.pt-company-hits--list .pt-company-card__dropdown {
  top: calc(100% + 0.55rem);
  right: 0;
  left: auto;
}
.pt-company-hits--list .pt-company-card__dropdown::before {
  top: -0.5rem;
  right: 1.25rem;
  left: auto;
  border-left: 1px solid oklch(82% 0 0);
  border-top: 1px solid oklch(82% 0 0);
  border-right: none;
  border-bottom: none;
  transform: rotate(45deg);
}
.pt-company-hits--list .pt-company-card__body {
  grid-area: body;
  display: grid;
  grid-template-columns: minmax(12rem, 1fr) minmax(16rem, 1fr);
  grid-template-areas: "main activities";
  align-items: start;
  column-gap: 1.25rem;
  row-gap: 0.45rem;
  min-width: 0;
  padding: 1rem 8rem 0.5rem 1rem;
}
.pt-company-hits--list .pt-company-card__name {
  grid-area: main;
  align-self: start;
  font-size: 0.95rem;
  line-height: 1.25;
}
.pt-company-hits--list .pt-company-card__name-link {
  -webkit-line-clamp: 2;
}
.pt-company-hits--list .pt-company-card__location {
  grid-area: main;
  align-self: start;
  margin-top: 2.1rem;
  min-width: 0;
}
.pt-company-hits--list .pt-company-card__stats {
  grid-area: main;
  align-self: start;
  margin-top: 4.05rem;
}
.pt-company-hits--list .pt-company-card__activities {
  grid-area: activities;
  justify-content: center;
  align-content: flex-start;
  justify-self: center;
  max-width: 100%;
  max-height: 3.25rem;
  overflow: hidden;
  padding-top: 0.1rem;
}
.pt-company-hits--list .pt-company-card__footer {
  grid-area: footer;
  align-self: end;
  justify-self: end;
  width: 22rem;
  margin: 0 1rem 1rem 0;
  border-top: none;
  background: transparent;
  border-radius: 0;
}
.pt-company-hits--list .pt-company-card__project-strip {
  display: grid;
  grid-template-columns: repeat(6, 3rem);
  justify-content: end;
  gap: 0.4rem;
  padding: 0;
}
.pt-company-hits--list .pt-project-thumb {
  width: 3rem;
  height: 3rem;
  aspect-ratio: auto;
  border-radius: 0.45rem;
}
.pt-company-hits--list .pt-project-thumb--count {
  font-size: 0.8rem;
}
.pt-company-hits--list .pt-company-card__no-projects {
  padding: 0;
  background: transparent;
  border-top: none;
  text-align: right;
}
.pt-company-hits--table .pt-company-grid {
  grid-template-columns: 1fr;
  gap: 0;
  border: 1px solid oklch(91% 0 0);
  border-radius: 0.5rem;
  overflow: visible;
}
.pt-company-hits--table .pt-company-grid__item:first-child .pt-company-card {
  border-top: none;
}
.pt-company-hits--table .pt-company-card {
  display: grid;
  grid-template-columns: 3.5rem minmax(0, 1fr) auto;
  min-height: 4rem;
  height: auto;
  border-radius: 0;
  border: none;
  border-top: 1px solid oklch(93% 0 0);
  box-shadow: none;
  overflow: visible;
  &:hover, &.pt-company-card--menu-open {
    transform: none;
    box-shadow: none;
    background: oklch(98% 0 0);
  }
}
.pt-company-hits--table .pt-company-card__header {
  padding: 0.55rem;
}
.pt-company-hits--table .pt-company-card__logo {
  width: 2.45rem;
  height: 2.45rem;
  border-radius: 0.35rem;
}
.pt-company-hits--table .pt-company-card__actions {
  position: absolute;
  top: 0.65rem;
  right: 0.75rem;
  left: auto;
  z-index: 30;
  flex-direction: row;
}
.pt-company-hits--table .pt-company-card__dropdown {
  top: calc(100% + 0.55rem);
  right: 0;
  left: auto;
}
.pt-company-hits--table .pt-company-card__dropdown::before {
  top: -0.5rem;
  right: 1.25rem;
  left: auto;
  border-left: 1px solid oklch(82% 0 0);
  border-top: 1px solid oklch(82% 0 0);
  border-right: none;
  border-bottom: none;
  transform: rotate(45deg);
}
.pt-company-hits--table .pt-company-card__body {
  display: grid;
  grid-template-columns: minmax(12rem, 2fr) minmax(9rem, 1fr) minmax(10rem, 1.5fr) minmax(7rem, 1fr);
  align-items: center;
  gap: 0.75rem;
  padding: 0.6rem 7rem 0.6rem 0.25rem;
}
.pt-company-hits--table .pt-company-card__name {
  font-size: 0.85rem;
}
.pt-company-hits--table .pt-company-card__name-link {
  -webkit-line-clamp: 1;
}
.pt-company-hits--table .pt-company-card__location {
  font-size: 0.78rem;
}
.pt-company-hits--table .pt-company-card__activities {
  flex-wrap: nowrap;
  overflow: hidden;
  max-height: 1.8rem;
}
.pt-company-hits--table .pt-activity-chip {
  max-width: 8rem;
  font-size: 0.7rem;
}
.pt-company-hits--table .pt-company-card__stats {
  flex-wrap: nowrap;
  overflow: hidden;
  margin-top: 0;
}
.pt-company-hits--table .pt-stat-pill {
  font-size: 0.7rem;
  padding: 0.15rem 0.45rem;
}
.pt-company-hits--table .pt-company-card__footer {
  display: none;
}
@media (max-width: 1100px) {
  .pt-company-hits--list .pt-company-card {
    display: flex;
    flex-direction: column;
    min-height: 30rem;
  }
  .pt-company-hits--list .pt-company-card__header {
    position: relative;
    display: flex;
    min-height: 12.75rem;
    height: auto;
    padding: 1.25rem 1.25rem 0;
    border-right: none;
  }
  .pt-company-hits--list .pt-company-card__logo-link {
    width: auto;
    height: auto;
  }
  .pt-company-hits--list .pt-company-card__logo {
    width: 9.75rem;
    height: 9.75rem;
    min-height: 0;
    border: 1px solid oklch(88% 0 0);
    border-radius: 1rem;
    img {
      max-width: 82%;
      max-height: 82%;
    }
  }
  .pt-company-hits--list .pt-company-card__actions {
    position: absolute;
    top: 1.25rem;
    right: 1.25rem;
    left: auto;
    flex-direction: row;
  }
  .pt-company-hits--list .pt-company-card__body {
    display: flex;
    flex-direction: column;
    padding: 0.25rem 1rem 1rem;
  }
  .pt-company-hits--list .pt-company-card__location, .pt-company-hits--list .pt-company-card__stats {
    margin-top: 0;
  }
  .pt-company-hits--list .pt-company-card__activities {
    justify-content: flex-start;
    justify-self: auto;
    padding-top: 0;
  }
  .pt-company-hits--list .pt-company-card__footer {
    width: auto;
    margin: 0;
    border-top: 1px solid oklch(91% 0 0);
    background: oklch(98% 0 0);
  }
  .pt-company-hits--list .pt-company-card__project-strip {
    grid-template-columns: repeat(6, minmax(0, 1fr));
    padding: 0.85rem 1rem 1rem;
  }
  .pt-company-hits--list .pt-project-thumb {
    width: auto;
    height: auto;
    aspect-ratio: 1 / 1;
  }
}
.pt-form-layout {
  display: flex;
  flex-direction: column;
  gap: 2rem;
  max-width: 64rem;
}
.pt-form-layout__header {
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
  h2 {
    font-size: 1.25rem;
    font-weight: 600;
    color: oklch(15% 0 0);
    margin: 0;
  }
  p {
    font-size: 0.875rem;
    color: oklch(45% 0 0);
    margin: 0;
  }
}
.pt-form-layout__section {
  border: none;
  padding: 0;
  margin: 0;
}
.pt-form-layout__section-title {
  font-size: 0.9375rem;
  font-weight: 600;
  color: oklch(20% 0 0);
  margin-bottom: 1rem;
  padding-bottom: 0.5rem;
  border-bottom: 1px solid oklch(90% 0 0);
}
.pt-form-layout__grid {
  display: grid;
  gap: 1rem 1.5rem;
}
.pt-form-layout__grid--cols-1 {
  grid-template-columns: 1fr;
}
.pt-form-layout__grid--cols-2 {
  grid-template-columns: repeat(2, 1fr);
}
.pt-form-layout__grid--cols-3 {
  grid-template-columns: repeat(3, 1fr);
}
@media (width <= 48rem) {
  .pt-form-layout__grid--cols-2, .pt-form-layout__grid--cols-3 {
    grid-template-columns: 1fr;
  }
}
.pt-form-layout__actions {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  padding-top: 1.5rem;
  border-top: 1px solid oklch(90% 0 0);
}
.pt-phase-detail {
  max-width: 100%;
  container-type: inline-size;
  container-name: phase;
}
.pt-phase-shell {
  display: block;
}
.pt-phase-shell--with-rail {
  display: flex;
  align-items: stretch;
  gap: 1.25rem;
}
.pt-phase-main {
  flex: 1;
  min-width: 0;
}
.pt-phase-rail, .pt-tender-rail {
  flex: 0 0 auto;
  display: flex;
  position: sticky;
  top: 0;
  align-self: flex-start;
  height: 100vh;
  min-height: 100vh;
  margin: -1.5rem -1.5rem -1.5rem 0;
}
.pt-phase-rail .pt-context-sidebar, .pt-tender-rail .pt-context-sidebar {
  height: 100%;
  min-height: 0;
}
.pt-phase-detail .pt-card {
  border-radius: 0.25rem;
}
.pt-phase-header {
  margin-bottom: 1.5rem;
}
.pt-phase-header__top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 0.75rem;
}
.pt-phase-header__back {
  display: inline-flex;
  align-items: center;
  gap: 0.375rem;
  font-size: 0.8125rem;
  font-weight: 500;
  color: var(--pt-text-secondary, var(--color-text-secondary));
  text-decoration: none;
  transition: color 0.15s ease;
}
.pt-phase-header__back:hover {
  color: var(--pt-text-primary, var(--color-text-primary));
}
.pt-phase-header__back-icon {
  width: 1rem;
  height: 1rem;
}
.pt-phase-header__actions {
  display: flex;
  gap: 0.5rem;
}
.pt-phase-header__title {
  font-size: 1.625rem;
  font-weight: 700;
  color: var(--pt-text-primary, var(--color-text-primary));
  line-height: 1.25;
  margin: 0 0 0.5rem;
}
.pt-phase-header__meta {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem;
  align-items: center;
}
.pt-phase-header__meta-item {
  display: inline-flex;
  align-items: center;
  gap: 0.25rem;
  font-size: 0.8125rem;
  color: var(--pt-text-secondary, var(--color-text-secondary));
}
.pt-phase-header__meta-icon {
  width: 0.875rem;
  height: 0.875rem;
  opacity: 0.6;
}
.pt-phase-stepper {
  margin-bottom: 1.5rem;
}
.pt-phase-stepper__track {
  display: flex;
  gap: 2px;
  border-radius: 0.25rem;
  overflow: hidden;
}
.pt-phase-stepper__step {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.375rem;
  padding: 0.625rem 1rem;
  font-size: 0.75rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  position: relative;
  text-decoration: none;
  transition: background-color 0.2s ease, filter 0.15s ease;
}
a.pt-phase-stepper__step:hover {
  filter: brightness(0.96);
  text-decoration: none;
}
.pt-phase-stepper__step--upcoming {
  background: var(--pt-surface-subtle, var(--color-surface-2));
  color: var(--pt-text-secondary, var(--color-text-muted));
}
.pt-phase-stepper__step--completed {
  background: var(--pt-success-subtle, var(--color-success-subtle));
  color: var(--pt-success, var(--color-success));
}
.pt-phase-stepper__step--active {
  background: var(--pt-primary, var(--color-brand));
  color: var(--color-surface);
}
.pt-phase-stepper__icon {
  width: 0.875rem;
  height: 0.875rem;
}
.pt-phase-stepper__label {
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.pt-phase-stepper__step:not(:last-child)::after {
  content: "";
  position: absolute;
  right: -8px;
  top: 50%;
  transform: translateY(-50%);
  width: 0;
  height: 0;
  border-top: 20px solid transparent;
  border-bottom: 20px solid transparent;
  z-index: 1;
}
.pt-phase-stepper__step--upcoming:not(:last-child)::after {
  border-left: 8px solid var(--pt-surface-subtle, var(--color-surface-2));
}
.pt-phase-stepper__step--completed:not(:last-child)::after {
  border-left: 8px solid var(--pt-success-subtle, var(--color-success-subtle));
}
.pt-phase-stepper__step--active:not(:last-child)::after {
  border-left: 8px solid var(--pt-primary, var(--color-brand));
}
.pt-phase-tabs {
  display: flex;
  gap: 0;
  border-bottom: 1px solid var(--pt-border, var(--color-border));
  margin-bottom: 1.5rem;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}
.pt-phase-tab {
  display: inline-flex;
  align-items: center;
  gap: 0.375rem;
  padding: 0.75rem 1rem;
  font-size: 0.8125rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--pt-text-secondary, var(--color-text-secondary));
  text-decoration: none;
  white-space: nowrap;
  border-bottom: 2px solid transparent;
  transition: color 0.15s ease, border-color 0.15s ease;
}
.pt-phase-tab:hover {
  color: var(--pt-text-primary, var(--color-text-primary));
}
.pt-phase-tab--active {
  color: var(--pt-primary, var(--color-brand));
  border-bottom-color: var(--pt-primary, var(--color-brand));
}
.pt-phase-tab__icon {
  width: 1rem;
  height: 1rem;
}
.pt-tender-detail {
  max-width: 100%;
  min-width: 0;
  container-type: inline-size;
  container-name: tender;
}
.pt-tender-shell {
  display: block;
}
.pt-tender-shell--with-rail {
  display: flex;
  align-items: stretch;
  gap: 0.75rem;
}
.pt-tender-main {
  flex: 1;
  min-width: 0;
}
.pt-tender-header {
  margin-bottom: 1.5rem;
}
.pt-tender-header__top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1.25rem;
  margin-bottom: 0.75rem;
}
.pt-tender-header__back {
  display: inline-flex;
  align-items: center;
  gap: 0.375rem;
  min-width: 0;
  color: var(--pt-text-secondary, var(--color-text-secondary));
  font-size: 0.8125rem;
  font-weight: 500;
  text-decoration: none;
  transition: color 0.15s ease;
}
.pt-tender-header__back:hover, .pt-tender-header__back:focus-visible {
  color: var(--pt-text-primary, var(--color-text-primary));
}
.pt-tender-header__back-icon {
  flex: 0 0 auto;
  width: 1rem;
  height: 1rem;
}
.pt-tender-header__title {
  min-width: 0;
  margin: 0 0 0.5rem;
  color: var(--pt-text-primary, var(--color-text-primary));
  font-size: 1.625rem;
  font-weight: 700;
  line-height: 1.25;
}
.pt-tender-header__actions {
  display: flex;
  flex: 0 0 auto;
  align-items: center;
  gap: 0.5rem;
}
.pt-tender-header__actions .pt-btn {
  white-space: nowrap;
}
.pt-tender-header__meta {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 1rem;
  color: var(--pt-text-secondary, var(--color-text-secondary));
  font-size: 0.8125rem;
  line-height: 1.45;
}
.pt-tender-header__meta-item {
  display: inline-flex;
  align-items: center;
  gap: 0.25rem;
  min-width: 0;
  color: var(--pt-text-secondary, var(--color-text-secondary));
  font-size: 0.8125rem;
}
.pt-tender-header__meta-icon {
  flex: 0 0 auto;
  width: 0.875rem;
  height: 0.875rem;
  opacity: 0.6;
}
.pt-tender-header__meta-item--reference {
  color: var(--pt-text-primary, var(--color-text-primary));
  font-weight: 500;
}
.pt-tender-header__meta-item--date {
  color: var(--pt-text-primary, var(--color-text-primary));
  font-weight: 500;
}
.pt-tender-header__meta-item--bids {
  align-items: center;
  gap: 0.1875rem;
}
.pt-tender-header__bids-submitted {
  color: var(--pt-success, var(--color-success));
  font-weight: 700;
}
.pt-tender-header__bids-total {
  color: var(--pt-text-primary, var(--color-text-primary));
  font-weight: 600;
}
.pt-tender-header__rfcs-closed {
  color: var(--pt-success, var(--color-success));
  font-weight: 700;
}
.pt-tender-header__rfcs-total {
  color: var(--pt-text-primary, var(--color-text-primary));
  font-weight: 600;
}
.pt-tender-header__bids-separator {
  color: var(--pt-text-secondary, var(--color-text-secondary));
}
.pt-tender-header__meta-item--rfcs {
  align-items: center;
  gap: 0.125rem;
  color: var(--pt-text-primary, var(--color-text-primary));
  font-weight: 500;
}
.pt-tender-header__meta-item--rfcs .pt-tender-header__bids-separator {
  margin-right: 0;
  margin-left: -0.125rem;
}
.pt-tender-header__meta-item--project {
  gap: 0.25rem;
  color: var(--pt-text-primary, var(--color-text-primary));
  font-weight: 500;
}
.pt-tender-header__project-link {
  display: inline;
  min-width: 0;
  color: var(--pt-primary, var(--color-brand));
  font-weight: 500;
  text-decoration: none;
  transition: color 0.15s ease, text-decoration-color 0.15s ease;
}
.pt-tender-header__project-link:hover, .pt-tender-header__project-link:focus-visible {
  color: var(--pt-primary, var(--color-brand));
  text-decoration: underline;
  text-underline-offset: 0.16em;
}
.pt-tender-header .pt-status-badge {
  display: inline-flex;
  align-items: center;
  min-height: 1.375rem;
  padding: 0.125rem 0.5rem;
  border-radius: 0.25rem;
  font-size: 0.6875rem;
  font-weight: 700;
  letter-spacing: 0.05em;
  line-height: 1;
  text-transform: uppercase;
}
.pt-tender-tabs {
  display: flex;
  gap: 0;
  margin: 0 0 1.5rem;
  overflow-x: auto;
  border-bottom: 1px solid var(--pt-border, var(--color-border));
  -webkit-overflow-scrolling: touch;
}
.pt-tender-tab {
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: 0.375rem;
  flex: 0 0 auto;
  padding: 0.75rem 1rem;
  color: var(--pt-text-secondary, var(--color-text-secondary));
  border-bottom: 2px solid transparent;
  font-size: 0.8125rem;
  font-weight: 600;
  letter-spacing: 0.04em;
  line-height: 1;
  text-decoration: none;
  text-transform: uppercase;
  white-space: nowrap;
  transition: color 0.15s ease, border-color 0.15s ease;
}
.pt-tender-tab:hover, .pt-tender-tab:focus-visible {
  color: var(--pt-text-primary, var(--color-text-primary));
}
.pt-tender-tab--active {
  color: var(--pt-primary, var(--color-brand));
  border-bottom-color: var(--pt-primary, var(--color-brand));
}
.pt-tender-tab--disabled {
  cursor: not-allowed;
  opacity: 0.56;
  pointer-events: none;
}
.pt-tender-tab__icon {
  width: 1rem;
  height: 1rem;
}
.pt-tender-content {
  min-height: 300px;
}
.pt-tender-overview {
  min-width: 0;
}
.pt-tender-overview__title {
  margin: 0 0 2rem;
  color: var(--pt-text-primary, var(--color-text-primary));
  font-size: 1.5rem;
  font-weight: 700;
  line-height: 1.3;
}
.pt-tender-section {
  margin-bottom: 2rem;
}
.pt-tender-section:last-child {
  margin-bottom: 0;
}
.pt-tender-section__heading {
  margin: 0 0 1rem;
  color: var(--pt-text-primary, var(--color-text-primary));
  font-size: 0.8125rem;
  font-weight: 700;
  letter-spacing: 0.075em;
  line-height: 1.3;
  text-transform: uppercase;
}
.pt-tender-panel {
  min-width: 0;
  padding: 1.75rem 1.5rem;
  background: var(--pt-surface, var(--color-surface));
  border: 1px solid var(--pt-border, var(--color-border));
  border-radius: 0.25rem;
}
.pt-tender-policies {
  display: grid;
  grid-template-columns: minmax(18rem, 1fr) minmax(20rem, 0.94fr);
  gap: 2.75rem;
  align-items: start;
}
.pt-tender-policies--single {
  grid-template-columns: 1fr;
}
.pt-tender-policies--single .pt-tender-policies__secondary {
  max-width: 50rem;
}
.pt-tender-policies__primary, .pt-tender-policies__secondary {
  min-width: 0;
}
.pt-tender-policy-block {
  min-width: 0;
}
.pt-tender-policy-block + .pt-tender-policy-block {
  margin-top: 1.5rem;
}
.pt-tender-policy-block__title {
  margin: 0 0 0.625rem;
  color: var(--pt-text-primary, var(--color-text-primary));
  font-size: 0.9375rem;
  font-weight: 700;
  line-height: 1.45;
}
.pt-tender-policy-block__text {
  color: var(--pt-text-secondary, var(--color-text-secondary));
  font-size: 0.875rem;
  line-height: 1.7;
  overflow-wrap: anywhere;
}
.pt-tender-policy-block__text p {
  margin: 0 0 0.75rem;
}
.pt-tender-policy-block__text p:last-child {
  margin-bottom: 0;
}
.pt-tender-detail-list, .pt-tender-bullet-list {
  margin: 0;
  padding-left: 1.125rem;
  list-style-type: disc;
  color: var(--pt-text-secondary, var(--color-text-secondary));
  font-size: 0.875rem;
  line-height: 1.65;
}
.pt-tender-detail-list__item, .pt-tender-bullet-list li {
  padding-left: 0.125rem;
}
.pt-tender-detail-list__item::marker, .pt-tender-bullet-list li::marker {
  color: var(--pt-text-primary, var(--color-text-primary));
}
.pt-tender-detail-list__item + .pt-tender-detail-list__item, .pt-tender-bullet-list li + li {
  margin-top: 0.25rem;
}
.pt-tender-detail-list__label {
  margin-right: 0.3rem;
  color: var(--pt-text-primary, var(--color-text-primary));
  font-weight: 500;
}
.pt-tender-detail-list__value {
  color: var(--pt-text-secondary, var(--color-text-secondary));
}
.pt-tender-area-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1rem 1.5rem;
}
.pt-tender-area-item {
  display: flex;
  flex-direction: column;
  min-width: 0;
  gap: 0.25rem;
}
.pt-tender-area-item__header {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  min-width: 0;
}
.pt-tender-area-item__icon {
  flex: 0 0 auto;
  width: 0.875rem;
  height: 0.875rem;
  color: var(--pt-text-secondary, var(--color-text-secondary));
}
.pt-tender-area-item__label {
  min-width: 0;
  color: var(--pt-text-primary, var(--color-text-primary));
  font-size: 0.8125rem;
  font-weight: 500;
  line-height: 1.4;
}
.pt-tender-area-item__value {
  padding-left: 1.375rem;
  color: var(--pt-text-secondary, var(--color-text-secondary));
  font-size: 0.8125rem;
  line-height: 1.4;
}
.pt-tender-fees {
  display: grid;
  grid-template-columns: minmax(18rem, 1fr) minmax(20rem, 0.94fr);
  gap: 2.75rem;
  align-items: start;
}
.pt-tender-fees--owner {
  grid-template-columns: repeat(2, minmax(14rem, 20rem));
  gap: 2rem;
}
.pt-tender-fees__description, .pt-tender-fees__breakdown {
  min-width: 0;
}
.pt-tender-fee-table {
  width: 100%;
  margin-top: 0.125rem;
  border-collapse: collapse;
  color: var(--pt-text-primary, var(--color-text-primary));
  font-size: 0.875rem;
}
.pt-tender-fee-table th, .pt-tender-fee-table td {
  padding: 0.75rem 0.875rem;
  border: 1px solid var(--pt-border, var(--color-border));
  vertical-align: middle;
}
.pt-tender-fee-table th {
  width: 56%;
  background: var(--pt-surface, var(--color-surface));
  color: var(--pt-text-secondary, var(--color-text-secondary));
  font-weight: 500;
  text-align: left;
}
.pt-tender-fee-table td {
  color: var(--pt-text-primary, var(--color-text-primary));
  font-weight: 500;
  text-align: left;
  white-space: nowrap;
}
.pt-tender-fee-table tfoot th, .pt-tender-fee-table tfoot td {
  background: var(--pt-surface-subtle, var(--color-surface-2));
  color: var(--pt-text-primary, var(--color-text-primary));
  font-weight: 700;
}
@container tender (max-width: 960px) {
  .pt-tender-policies, .pt-tender-fees, .pt-tender-fees--owner {
    grid-template-columns: 1fr;
    gap: 2rem;
  }
}
@container tender (max-width: 720px) {
  .pt-tender-area-grid {
    grid-template-columns: 1fr;
  }
  .pt-tender-header__top {
    flex-direction: column;
    align-items: flex-start;
    gap: 0.875rem;
  }
  .pt-tender-header__title {
    font-size: 1.25rem;
  }
  .pt-tender-header__meta {
    gap: 0.5rem 1rem;
  }
  .pt-tender-header__meta-item--project {
    flex-basis: 100%;
  }
  .pt-tender-tab {
    padding: 0.8125rem 0.875rem;
  }
  .pt-tender-overview__title {
    margin-bottom: 1.5rem;
    font-size: 1.25rem;
  }
  .pt-tender-panel {
    padding: 1.25rem 1rem;
  }
}
.pt-tender-overview__section {
  margin-bottom: 2rem;
}
.pt-tender-overview__grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 1rem;
}
.pt-tender-overview__card {
  background: var(--pt-surface, var(--color-surface));
  border: 1px solid var(--pt-border, var(--color-border));
  border-radius: 0.25rem;
  padding: 1.25rem;
}
.pt-tender-overview__card-title {
  font-size: 0.75rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--pt-text-secondary, var(--color-text-secondary));
  margin: 0 0 0.5rem;
}
.pt-tender-overview__card-body {
  font-size: 0.875rem;
  color: var(--pt-text-primary, var(--color-text-primary));
  line-height: 1.6;
}
.pt-tender-overview__list {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}
.pt-tender-overview__list-item {
  display: flex;
  align-items: flex-start;
  gap: 0.625rem;
  font-size: 0.875rem;
  color: var(--pt-text-primary, var(--color-text-primary));
  line-height: 1.5;
  padding: 0.625rem 1rem;
  background: var(--pt-surface, var(--color-surface));
  border: 1px solid var(--pt-border, var(--color-border));
  border-radius: 0.25rem;
}
.pt-tender-overview__list-icon {
  width: 1.125rem;
  height: 1.125rem;
  flex-shrink: 0;
  margin-top: 0.125rem;
  color: var(--pt-text-secondary, var(--color-text-secondary));
}
.pt-bidders-list {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}
.pt-bidder-card {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 1rem 1.25rem;
  background: var(--pt-surface, var(--color-surface));
  border: 1px solid var(--pt-border, var(--color-border));
  border-radius: 0.25rem;
  transition: border-color 0.15s ease, box-shadow 0.15s ease;
}
.pt-bidder-card:hover {
  border-color: var(--pt-border-hover, var(--color-border));
  box-shadow: 0 1px 3px rgba(0,0,0,0.05);
}
.pt-bidder-card__info {
  flex: 1;
  min-width: 0;
}
.pt-bidder-card__name {
  font-size: 0.9375rem;
  font-weight: 600;
  color: var(--pt-text-primary, var(--color-text-primary));
  margin: 0 0 0.25rem;
}
.pt-bidder-card__meta {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
  align-items: center;
}
.pt-bidder-card__date {
  display: inline-flex;
  align-items: center;
  gap: 0.25rem;
  font-size: 0.75rem;
  color: var(--pt-text-secondary, var(--color-text-secondary));
}
.pt-phase-gallery {
  display: grid;
  gap: 0.5rem;
  margin-bottom: 0;
}
.pt-phase-gallery {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}
.pt-phase-gallery--count-1 {
  grid-template-columns: 1fr;
}
.pt-phase-gallery--count-2 {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}
.pt-phase-gallery__item {
  border-radius: 0.25rem;
  overflow: hidden;
  aspect-ratio: 16 / 9;
  position: relative;
}
.pt-phase-gallery__item {
  max-height: 280px;
}
.pt-phase-gallery--count-2 .pt-phase-gallery__item {
  max-height: calc(600px - 2rem);
}
.pt-phase-gallery--count-1 .pt-phase-gallery__item {
  aspect-ratio: auto;
  max-height: calc(600px - 2rem);
}
.pt-phase-gallery--count-1 .pt-phase-gallery__image {
  height: auto;
  max-height: calc(600px - 2rem);
  object-fit: contain;
}
.pt-phase-gallery__image {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.3s ease;
}
.pt-phase-gallery__item:hover .pt-phase-gallery__image {
  transform: scale(1.03);
}
.pt-phase-gallery__placeholder {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  padding: 3rem;
  background: var(--pt-surface-subtle, var(--color-surface-2));
  border: 2px dashed var(--pt-border, var(--color-border));
  border-radius: 0.25rem;
  color: var(--pt-text-muted, var(--color-text-muted));
  grid-column: 1 / -1;
}
.pt-phase-gallery__placeholder-icon {
  width: 2.5rem;
  height: 2.5rem;
  opacity: 0.4;
}
.pt-phase-section-title {
  font-size: 0.8125rem;
  font-weight: 700;
  color: var(--pt-text-secondary, var(--color-text-secondary));
  text-transform: uppercase;
  letter-spacing: 0.06em;
  margin: 0;
  padding: 0.875rem 1.25rem;
}
.pt-phase-section-title__count {
  color: var(--pt-text-tertiary, var(--color-text-muted));
  font-weight: 600;
  margin-left: 0.25rem;
}
@container phase (max-width: 930px) {
  .pt-phase-shell--with-rail {
    flex-direction: column;
  }
  .pt-phase-rail {
    position: relative;
    top: auto;
    align-self: stretch;
    height: auto;
    min-height: 0;
    margin: 0;
  }
  .pt-phase-rail, .pt-phase-rail .pt-context-sidebar {
    width: 100%;
    min-width: 0;
  }
  .pt-phase-rail .pt-context-sidebar {
    height: auto;
  }
  .pt-phase-rail .pt-context-sidebar--collapsed {
    width: 100%;
    min-width: 0;
  }
  .pt-phase-rail .pt-context-sidebar--collapsed .pt-context-sidebar__icons {
    display: none;
  }
  .pt-phase-rail .pt-context-sidebar--collapsed .pt-context-sidebar__body {
    display: flex;
  }
  .pt-phase-rail .pt-context-sidebar__toggle, .pt-phase-rail .pt-context-sidebar__collapse {
    display: none;
  }
}
@container tender (max-width: 930px) {
  .pt-tender-shell--with-rail {
    flex-direction: column;
  }
  .pt-tender-rail {
    position: relative;
    top: auto;
    align-self: stretch;
    height: auto;
    min-height: 0;
    margin: 0;
  }
  .pt-tender-rail, .pt-tender-rail .pt-context-sidebar {
    width: 100%;
    min-width: 0;
  }
  .pt-tender-rail .pt-context-sidebar {
    height: auto;
  }
  .pt-tender-rail .pt-context-sidebar--collapsed {
    width: 100%;
    min-width: 0;
  }
  .pt-tender-rail .pt-context-sidebar--collapsed .pt-context-sidebar__icons {
    display: none;
  }
  .pt-tender-rail .pt-context-sidebar--collapsed .pt-context-sidebar__body {
    display: flex;
  }
  .pt-tender-rail .pt-context-sidebar__toggle, .pt-tender-rail .pt-context-sidebar__collapse {
    display: none;
  }
}
.pt-phase-content > * + * {
  margin-top: 1.25rem;
}
.pt-phase-card-content {
  padding: 1rem 1.25rem;
}
.pt-phase-overview-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.2fr) minmax(0, 1fr);
  align-items: stretch;
}
.pt-phase-overview-grid__media {
  min-width: 0;
  max-height: 600px;
  padding: 1rem 1.25rem;
  overflow: hidden;
}
.pt-phase-overview-grid__media .pt-phase-gallery {
  margin-bottom: 0;
}
.pt-phase-overview-grid__media .pt-phase-gallery__placeholder {
  min-height: 220px;
}
.pt-phase-overview-grid__details {
  min-width: 0;
  padding: 0.25rem 1.25rem;
  border-left: 1px solid var(--pt-border, var(--color-border));
}
@container phase (max-width: 930px) {
  .pt-phase-overview-grid {
    grid-template-columns: 1fr;
  }
  .pt-phase-overview-grid__details {
    border-left: 0;
    border-top: 1px solid var(--pt-border, var(--color-border));
  }
}
.pt-phase-details {
  margin-bottom: 2rem;
}
.pt-phase-details__grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: 1.25rem;
}
.pt-phase-detail-item {
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
}
.pt-phase-detail-item__label {
  font-size: 0.75rem;
  font-weight: 600;
  color: var(--pt-text-secondary, var(--color-text-secondary));
  text-transform: uppercase;
  letter-spacing: 0.04em;
}
.pt-phase-detail-item__value {
  font-size: 0.875rem;
  font-weight: 500;
  color: var(--pt-text-primary, var(--color-text-primary));
}
.pt-phase-scope {
  margin-bottom: 2rem;
}
.pt-phase-scope__content {
  font-size: 0.875rem;
  line-height: 1.7;
  color: var(--pt-text-primary, var(--color-text-primary));
  white-space: pre-wrap;
}
.pt-phase-scope__empty {
  font-size: 0.875rem;
  color: var(--pt-text-muted, var(--color-text-muted));
  font-style: italic;
  padding: 1.5rem;
  background: var(--pt-surface-subtle, var(--color-surface-2));
  border-radius: 0.25rem;
  text-align: center;
}
.pt-phase-facts {
  margin-bottom: 2rem;
}
.pt-phase-facts__grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
  gap: 1rem 1.5rem;
}
.pt-phase-fact-row {
  display: flex;
  align-items: center;
  gap: 0.625rem;
  min-width: 0;
}
.pt-phase-fact-row__icon {
  flex-shrink: 0;
  width: 1.125rem;
  height: 1.125rem;
  color: var(--pt-text-secondary, var(--color-text-secondary));
}
.pt-phase-fact-row__body {
  flex: 1;
  min-width: 0;
}
.pt-phase-fact-row__label {
  font-size: 0.875rem;
  font-weight: 700;
  color: var(--pt-text-primary, var(--color-text-primary));
  line-height: 1.2;
}
.pt-phase-fact-row__value {
  font-size: 0.8125rem;
  color: var(--pt-text-secondary, var(--color-text-secondary));
  margin-top: 0.125rem;
  overflow-wrap: anywhere;
}
.pt-phase-map {
  margin-bottom: 2rem;
}
.pt-phase-map__container {
  width: 100%;
  height: 300px;
  border-radius: 0.25rem;
  overflow: hidden;
  background: var(--pt-surface-subtle, var(--color-surface-2));
  border: 1px solid var(--pt-border, var(--color-border));
}
@container phase (max-width: 950px) {
  .pt-phase-stepper__track {
    flex-direction: column;
    overflow: visible;
  }
  .pt-phase-stepper__step {
    flex: none;
    width: 100%;
    justify-content: flex-start;
    padding: 0.625rem 1rem;
  }
  .pt-phase-stepper__step:not(:last-child)::after {
    display: none;
  }
  .pt-phase-header__meta {
    flex-wrap: wrap;
    row-gap: 0.5rem;
  }
  .pt-phase-tabs {
    overflow-x: auto;
    flex-wrap: nowrap;
  }
}
@container phase (max-width: 818px) {
  .pt-phase-header__top {
    flex-direction: column;
    align-items: flex-start;
    gap: 0.75rem;
  }
  .pt-phase-header__title {
    font-size: 1.25rem;
  }
  .pt-phase-facts__grid {
    grid-template-columns: 1fr;
  }
}
@container phase (max-width: 530px) {
  .pt-phase-gallery, .pt-phase-gallery--count-2 {
    grid-template-columns: 1fr;
  }
}
.pt-phase-gallery .pt-phase-gallery__item {
  background: transparent;
  border: 0;
  padding: 0;
  cursor: pointer;
  font: inherit;
  color: inherit;
  text-align: inherit;
}
.pt-phase-gallery__more-overlay {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(15, 23, 42, 0.55);
  color: #fff;
  font-size: 1.5rem;
  font-weight: 700;
  letter-spacing: 0.02em;
  text-shadow: 0 1px 4px rgba(0, 0, 0, 0.35);
  transition: background 0.2s ease;
}
.pt-phase-gallery__item:hover .pt-phase-gallery__more-overlay {
  background: rgba(15, 23, 42, 0.7);
}
.pt-gallery-lightbox {
  border: 0;
  background: transparent;
  padding: 0;
  max-width: 96vw;
  max-height: 96vh;
  width: 96vw;
  height: 96vh;
  color: #fff;
}
.pt-gallery-lightbox::backdrop {
  background: rgba(15, 23, 42, 0.85);
}
.pt-gallery-lightbox__inner {
  position: relative;
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
}
.pt-gallery-lightbox__image {
  max-width: 100%;
  max-height: 100%;
  object-fit: contain;
  border-radius: 0.25rem;
  box-shadow: 0 24px 48px rgba(0, 0, 0, 0.45);
}
.pt-gallery-lightbox__nav, .pt-gallery-lightbox__close {
  position: absolute;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 2.5rem;
  height: 2.5rem;
  border-radius: 9999px;
  border: 0;
  background: rgba(15, 23, 42, 0.55);
  color: #fff;
  cursor: pointer;
  transition: background 0.15s ease, transform 0.15s ease;
}
.pt-gallery-lightbox__nav:hover, .pt-gallery-lightbox__close:hover {
  background: rgba(15, 23, 42, 0.8);
  transform: scale(1.05);
}
.pt-gallery-lightbox__nav--prev {
  left: 0.5rem;
  top: 50%;
  transform: translateY(-50%);
}
.pt-gallery-lightbox__nav--prev:hover {
  transform: translateY(-50%) scale(1.05);
}
.pt-gallery-lightbox__nav--next {
  right: 0.5rem;
  top: 50%;
  transform: translateY(-50%);
}
.pt-gallery-lightbox__nav--next:hover {
  transform: translateY(-50%) scale(1.05);
}
.pt-gallery-lightbox__nav-icon, .pt-gallery-lightbox__close-icon {
  width: 1.25rem;
  height: 1.25rem;
}
.pt-gallery-lightbox__close {
  top: 0.75rem;
  right: 0.75rem;
}
.pt-gallery-lightbox__counter {
  position: absolute;
  bottom: 0.75rem;
  left: 50%;
  transform: translateX(-50%);
  padding: 0.25rem 0.75rem;
  border-radius: 9999px;
  background: rgba(15, 23, 42, 0.55);
  font-size: 0.8125rem;
  font-weight: 500;
  color: #fff;
}
.pt-phase-relations {
  display: flex;
  align-items: center;
  gap: 0.875rem;
  padding: 0.875rem 1rem;
  margin-bottom: 1.5rem;
  background: var(--pt-surface-subtle, var(--color-surface-2));
  border: 1px dashed var(--pt-border, var(--color-border));
  border-radius: 0.25rem;
}
.pt-phase-relations__icon {
  flex: 0 0 auto;
  width: 2rem;
  height: 2rem;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--pt-text-secondary, var(--color-text-secondary));
}
.pt-phase-relations__icon-svg {
  width: 1.25rem;
  height: 1.25rem;
}
.pt-phase-relations__title {
  font-size: 0.75rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--pt-text-secondary, var(--color-text-secondary));
  margin: 0 0 0.125rem;
}
.pt-phase-relations__value {
  font-size: 0.9375rem;
  font-weight: 500;
  color: var(--pt-text-primary, var(--color-text-primary));
}
.pt-ctx-view-all-wrap {
  margin-top: 0.5rem;
  padding-top: 0.5rem;
  border-top: 1px solid var(--pt-border, var(--color-border));
  text-align: center;
}
.pt-ctx-view-all {
  display: inline-flex;
  align-items: center;
  gap: 0.375rem;
  background: none;
  border: 0;
  padding: 0.375rem 0.75rem;
  margin: 0 auto;
  cursor: pointer;
  font-size: 0.8125rem;
  font-weight: 600;
  color: var(--pt-brand, #1d4ed8);
  transition: color 0.15s ease;
}
.pt-ctx-view-all:hover {
  color: var(--pt-brand-strong, #1e40af);
  text-decoration: underline;
}
.pt-ctx-activity-content a, .pt-ctx-activity-list--modal a {
  color: inherit;
  font-weight: 500;
  text-decoration: none;
}
.pt-ctx-activity-content a:hover, .pt-ctx-activity-list--modal a:hover {
  text-decoration: underline;
  text-decoration-color: currentColor;
}
.pt-notifications-modal {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}
.pt-notifications-modal[aria-busy="true"] {
  min-height: 8rem;
  opacity: 0.72;
  pointer-events: none;
}
.pt-notifications-modal__error {
  padding: 1rem;
  border: 1px solid var(--pt-danger-border, #fecdca);
  border-radius: 0.25rem;
  background: var(--pt-danger-subtle, #fef3f2);
  color: var(--pt-danger, #b42318);
  font-size: 0.875rem;
  line-height: 1.5;
}
.pt-notifications-modal__title {
  font-size: 1rem;
  font-weight: 700;
  color: var(--pt-text-primary, var(--color-text-primary));
  margin: 0;
}
.pt-notifications-modal__body {
  max-height: 60vh;
  overflow-y: auto;
}
.pt-ctx-activity-list--modal {
  list-style: none;
  margin: 0;
  padding: 0;
}
.pt-ctx-activity-list--modal .pt-ctx-activity-item {
  padding: 0.625rem 0;
  border-bottom: 1px solid var(--pt-border, var(--color-border));
}
.pt-ctx-activity-list--modal .pt-ctx-activity-item:last-child {
  border-bottom: 0;
}
.pt-ctx-activity-item--archived {
  opacity: 0.7;
}
.pt-tenders-page {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}
.pt-tenders-page__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  flex-wrap: wrap;
}
.pt-tenders-page__title-row {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  min-width: 0;
}
.pt-tenders-page__header-actions {
  display: flex;
  align-items: center;
  gap: 0.625rem;
  flex-shrink: 0;
  .pt-tenders-sort {
    height: 2rem;
    box-sizing: border-box;
    line-height: 1;
  }
}
.pt-tenders-sort {
  padding: 0.3rem 2rem 0.3rem 0.625rem;
  border: 1px solid oklch(82% 0 0);
  border-radius: 0.375rem;
  font-size: 0.8125rem;
  color: oklch(25% 0 0);
  background: white url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23647079' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E") no-repeat right 0.5rem center;
  appearance: none;
  cursor: pointer;
  min-width: 9rem;
  &:focus {
    outline: 2px solid oklch(50% 0.18 250);
    outline-offset: 1px;
    border-color: transparent;
  }
  &:hover {
    border-color: oklch(70% 0 0);
  }
}
.pt-tenders-page__list {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}
.pt-tenders-cta {
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 0.75rem;
  width: 18rem;
  min-height: 8.5rem;
  padding: 1.5rem 2rem;
  background: white;
  border: 1px solid oklch(88% 0 0);
  border-radius: 0.375rem;
  box-shadow: 0 0.125rem 0.5rem oklch(20% 0 0 / 5%);
  color: oklch(25% 0 0);
  text-decoration: none;
  transition: border-color 120ms ease, box-shadow 120ms ease;
  &:hover {
    border-color: oklch(72% 0 0);
    box-shadow: 0 0.25rem 0.75rem oklch(20% 0 0 / 10%);
  }
}
.pt-tenders-cta__icon {
  width: 2.25rem;
  height: 2.25rem;
  color: oklch(35% 0 0);
  flex-shrink: 0;
}
.pt-tenders-cta__label {
  font-size: 0.9375rem;
  font-weight: 600;
  color: oklch(25% 0 0);
}
.pt-auth-alerts {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 1000;
  display: flex;
  flex-direction: column;
  pointer-events: none;
  & > * {
    pointer-events: auto;
  }
}
.pt-auth-shell {
  display: grid;
  grid-template-columns: 2fr 3fr;
  min-height: 100dvh;
  @media (max-width: 768px) {
    grid-template-columns: 1fr;
  }
}
.pt-auth-brand {
  position: relative;
  overflow: hidden;
  background: oklch(18% 0.02 250);
  display: flex;
  flex-direction: column;
  @media (max-width: 768px) {
    display: none;
  }
}
.pt-auth-brand__video {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  z-index: 0;
}
.pt-auth-brand__scrim {
  position: absolute;
  inset: 0;
  z-index: 1;
  background: linear-gradient(160deg, oklch(12% 0.02 250 / 0.78) 0%, oklch(10% 0.03 250 / 0.62) 100%);
  pointer-events: none;
}
.pt-auth-brand__content {
  position: relative;
  z-index: 2;
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
  padding: 2.5rem;
  flex: 1;
}
.pt-auth-brand__headline {
  font-family: var(--font-display);
  font-size: clamp(1.875rem, 3vw, 2.75rem);
  font-weight: 800;
  text-transform: uppercase;
  color: var(--color-surface);
  line-height: 1.05;
  letter-spacing: -0.01em;
  margin: 0;
  max-width: 14ch;
  text-wrap: balance;
}
.pt-auth-brand__headline-accent {
  display: block;
  color: var(--color-brand-orange);
}
.pt-auth-brand__actions {
  list-style: none;
  margin: 0;
  padding: 0;
  counter-reset: pt-action;
  display: flex;
  flex-direction: column;
  gap: 0.875rem;
}
.pt-auth-brand__action {
  counter-increment: pt-action;
  display: flex;
  align-items: baseline;
  gap: 1rem;
  font-family: var(--font-display);
  font-size: clamp(1.375rem, 2vw, 1.75rem);
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: -0.01em;
  line-height: 1;
  color: var(--color-surface);
}
.pt-auth-brand__action::before {
  content: counter(pt-action, decimal-leading-zero);
  font-size: 0.8125rem;
  font-weight: 700;
  letter-spacing: 0;
  color: var(--color-brand-orange);
  min-width: 1.5rem;
}
.pt-auth-form-panel {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 2rem;
  background: var(--color-surface);
}
.pt-auth-form-card {
  width: 100%;
  max-width: 22rem;
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
}
.pt-auth-form-card__header {
  text-align: center;
}
.pt-auth-form-card__title {
  font-size: 1.75rem;
  font-weight: 700;
  color: oklch(15% 0 0);
  letter-spacing: -0.03em;
  margin: 0 0 0.375rem;
}
.pt-auth-form-card__subtitle {
  font-size: 0.875rem;
  color: oklch(50% 0 0);
  margin: 0;
}
.pt-auth-form {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}
.pt-auth-form__field {
  display: flex;
  flex-direction: column;
  gap: 0.375rem;
}
.pt-auth-form__field-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.pt-auth-form__label {
  font-size: 0.8125rem;
  font-weight: 500;
  color: oklch(25% 0 0);
}
.pt-auth-form__input {
  width: 100%;
  padding: 0.625rem 0.875rem;
  border: 1.5px solid oklch(88% 0 0);
  border-radius: 0.5rem;
  font-size: 0.9375rem;
  color: oklch(15% 0 0);
  background: var(--color-surface);
  outline: none;
  transition: border-color 120ms ease, box-shadow 120ms ease;
  box-sizing: border-box;
  &::placeholder {
    color: oklch(65% 0 0);
  }
  &:focus {
    border-color: oklch(45% 0.18 250);
    box-shadow: 0 0 0 3px oklch(45% 0.18 250 / 0.12);
  }
}
.pt-auth-form__forgot-link {
  font-size: 0.8125rem;
  color: oklch(45% 0.18 250);
  text-decoration: none;
  &:hover {
    text-decoration: underline;
  }
}
.pt-auth-form__remember {
  display: flex;
  align-items: center;
  gap: 0.5rem;
}
.pt-auth-form__checkbox {
  width: 1rem;
  height: 1rem;
  accent-color: oklch(45% 0.18 250);
  cursor: pointer;
}
.pt-auth-form__remember-label {
  font-size: 0.8125rem;
  color: oklch(40% 0 0);
  cursor: pointer;
}
.pt-auth-form__submit {
  width: 100%;
  padding: 0.75rem;
  background: oklch(45% 0.18 250);
  color: var(--color-surface);
  font-size: 0.9375rem;
  font-weight: 600;
  border: none;
  border-radius: 0.5rem;
  cursor: pointer;
  transition: background 120ms ease, transform 80ms ease;
  margin-top: 0.25rem;
  letter-spacing: -0.01em;
  &:hover {
    background: oklch(40% 0.18 250);
  }
  &:active {
    transform: scale(0.99);
  }
}
.pt-auth-form-divider {
  display: flex;
  align-items: center;
  gap: 0.75rem;
}
.pt-auth-form-divider__line {
  flex: 1;
  height: 1px;
  background: oklch(92% 0 0);
}
.pt-auth-form-divider__text {
  font-size: 0.75rem;
  color: oklch(60% 0 0);
  white-space: nowrap;
}
.pt-auth-sso-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  width: 100%;
  padding: 0.6875rem;
  border: 1.5px solid oklch(88% 0 0);
  border-radius: 0.5rem;
  font-size: 0.875rem;
  font-weight: 500;
  color: oklch(25% 0 0);
  text-decoration: none;
  background: var(--color-surface);
  transition: border-color 120ms ease, background 120ms ease;
  &:hover {
    border-color: oklch(70% 0 0);
    background: oklch(98.5% 0 0);
  }
}
.pt-auth-sso-btn__icon {
  flex-shrink: 0;
  color: oklch(45% 0.18 250);
}
.pt-auth-form-footer {
  text-align: center;
  font-size: 0.8125rem;
  color: oklch(55% 0 0);
}
.pt-auth-form-footer__link {
  color: oklch(45% 0.18 250);
  font-weight: 500;
  text-decoration: none;
  margin-left: 0.25rem;
  &:hover {
    text-decoration: underline;
  }
}
.pt-auth-card-shell {
  min-height: 100dvh;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 2rem 1rem;
  gap: 1.25rem;
  background: oklch(98.5% 0 0);
}
.pt-auth-card-shell .pt-auth-form-card {
  background: var(--color-surface);
  border: 1px solid oklch(91% 0 0);
  border-radius: 1rem;
  padding: 2rem;
  box-shadow: 0 1px 4px oklch(0% 0 0 / 0.05), 0 4px 16px oklch(0% 0 0 / 0.04);
  max-width: 24rem;
}
.pt-auth-form__back-link {
  font-size: 0.8125rem;
  color: oklch(50% 0 0);
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  gap: 0.25rem;
  transition: color 120ms ease;
  &:hover {
    color: oklch(45% 0.18 250);
  }
}
.pt-auth-form__hint {
  font-size: 0.75rem;
  color: oklch(58% 0 0);
  margin: 0;
  line-height: 1.4;
}
.pt-auth-form__success {
  background: oklch(96% 0.04 145);
  border: 1px solid oklch(80% 0.08 145);
  border-radius: 0.5rem;
  padding: 0.875rem 1rem;
  font-size: 0.875rem;
  color: oklch(30% 0.08 145);
  line-height: 1.5;
}
.pt-auth-form-errors {
  background: oklch(95% 0.05 25);
  border: 1px solid oklch(75% 0.12 25);
  border-radius: 0.5rem;
  padding: 0.875rem 1rem;
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}
.pt-auth-form-errors__header {
  display: flex;
  align-items: center;
  gap: 0.5rem;
}
.pt-auth-form-errors__icon {
  width: 1.125rem;
  height: 1.125rem;
  flex-shrink: 0;
  color: oklch(45% 0.18 25);
}
.pt-auth-form-errors__heading {
  font-size: 0.8125rem;
  font-weight: 600;
  color: oklch(35% 0.12 25);
}
.pt-auth-form-errors__list {
  margin: 0;
  padding: 0 0 0 1.5rem;
  list-style: disc;
}
.pt-auth-form-errors__item {
  font-size: 0.8125rem;
  color: oklch(40% 0.1 25);
  line-height: 1.5;
}
.pt-auth-form-card--wide {
  max-width: 26rem;
}
.pt-auth-form__row {
  display: flex;
  gap: 0.75rem;
}
.pt-auth-form__field--half {
  flex: 1;
  min-width: 0;
}
.pt-auth-form__terms {
  font-size: 0.75rem;
  color: oklch(55% 0 0);
  line-height: 1.5;
}
.pt-auth-form-card__icon {
  font-size: 2.5rem;
  line-height: 1;
  margin-bottom: 0.25rem;
}
.pt-auth-form .input {
  margin-bottom: 0;
}
.pt-auth-form .input label {
  font-size: 0.8125rem;
  font-weight: 500;
  color: oklch(25% 0 0);
  margin-bottom: 0.375rem;
  display: block;
}
.pt-auth-form .input input[type="text"], .pt-auth-form .input input[type="email"], .pt-auth-form .input input[type="password"], .pt-auth-form .input input[type="tel"] {
  width: 100%;
  padding: 0.625rem 0.875rem;
  border: 1.5px solid oklch(88% 0 0);
  border-radius: 0.5rem;
  font-size: 0.9375rem;
  color: oklch(15% 0 0);
  background: var(--color-surface);
  outline: none;
  transition: border-color 120ms ease, box-shadow 120ms ease;
  box-sizing: border-box;
  &::placeholder {
    color: oklch(65% 0 0);
  }
  &:focus {
    border-color: oklch(45% 0.18 250);
    box-shadow: 0 0 0 3px oklch(45% 0.18 250 / 0.12);
  }
}
.pt-auth-form .input .error, .pt-auth-form .input .hint {
  display: none;
}
.pt-auth-form-panel {
  overflow-y: auto;
}
.pt-account-settings {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-xl);
  width: 100%;
  min-width: 0;
}
.pt-account-settings__header {
  min-width: 0;
}
.pt-account-settings-header {
  margin-bottom: var(--spacing-xl);
  background: var(--pt-surface, var(--color-surface));
  border: 1px solid var(--pt-border, var(--color-border));
  border-radius: 0.25rem;
  box-shadow: 0 1px 2px rgba(15, 23, 42, 0.035);
}
.pt-account-settings-header__body {
  display: flex;
  align-items: flex-start;
  gap: var(--spacing-lg);
  padding: 1.125rem 1.5rem 0.875rem;
}
.pt-account-settings-header__icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 auto;
  width: 2.5rem;
  height: 2.5rem;
  color: var(--color-brand);
  background: var(--color-brand-subtle);
  border-radius: var(--radius-lg);
}
.pt-account-settings-header__text {
  min-width: 0;
}
.pt-account-settings-header__title {
  margin: 0 0 0.375rem;
  font-size: 1.625rem;
  font-weight: 700;
  line-height: 1.25;
  color: var(--pt-text-primary, var(--color-text-primary));
}
.pt-account-settings-header__subtitle {
  margin: 0;
  font-size: var(--text-sm);
  line-height: 1.5;
  color: var(--pt-text-secondary, var(--color-text-secondary));
}
.pt-account-settings-tabs {
  display: flex;
  align-items: stretch;
  gap: 0;
  padding: 0 1.5rem;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
  border-top: 1px solid var(--pt-border, var(--color-border));
}
.pt-account-settings-tabs::-webkit-scrollbar {
  display: none;
}
.pt-account-settings-tab {
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: 0.4375rem;
  flex: 0 0 auto;
  padding: 0.8125rem 1.125rem;
  font-size: 0.8125rem;
  font-weight: 600;
  letter-spacing: 0.04em;
  line-height: 1;
  text-transform: uppercase;
  color: var(--pt-text-secondary, var(--color-text-secondary));
  text-decoration: none;
  white-space: nowrap;
  border-bottom: 2px solid transparent;
  transition: color 0.15s ease, border-color 0.15s ease, background 0.15s ease;
}
.pt-account-settings-tab:hover, .pt-account-settings-tab:focus-visible {
  color: var(--pt-text-primary, var(--color-text-primary));
  outline: none;
}
.pt-account-settings-tab:focus-visible {
  background: var(--color-brand-subtle);
}
.pt-account-settings-tab--active {
  color: var(--pt-primary, var(--color-brand));
  border-bottom-color: var(--pt-primary, var(--color-brand));
}
.pt-account-settings-tab__icon {
  flex: 0 0 auto;
  width: 1rem;
  height: 1rem;
}
.pt-account-settings__grid {
  display: grid;
  grid-template-columns: minmax(14rem, 17rem) minmax(0, 1fr);
  gap: var(--spacing-xl);
  align-items: start;
}
.pt-account-settings__sidebar {
  position: sticky;
  top: var(--spacing-xl);
  padding: var(--spacing-lg);
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-card);
}
.pt-account-settings__nav-heading {
  margin: 0 0 var(--spacing-md);
  font-size: var(--text-xs);
  font-weight: 700;
  letter-spacing: 0.08em;
  color: var(--color-muted);
}
.pt-account-settings__nav {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-xs);
}
.pt-account-settings__nav-link {
  display: flex;
  align-items: center;
  gap: var(--spacing-sm);
  padding: 0.625rem var(--spacing-md);
  color: var(--color-text-secondary);
  text-decoration: none;
  border-radius: var(--radius-lg);
  font-size: var(--text-sm);
  font-weight: 500;
  transition: background 150ms ease, color 150ms ease, box-shadow 150ms ease;
}
.pt-account-settings__nav-link:hover, .pt-account-settings__nav-link:focus-visible {
  color: var(--color-brand);
  background: var(--color-brand-subtle);
  outline: none;
}
.pt-account-settings__nav-link:focus-visible {
  box-shadow: 0 0 0 3px oklch(45% 0.18 250 / 14%);
}
.pt-account-settings__nav-link--active {
  color: var(--color-brand);
  background: var(--color-brand-subtle);
}
.pt-account-settings__nav-link--disabled {
  color: var(--color-text-disabled);
  cursor: not-allowed;
}
.pt-account-settings__content {
  min-width: 0;
}
.pt-account-settings__content--wide {
  width: 100%;
}
.pt-account-settings-page {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-xl);
}
.pt-account-settings-card__header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: var(--spacing-lg);
}
.pt-account-settings-card__title-group {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-xs);
}
.pt-account-settings-card__title {
  margin: 0;
  color: var(--color-text-primary);
  font-size: var(--text-xl);
  font-weight: 700;
  line-height: 1.3;
}
.pt-account-settings-card__description {
  max-width: 62rem;
  margin: 0;
  color: var(--color-text-secondary);
  font-size: var(--text-sm);
  line-height: 1.5;
}
.pt-account-settings-form {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-xl);
}
.pt-account-settings-form__grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: var(--spacing-lg) var(--spacing-xl);
}
.pt-account-settings-form__full {
  grid-column: 1 / -1;
}
.pt-account-settings-form__section {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-lg);
  padding-top: var(--spacing-xl);
  border-top: 1px solid var(--color-border);
}
.pt-account-settings-form__section:first-of-type {
  padding-top: 0;
  border-top: 0;
}
.pt-account-settings-form__section-title {
  margin: 0;
  color: var(--color-text-primary);
  font-size: var(--text-lg);
  font-weight: 700;
}
.pt-account-settings-form__checkbox-title {
  font-weight: 600;
}
.pt-account-settings-form__actions {
  display: flex;
  align-items: center;
  gap: var(--spacing-sm);
  justify-content: flex-end;
  padding-top: var(--spacing-lg);
  border-top: 1px solid var(--color-border);
}
.pt-account-settings-alert {
  padding: var(--spacing-md);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  color: var(--color-text-primary);
  font-size: var(--text-sm);
  line-height: 1.5;
}
.pt-account-settings-alert p, .pt-account-settings-alert ul {
  margin: var(--spacing-xs) 0 0;
}
.pt-account-settings-alert--info {
  background: var(--color-brand-subtle);
  border-color: color-mix(in srgb, oklch(45% 0.18 250) 25%, oklch(88% 0 0));
  @supports (color: color-mix(in lab, red, red)) {
    border-color: color-mix(in oklch, var(--color-brand) 25%, var(--color-border));
  }
}
.pt-account-settings-alert--warning {
  background: var(--color-warning-subtle, var(--color-surface-muted));
  border-color: var(--color-warning, var(--color-border));
}
.pt-account-settings-alert--danger {
  background: var(--color-danger-subtle, var(--color-surface-muted));
  border-color: var(--color-danger, var(--color-border));
}
.pt-account-settings-stats {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: var(--spacing-md);
}
.pt-account-settings-stat {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-xs);
  min-width: 0;
  padding: var(--spacing-md);
  background: var(--color-surface-muted);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
}
.pt-account-settings-stat__label, .pt-account-settings-status__label {
  color: var(--color-text-secondary);
  font-size: var(--text-xs);
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}
.pt-account-settings-stat__value {
  color: var(--color-text-primary);
  font-size: var(--text-lg);
  font-weight: 700;
  line-height: 1.25;
}
.pt-account-settings-stat__value--link, .pt-account-settings-stat__link, .pt-account-settings-inline-link, .pt-account-settings-link-button {
  color: var(--color-brand);
  font-size: var(--text-sm);
  font-weight: 600;
  text-decoration: none;
}
.pt-account-settings-stat__value--link:hover, .pt-account-settings-stat__link:hover, .pt-account-settings-inline-link:hover, .pt-account-settings-link-button:hover {
  text-decoration: underline;
}
.pt-account-settings-link-button {
  padding: 0;
  background: transparent;
  border: 0;
  cursor: pointer;
}
.pt-account-settings-link-button--danger {
  color: var(--color-danger);
}
.pt-account-settings-table-wrapper {
  width: 100%;
  overflow-x: auto;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
}
.pt-account-settings-table {
  width: 100%;
  min-width: 42rem;
  border-collapse: collapse;
  font-size: var(--text-sm);
}
.pt-account-settings-table th, .pt-account-settings-table td {
  padding: 0.875rem var(--spacing-md);
  text-align: left;
  vertical-align: top;
  border-bottom: 1px solid var(--color-border);
  overflow-wrap: anywhere;
}
.pt-account-settings-table th {
  color: var(--color-text-secondary);
  background: var(--color-surface-muted);
  font-size: var(--text-xs);
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}
.pt-account-settings-table tbody tr:last-child td, .pt-account-settings-table tfoot tr:last-child td {
  border-bottom: 0;
}
.pt-account-settings-table tfoot td {
  font-weight: 700;
  background: var(--color-surface-muted);
}
.pt-account-settings-empty {
  display: flex;
  align-items: center;
  gap: var(--spacing-sm);
  padding: var(--spacing-lg);
  color: var(--color-text-secondary);
  background: var(--color-surface-muted);
  border: 1px dashed var(--color-border);
  border-radius: var(--radius-lg);
}
.pt-account-settings-empty p {
  margin: 0;
}
.pt-account-settings-status {
  display: inline-flex;
  align-items: center;
  gap: var(--spacing-sm);
  width: fit-content;
  padding: var(--spacing-sm) var(--spacing-md);
  background: var(--color-brand-subtle);
  border-radius: var(--radius-full);
}
.pt-account-settings-status__value {
  color: var(--color-brand);
}
.pt-account-settings-document {
  display: flex;
  align-items: center;
  gap: var(--spacing-sm);
  max-width: 36rem;
  margin-bottom: var(--spacing-sm);
  padding: var(--spacing-md);
  color: var(--color-text-primary);
  background: var(--color-surface-muted);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
}
.pt-account-settings-document__body {
  display: flex;
  flex-direction: column;
  gap: 0.125rem;
  min-width: 0;
  font-size: var(--text-sm);
}
.pt-account-settings-document__body span {
  color: var(--color-text-secondary);
}
.pt-account-settings-copy {
  max-width: 68ch;
  color: var(--color-text-secondary);
  font-size: var(--text-sm);
  line-height: 1.6;
}
.pt-account-settings-copy h3 {
  margin: var(--spacing-lg) 0 var(--spacing-xs);
  color: var(--color-text-primary);
  font-size: var(--text-lg);
}
.pt-account-settings-copy p {
  margin: 0 0 var(--spacing-md);
}
.pt-account-settings-copy ul {
  margin: 0 0 var(--spacing-md);
  padding-left: var(--spacing-xl);
}
.pt-file-input, .pt-textarea {
  display: block;
  width: 100%;
  color: var(--color-text-primary);
  font-size: var(--text-sm);
}
.pt-account-settings .pt-file-upload {
  max-width: 36rem;
}
.pt-account-settings .pt-file-upload__dropzone {
  align-items: flex-start;
  padding: var(--spacing-lg);
  text-align: left;
}
.pt-account-settings .pt-file-upload__icon-svg {
  width: 2rem;
  height: 2rem;
}
.pt-textarea {
  min-height: 8rem;
  padding: 0.625rem 0.75rem;
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
}
.pt-textarea:focus {
  border-color: var(--color-brand);
  outline: none;
  box-shadow: 0 0 0 3px oklch(45% 0.18 250 / 14%);
}
.pt-account-settings-form__hint, .pt-account-settings-muted {
  margin: var(--spacing-xs) 0 0;
  color: var(--color-text-secondary);
  font-size: var(--text-sm);
  line-height: 1.5;
}
.pt-account-settings-setting-row {
  display: grid;
  grid-template-columns: minmax(0, 0.8fr) minmax(16rem, 1fr);
  gap: var(--spacing-xl);
  align-items: start;
}
.pt-account-settings-setting-row__copy h3 {
  margin: 0 0 var(--spacing-xs);
  color: var(--color-text-primary);
  font-size: var(--text-base);
  font-weight: 700;
}
.pt-account-settings-setting-row__copy p {
  margin: 0;
  color: var(--color-text-secondary);
  font-size: var(--text-sm);
  line-height: 1.5;
}
.pt-account-settings-actions {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: var(--spacing-sm);
}
.pt-account-settings-list-toolbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--spacing-md);
  margin-top: var(--spacing-lg);
}
.pt-account-settings-sort-form {
  display: inline-flex;
  align-items: center;
  gap: var(--spacing-sm);
  color: var(--color-text-secondary);
  font-size: var(--text-sm);
}
.pt-account-settings-list-stack {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-md);
}
.pt-account-settings-list-card {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: var(--spacing-lg);
  padding: var(--spacing-lg);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
}
.pt-account-settings-list-card__main {
  min-width: 0;
}
.pt-account-settings-list-card__title {
  margin: 0 0 var(--spacing-xs);
  font-size: var(--text-lg);
  font-weight: 700;
}
.pt-account-settings-list-card__title a {
  color: var(--color-text-primary);
  text-decoration: none;
}
.pt-account-settings-list-card__title a:hover {
  color: var(--color-brand);
}
.pt-account-settings-list-card__meta, .pt-account-settings-list-card__description {
  margin: 0 0 var(--spacing-sm);
  color: var(--color-text-secondary);
  font-size: var(--text-sm);
  line-height: 1.5;
}
.pt-account-settings-list-card__actions {
  display: flex;
  align-items: center;
  gap: var(--spacing-sm);
  flex: 0 0 auto;
}
.pt-account-settings-chip-list, .pt-account-settings-checkbox-grid {
  display: flex;
  flex-wrap: wrap;
  gap: var(--spacing-sm);
}
.pt-account-settings .pt-checkbox-group--inline .pt-checkbox-group__options {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(12rem, 1fr));
  gap: var(--spacing-sm);
}
.pt-account-settings .pt-checkbox-group--inline .pt-checkbox {
  min-width: 0;
}
.pt-account-settings-chip {
  display: inline-flex;
  align-items: center;
  padding: 0.25rem 0.625rem;
  color: var(--color-text-secondary);
  background: var(--color-surface-muted);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-full);
  font-size: var(--text-xs);
  font-weight: 600;
}
.pt-account-settings-checkbox-card {
  display: inline-flex;
  align-items: center;
  gap: var(--spacing-xs);
  padding: 0.5rem 0.75rem;
  color: var(--color-text-primary);
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  font-size: var(--text-sm);
  cursor: pointer;
}
.pt-account-settings-checkbox-card:focus-within {
  border-color: var(--color-brand);
  box-shadow: 0 0 0 3px oklch(45% 0.18 250 / 14%);
}
.pt-account-settings-referral-code {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--spacing-md);
  padding: var(--spacing-lg);
  background: var(--color-surface-muted);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
}
.pt-account-settings-referral-code span {
  color: var(--color-text-secondary);
  font-size: var(--text-sm);
}
.pt-account-settings-referral-code strong {
  color: var(--color-text-primary);
  font-size: var(--text-xl);
  letter-spacing: 0.05em;
}
.pt-account-settings-pagination {
  display: flex;
  justify-content: flex-end;
  margin-top: var(--spacing-lg);
}
.pt-account-settings-table__primary {
  color: var(--color-text-primary);
  font-weight: 600;
}
.pt-account-settings-table__date, .pt-account-settings-table__amount {
  white-space: nowrap;
}
.pt-account-settings-table__amount {
  font-variant-numeric: tabular-nums;
  font-weight: 600;
}
.pt-account-settings-table--users td, .pt-account-settings-table--invoices td {
  vertical-align: middle;
}
.pt-account-settings-row-actions {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: var(--spacing-sm);
  min-width: max-content;
}
.pt-account-settings-licence-summary {
  display: flex;
  align-items: flex-start;
  gap: var(--spacing-sm);
  margin-bottom: var(--spacing-lg);
  padding: var(--spacing-md) var(--spacing-lg);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
}
.pt-account-settings-licence-summary--available {
  background: var(--color-brand-subtle);
  border-color: color-mix(in srgb, oklch(45% 0.18 250) 28%, oklch(88% 0 0));
  @supports (color: color-mix(in lab, red, red)) {
    border-color: color-mix(in oklch, var(--color-brand) 28%, var(--color-border));
  }
}
.pt-account-settings-licence-summary--limit {
  background: var(--color-warning-subtle, var(--color-surface-muted));
  border-color: var(--color-warning, var(--color-border));
}
.pt-account-settings-licence-summary__icon {
  display: inline-flex;
  flex: 0 0 auto;
  margin-top: 0.0625rem;
  color: var(--color-brand);
}
.pt-account-settings-licence-summary--limit .pt-account-settings-licence-summary__icon {
  color: var(--color-warning, var(--color-text-secondary));
}
.pt-account-settings-licence-summary__content {
  display: flex;
  flex-direction: column;
  gap: 0.1875rem;
  min-width: 0;
  color: var(--color-text-primary);
  font-size: var(--text-sm);
  line-height: 1.5;
}
.pt-account-settings-licence-summary__content span {
  color: var(--color-text-secondary);
}
@media (max-width: 40rem) {
  .pt-account-settings-pagination {
    justify-content: stretch;
  }
  .pt-account-settings-pagination > * {
    width: 100%;
  }
  .pt-account-settings-row-actions {
    min-width: 0;
  }
}
.pt-account-settings-pagination {
  display: flex;
  justify-content: flex-end;
  margin-top: var(--spacing-lg);
}
.pt-account-settings-verification-status {
  display: flex;
  align-items: center;
  gap: var(--spacing-sm);
  flex: 0 0 auto;
  padding: 0.5rem 0.75rem;
  background: var(--color-brand-subtle);
  border: 1px solid color-mix(in srgb, oklch(45% 0.18 250) 22%, oklch(88% 0 0));
  @supports (color: color-mix(in lab, red, red)) {
    border: 1px solid color-mix(in oklch, var(--color-brand) 22%, var(--color-border));
  }
  border-radius: var(--radius-lg);
}
.pt-account-settings-verification-status__label {
  color: var(--color-text-secondary);
  font-size: var(--text-xs);
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  white-space: nowrap;
}
.pt-account-settings-verification-guidance {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: var(--spacing-xl);
}
.pt-account-settings-verification-guidance__section {
  min-width: 0;
  padding: var(--spacing-lg);
  background: var(--color-surface-muted);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
}
.pt-account-settings-verification-guidance__title {
  margin: 0 0 var(--spacing-sm);
  color: var(--color-text-primary);
  font-size: var(--text-lg);
  font-weight: 700;
  line-height: 1.35;
}
.pt-account-settings-verification-guidance__intro {
  margin: 0 0 var(--spacing-md);
  color: var(--color-text-secondary);
  font-size: 0.9375rem;
  line-height: 1.65;
}
.pt-account-settings-verification-guidance__list {
  display: flex;
  flex-direction: column;
  gap: 0.625rem;
  margin: 0;
  padding-left: 1.25rem;
  color: var(--color-text-primary);
  font-size: 0.9375rem;
  line-height: 1.6;
}
.pt-account-settings-verification-guidance__list li::marker {
  color: var(--color-brand);
}
.pt-account-settings-verification-guidance__list--emphasized strong, .pt-account-settings-verification-guidance__list--emphasized b, .pt-account-settings-verification-guidance__list--emphasized u {
  color: var(--color-text-primary);
  font-weight: 700;
  text-decoration: none;
}
.pt-account-settings-verification-guidance__list--emphasized a {
  color: inherit;
  font-weight: 700;
  text-decoration: none;
}
.pt-account-settings-verification-guidance__list--emphasized a:hover {
  text-decoration: underline;
}
@media (max-width: 64rem) {
  .pt-account-settings-verification-guidance {
    grid-template-columns: 1fr;
  }
}
@media (max-width: 40rem) {
  .pt-account-settings-verification-status {
    width: 100%;
    justify-content: space-between;
  }
}
.pt-account-settings-account-summary {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: var(--spacing-md);
}
.pt-account-settings-account-summary__card {
  display: flex;
  align-items: flex-start;
  min-width: 0;
  padding: var(--spacing-lg);
  background: var(--color-surface-muted);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  text-align: left;
}
.pt-account-settings-account-summary__card--actionable {
  justify-content: space-between;
  gap: var(--spacing-md);
}
.pt-account-settings-account-summary__content {
  display: flex;
  flex: 1 1 auto;
  flex-direction: column;
  align-items: flex-start;
  min-width: 0;
  text-align: left;
}
.pt-account-settings-account-summary__label {
  color: var(--color-text-secondary);
  font-size: var(--text-xs);
  font-weight: 700;
  letter-spacing: 0.06em;
  line-height: 1.25;
  text-align: left;
  text-transform: uppercase;
}
.pt-account-settings-account-summary__value {
  margin-top: var(--spacing-sm);
  color: var(--color-text-primary);
  font-size: 1.375rem;
  font-weight: 700;
  line-height: 1.25;
  text-align: left;
  white-space: nowrap;
}
.pt-account-settings-account-summary__action {
  display: flex;
  flex: 0 0 auto;
  align-items: flex-start;
  justify-content: flex-end;
  padding-top: 0.0625rem;
}
.pt-account-settings-account-summary__action .pt-btn {
  white-space: nowrap;
}
@media (max-width: 64rem) {
  .pt-account-settings-account-summary {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}
@media (max-width: 40rem) {
  .pt-account-settings-account-summary {
    grid-template-columns: 1fr;
  }
  .pt-account-settings-account-summary__card--actionable {
    align-items: flex-start;
  }
  .pt-account-settings-account-summary__action {
    padding-top: 0;
  }
}
@media (max-width: 64rem) {
  .pt-account-settings__grid {
    grid-template-columns: 1fr;
  }
  .pt-account-settings__sidebar {
    position: static;
  }
  .pt-account-settings__nav {
    flex-direction: row;
    flex-wrap: wrap;
  }
  .pt-account-settings-stats {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .pt-account-settings-setting-row {
    grid-template-columns: 1fr;
  }
}
@media (max-width: 40rem) {
  .pt-account-settings__sidebar {
    padding: var(--spacing-md);
  }
  .pt-account-settings-header__body {
    padding: var(--spacing-lg);
  }
  .pt-account-settings-tabs {
    padding: 0 var(--spacing-lg);
  }
  .pt-account-settings__nav {
    flex-direction: column;
  }
  .pt-account-settings-form__grid {
    grid-template-columns: 1fr;
  }
  .pt-account-settings-form__actions {
    justify-content: stretch;
    flex-direction: column-reverse;
  }
  .pt-account-settings-form__actions .pt-btn {
    width: 100%;
    justify-content: center;
  }
  .pt-account-settings-stats {
    grid-template-columns: 1fr;
  }
  .pt-account-settings-card__header, .pt-account-settings-list-card, .pt-account-settings-referral-code {
    flex-direction: column;
  }
  .pt-account-settings-list-card__actions {
    width: 100%;
    justify-content: flex-start;
  }
}
.pt-company-table__group-header .ag-header-group-cell-label {
  align-items: center;
  justify-content: center;
  color: oklch(27% 0 0);
  font-size: 0.72rem;
  font-weight: 750;
  letter-spacing: 0.08em;
  text-align: center;
  text-transform: uppercase;
}
.pt-company-table__group-header--projects .ag-header-group-cell-label {
  justify-content: center;
}
.pt-company-table__sub-header .ag-header-cell-label, .pt-company-table__sub-header--center .ag-header-cell-label {
  justify-content: center;
  color: oklch(30% 0 0);
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.05em;
  text-align: center;
  text-transform: uppercase;
}
.pt-company-table__sub-header--numeric .ag-header-cell-label {
  justify-content: center;
}
.pt-company-table__cell {
  display: flex;
  align-items: center;
  color: oklch(20% 0 0);
  font-size: 0.835rem;
  line-height: 1.35;
}
.pt-company-table__cell--name {
  font-weight: 650;
}
.pt-company-table__cell--numeric {
  justify-content: flex-end;
  font-variant-numeric: tabular-nums;
}
.pt-company-table-company {
  display: flex;
  align-items: center;
  gap: 0.65rem;
  width: 100%;
  min-width: 0;
}
.pt-company-table-company__avatar {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 2rem;
  width: 2rem;
  height: 2rem;
  border: 1px solid oklch(88% 0 0);
  border-radius: 0.45rem;
  background: oklch(98% 0 0);
  color: oklch(45% 0.16 250);
  font-size: 0.78rem;
  font-weight: 750;
  overflow: hidden;
}
.pt-company-table-company__avatar img {
  display: block;
  width: auto;
  height: auto;
  max-width: 82%;
  max-height: 82%;
  object-fit: contain;
}
.pt-company-table-company__link {
  display: inline-block;
  min-width: 0;
  max-width: 100%;
  color: inherit;
  text-decoration: none;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.pt-company-table-company__link:hover, .pt-ag-grid-container .ag-row:hover .pt-company-table-company__link {
  color: oklch(45% 0.18 250);
  text-decoration: underline;
}
.pt-company-table-chips {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 0.35rem;
  width: 100%;
  min-width: 0;
  max-width: 100%;
  overflow: visible;
}
.pt-company-table-chip {
  box-sizing: border-box;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex: 0 1 auto;
  width: fit-content;
  max-width: 100%;
  min-width: 0;
  padding: 0.22rem 0.6rem;
  border-radius: 999px;
  font-size: 0.74rem;
  line-height: 1.15;
  white-space: normal;
  overflow: visible;
  overflow-wrap: anywhere;
  text-align: center;
  text-overflow: unset;
}
.pt-company-table-chip--activity {
  background: oklch(91% 0.055 250);
  color: oklch(35% 0.18 250);
}
.pt-company-table-chip--office {
  background: oklch(94% 0 0);
  color: oklch(34% 0 0);
  border: 1px solid oklch(88% 0 0);
}
.pt-company-table-chip--more {
  flex: 0 0 auto;
  white-space: nowrap;
  background: oklch(90% 0 0);
  color: oklch(35% 0 0);
  font-weight: 700;
}
.pt-company-table-empty {
  color: oklch(55% 0 0);
}
.pt-company-projects-directory {
  position: relative;
  z-index: 1;
}
.pt-company-projects-directory .pt-table-columns-menu {
  position: relative;
  z-index: 800;
}
.pt-company-projects-directory .pt-table-columns-menu__dropdown, .pt-company-projects-directory .pt-table-columns-menu__menu, .pt-company-projects-directory .pt-table-columns-menu__panel, .pt-company-projects-directory [class*="table-columns-menu"] {
  z-index: 900;
}
.pt-company-projects-chart__menu, .pt-company-projects-directory .pt-ag-donut-chart__menu {
  z-index: 900;
}
.pt-company-projects-directory {
  width: 100%;
}
.pt-company-projects-directory .pt-directory-controls__top {
  align-items: center;
}
.pt-company-projects-directory .pt-directory-refinements__actions {
  align-items: center;
}
.pt-company-projects-directory .pt-table-columns-menu {
  flex: 0 0 auto;
}
.pt-company-projects-directory .pt-project-hits--grid .pt-project-grid {
  grid-template-columns: repeat(auto-fill, minmax(min(100%, 14rem), 1fr));
  gap: 1rem;
}
.pt-company-projects-directory .pt-project-hits--grid .pt-project-card__body {
  padding: 0.85rem 1rem 0.65rem;
  min-height: 7.5rem;
}
.pt-company-projects-directory .pt-project-hits--grid .pt-project-card__footer {
  padding: 0.65rem 1rem 0.85rem;
}
.pt-company-projects-directory .pt-project-hits--grid .pt-project-card__title {
  font-size: 0.98rem;
  line-height: 1.25;
}
.pt-company-projects-directory .pt-project-hits--grid .pt-project-card__meta, .pt-company-projects-directory .pt-project-hits--grid .pt-project-card__dates {
  font-size: 0.8rem;
}
.pt-company-projects-directory .pt-project-hits--grid .pt-metric-pill {
  padding: 0.3rem 0.58rem;
  font-size: 0.72rem;
}
.pt-company-projects-directory .pt-project-blank-view {
  min-height: 28rem;
}
.pt-company-projects-directory .pt-project-blank-view[data-view="map"] {
  height: 65vh;
  min-height: 32rem;
}
.pt-company-projects-directory .pt-project-blank-view[data-view="charts"] {
  height: auto;
  min-height: 0;
}
.pt-company-projects-breakdown {
  display: flex;
  flex-direction: column;
  gap: 1.15rem;
}
.pt-company-projects-breakdown__status {
  margin-bottom: 0.1rem;
  color: var(--pt-color-text-muted, #6b7280);
  font-size: 0.8125rem;
}
.pt-company-projects-breakdown .pt-projects-breakdown__row {
  margin: 0;
}
.pt-company-projects-breakdown .pt-projects-breakdown__row--pies {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1.15rem;
}
.pt-company-projects-breakdown .pt-projects-breakdown__panel {
  overflow: visible;
  border: 1px solid var(--pt-color-border, #d1d5db);
  border-radius: 0.5rem;
  background: #ffffff;
  padding: 1rem 1.1rem 1.05rem;
}
.pt-company-projects-breakdown .pt-projects-breakdown__title {
  margin: 0;
  color: var(--pt-color-text, #111827);
  font-size: 0.95rem;
  font-weight: 700;
  line-height: 1.35;
}
.pt-company-projects-breakdown__panel-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  margin-bottom: 0.85rem;
}
.pt-company-projects-breakdown__controls {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 0.55rem;
  flex-wrap: wrap;
}
.pt-company-projects-breakdown__control {
  display: flex;
  align-items: center;
  gap: 0.35rem;
  color: var(--pt-color-text-muted, #6b7280);
  font-size: 0.78rem;
  line-height: 1.2;
}
.pt-company-projects-breakdown__control label {
  margin: 0;
  color: var(--pt-color-text-muted, #6b7280);
  font-size: 0.78rem;
  font-weight: 400;
  white-space: nowrap;
}
.pt-company-projects-breakdown__control select {
  min-width: 5.25rem;
  min-height: 2rem;
  border: 1px solid var(--pt-color-border, #d1d5db);
  border-radius: 0.25rem;
  background: #ffffff;
  color: var(--pt-color-text, #111827);
  padding: 0 1.75rem 0 0.55rem;
  font-size: 0.8125rem;
  line-height: 1.2;
}
.pt-company-projects-breakdown__control select:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}
.pt-company-projects-breakdown__control--checkbox label {
  display: inline-flex;
  align-items: center;
  gap: 0.3rem;
  color: var(--pt-color-text, #111827);
  font-size: 0.78rem;
}
.pt-company-projects-breakdown__control--checkbox input {
  width: 0.875rem;
  height: 0.875rem;
  margin: 0;
}
.pt-company-projects-chart {
  position: relative;
  width: 100%;
  overflow: visible;
}
.pt-company-projects-chart__canvas {
  width: 100%;
}
.pt-company-projects-chart__table {
  margin-top: 0.75rem;
  overflow: auto;
  max-height: 18rem;
  border: 1px solid var(--pt-color-border, #d1d5db);
  border-radius: 0.35rem;
  background: #ffffff;
}
.pt-company-projects-chart__table table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.78rem;
}
.pt-company-projects-chart__table th, .pt-company-projects-chart__table td {
  border-bottom: 1px solid var(--pt-color-border-subtle, #e5e7eb);
  padding: 0.45rem 0.55rem;
  text-align: left;
  white-space: nowrap;
}
.pt-company-projects-chart__table th {
  background: var(--pt-color-surface-subtle, #f3f4f6);
  color: var(--pt-color-text, #111827);
  font-weight: 700;
}
.pt-company-projects-chart__menu-button {
  position: absolute;
  top: 0.75rem;
  right: 0.75rem;
  z-index: 2;
  width: 1.75rem;
  height: 1.75rem;
  border: 1px solid var(--pt-color-border, #d1d5db);
  border-radius: 0.25rem;
  background: #ffffff;
  color: var(--pt-color-text, #111827);
  line-height: 1;
  cursor: pointer;
}
.pt-company-projects-chart__menu-button:hover {
  background: var(--pt-color-surface-subtle, #f3f4f6);
}
.pt-company-projects-chart__menu {
  position: fixed;
  z-index: 900;
  min-width: 13.25rem;
  border: 1px solid var(--pt-color-border, #d1d5db);
  border-radius: 0.25rem;
  background: #ffffff;
  box-shadow: 0 0.5rem 1.5rem rgba(15, 23, 42, 0.16);
  padding: 0.35rem 0;
}
.pt-company-projects-chart__menu-separator {
  height: 1px;
  margin: 0.35rem 0;
  background: var(--pt-color-border-subtle, #e5e7eb);
}
.pt-company-projects-chart__menu-item {
  display: block;
  width: 100%;
  border: 0;
  background: transparent;
  padding: 0.42rem 0.75rem;
  color: var(--pt-color-text, #111827);
  text-align: left;
  font-size: 0.78rem;
  line-height: 1.25;
  cursor: pointer;
}
.pt-company-projects-chart__menu-item:hover {
  background: var(--pt-color-surface-subtle, #f3f4f6);
}
.pt-company-projects-directory .pt-project-blank-view > .pt-map-viewer, .pt-company-projects-directory .pt-project-blank-view > .pt-company-projects-breakdown {
  width: 100%;
}
.pt-company-projects-directory .pt-project-blank-view[data-view="map"] > .pt-map-viewer {
  display: block;
}
.pt-company-projects-directory .pt-project-blank-view[data-view="map"] > .pt-company-projects-breakdown {
  display: none !important;
}
.pt-company-projects-directory .pt-project-blank-view[data-view="charts"] > .pt-map-viewer {
  display: none !important;
}
.pt-company-projects-directory .pt-project-blank-view[data-view="charts"] > .pt-company-projects-breakdown {
  display: flex;
}
.pt-company-projects-directory .pt-project-blank-view:not([data-view="map"]):not([data-view="charts"]) > .pt-map-viewer, .pt-company-projects-directory .pt-project-blank-view:not([data-view="map"]):not([data-view="charts"]) > .pt-company-projects-breakdown {
  display: none !important;
}
@media (max-width: 1500px) {
  .pt-company-projects-directory .pt-project-hits--grid .pt-project-grid {
    grid-template-columns: repeat(auto-fill, minmax(min(100%, 14rem), 1fr));
  }
}
@media (max-width: 1200px) {
  .pt-company-projects-directory .pt-project-hits--grid .pt-project-grid {
    grid-template-columns: repeat(auto-fill, minmax(min(100%, 14rem), 1fr));
  }
  .pt-company-projects-breakdown .pt-projects-breakdown__row--pies {
    grid-template-columns: 1fr;
  }
  .pt-company-projects-breakdown__panel-header {
    align-items: flex-start;
    flex-direction: column;
  }
  .pt-company-projects-breakdown__controls {
    justify-content: flex-start;
  }
}
@media (max-width: 900px) {
  .pt-company-projects-directory .pt-directory-controls__top {
    align-items: flex-start;
  }
  .pt-company-projects-directory .pt-directory-refinements__actions {
    margin-left: 0;
  }
  .pt-company-projects-directory .pt-project-hits--grid .pt-project-grid {
    grid-template-columns: repeat(auto-fill, minmax(min(100%, 14rem), 1fr));
  }
  .pt-company-projects-directory .pt-project-blank-view[data-view="map"] {
    height: 28rem;
    min-height: 28rem;
  }
}
.pt-company-hero {
  position: relative;
  background: var(--color-surface);
}
.pt-company-hero__banner {
  height: 180px;
  background: radial-gradient(125% 130% at 12% -15%, rgba(255, 255, 255, 0.16), rgba(255, 255, 255, 0) 55%), repeating-linear-gradient(135deg, rgba(255, 255, 255, 0.05) 0, rgba(255, 255, 255, 0.05) 2px, transparent 2px, transparent 24px), linear-gradient(135deg, var(--color-brand-hover) 0%, var(--color-brand-dark) 100%);
  background-size: cover;
  background-position: center;
}
.pt-company-hero__identity {
  display: flex;
  align-items: flex-start;
  gap: 1rem;
  padding: 0 1.5rem 1.25rem;
  margin-top: -44px;
}
.pt-company-hero__logo-wrap {
  flex-shrink: 0;
}
.pt-company-hero__logo {
  height: 88px;
  width: auto;
  max-width: 220px;
  min-width: 88px;
  box-sizing: border-box;
  padding: 0.3rem;
  border-radius: 0.75rem;
  border: 3px solid var(--color-surface);
  background: var(--color-surface);
  object-fit: contain;
  box-shadow: 0 2px 8px rgba(0,0,0,0.12);
  display: block;
}
.pt-company-hero__logo-placeholder {
  width: 88px;
  height: 88px;
  border-radius: 0.75rem;
  border: 3px solid var(--color-surface);
  background: var(--color-brand-hover);
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 2px 8px rgba(0,0,0,0.12);
}
.pt-company-hero__logo-initials {
  font-size: 1.375rem;
  font-weight: 700;
  color: var(--color-surface);
  letter-spacing: 0.05em;
}
.pt-company-hero__meta {
  flex: 1;
  padding-top: 2.75rem;
  min-width: 0;
}
.pt-company-hero__name {
  font-size: 1.35rem;
  font-weight: 700;
  color: var(--color-text-primary);
  margin: 0 0 0.2rem;
  line-height: 1.3;
}
.pt-company-hero__category {
  font-size: 0.82rem;
  color: var(--color-text-secondary);
  margin: 0 0 0.4rem;
  text-transform: capitalize;
}
.pt-company-hero__details {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
  align-items: center;
}
.pt-company-hero__detail-item {
  display: flex;
  align-items: center;
  gap: 0.25rem;
  font-size: 0.78rem;
  color: var(--color-text-secondary);
}
.pt-company-hero__detail-item a {
  color: var(--color-text-secondary);
  text-decoration: none;
}
.pt-company-hero__detail-item a:hover {
  color: var(--color-brand);
}
.pt-company-hero__detail-icon {
  width: 0.875rem;
  height: 0.875rem;
  flex-shrink: 0;
  opacity: 0.7;
}
.pt-company-hero__actions {
  position: absolute;
  top: 1.35rem;
  right: 1.75rem;
  z-index: 3;
  display: flex;
  width: min(34rem, calc(100% - 3.5rem));
  align-items: center;
  justify-content: flex-end;
  align-content: flex-start;
  gap: 0.55rem;
  flex-wrap: wrap;
  padding-top: 0;
}
.pt-company-hero__actions > [hidden], .pt-company-hero__actions > .hidden, .pt-company-hero__actions > .is-hidden, .pt-company-hero__actions > [aria-hidden="true"] {
  display: none !important;
}
.pt-company-hero__actions .pt-company-tags {
  order: 10;
}
.pt-company-hero__actions .pt-btn, .pt-company-hero__actions .pt-company-tags {
  flex: 0 0 auto;
  min-height: 2.25rem;
  padding: 0.48rem 0.9rem;
  border: 1px solid rgba(209, 213, 219, 0.9);
  border-radius: 0.45rem;
  background: rgba(255, 255, 255, 0.94);
  color: var(--color-text-primary);
  box-shadow: 0 8px 22px rgba(15, 23, 42, 0.18);
  backdrop-filter: blur(8px);
  font-size: 0.84rem;
  font-weight: 700;
  white-space: nowrap;
}
.pt-company-hero__actions .pt-btn--primary, .pt-company-hero__actions .pt-btn--outline, .pt-company-hero__actions .pt-btn--ghost, .pt-company-hero__actions .pt-company-tags {
  background: rgba(255, 255, 255, 0.94);
  color: var(--color-text-primary);
  border-color: rgba(209, 213, 219, 0.9);
}
.pt-company-hero__actions .pt-btn:hover, .pt-company-hero__actions .pt-btn:focus-visible, .pt-company-hero__actions .pt-company-tags:hover, .pt-company-hero__actions .pt-company-tags:focus-visible {
  background: #ffffff;
  border-color: var(--color-brand);
  color: var(--color-brand);
  text-decoration: none;
}
.pt-company-hero__actions .pt-btn__icon, .pt-company-hero__actions .pt-company-tags__icon {
  width: 0.95rem;
  height: 0.95rem;
  color: currentColor;
}
.pt-company-hero__actions .pt-company-tags {
  min-width: 122px;
}
.pt-company-tags {
  display: inline-flex;
  align-items: center;
  gap: 0.375rem;
  padding: 0.375rem 0.75rem;
  border-radius: 0.5rem;
  border: 1.5px solid var(--color-border);
  font-size: 0.8125rem;
  font-weight: 500;
  color: var(--color-text-primary);
  background: transparent;
  cursor: pointer;
  position: relative;
  min-width: 110px;
}
.pt-company-tags:hover {
  background: var(--color-surface-2);
  border-color: var(--color-text-muted);
}
.pt-company-tags__icon {
  width: 0.875rem;
  height: 0.875rem;
  flex-shrink: 0;
  color: var(--color-text-secondary);
}
.pt-company-tags__label {
  font-size: 0.8125rem;
  font-weight: 500;
}
.pt-company-tags input.tags {
  position: absolute;
  opacity: 0;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  cursor: pointer;
}
.pt-company-tabs {
  background: var(--color-surface);
  border-bottom: 1px solid var(--color-border);
  padding: 0 1.5rem;
}
.pt-company-tabs__nav {
  display: flex;
  overflow-x: auto;
  -ms-overflow-style: none;
  scrollbar-width: none;
}
.pt-company-tabs__nav::-webkit-scrollbar {
  display: none;
}
.pt-company-tab {
  display: inline-flex;
  align-items: center;
  gap: 0.375rem;
  padding: 0.75rem 1rem;
  font-size: 0.8125rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--pt-text-secondary, var(--color-text-secondary));
  text-decoration: none;
  border-bottom: 2px solid transparent;
  white-space: nowrap;
  transition: color 0.15s ease, border-color 0.15s ease;
}
.pt-company-tab:hover {
  color: var(--pt-text-primary, var(--color-text-primary));
  text-decoration: none;
}
.pt-company-tab--active {
  color: var(--pt-primary, var(--color-brand));
  border-bottom-color: var(--pt-primary, var(--color-brand));
}
.pt-company-tab__icon {
  width: 1rem;
  height: 1rem;
  flex-shrink: 0;
}
.pt-company-tab__count {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 1.25rem;
  height: 1.25rem;
  padding: 0 0.25rem;
  border-radius: 9999px;
  font-size: 0.6875rem;
  font-weight: 700;
  background: var(--color-border);
  color: var(--color-text-secondary);
  margin-left: 0.25rem;
  line-height: 1;
}
.pt-company-tab--active .pt-company-tab__count {
  background: var(--color-brand-subtle);
  color: var(--pt-primary, var(--color-brand));
}
.pt-btn--ghost {
  background: transparent;
  border: 1.5px solid rgba(255,255,255,0.5);
  color: var(--color-text-primary);
  cursor: pointer;
  border-color: var(--color-border);
}
.pt-btn--ghost:hover {
  background: var(--color-surface-2);
  border-color: var(--color-text-muted);
  text-decoration: none;
  color: var(--color-text-primary);
}
.pt-company-content {
  padding: 1.5rem;
  background: var(--color-surface-2);
  min-height: 400px;
}
.pt-company-profile-body {
  display: grid;
  grid-template-columns: 1fr 320px;
  gap: 1.25rem;
  align-items: start;
  max-width: 1280px;
}
@media (max-width: 900px) {
  .pt-company-profile-body {
    grid-template-columns: 1fr;
  }
  .pt-company-sidebar {
    order: -1;
  }
}
.pt-company-section {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: 0.625rem;
  overflow: hidden;
  margin-bottom: 1.25rem;
}
.pt-company-main .pt-company-section:last-child, .pt-company-sidebar .pt-company-section:last-child {
  margin-bottom: 0;
}
.pt-company-section__header {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.625rem 1rem;
  background: var(--color-surface-2);
  border-bottom: 1px solid var(--color-border);
}
.pt-company-section__icon {
  width: 1rem;
  height: 1rem;
  color: var(--color-brand);
  flex-shrink: 0;
}
.pt-company-section__title {
  font-size: 0.7rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.07em;
  color: var(--color-text-secondary);
  margin: 0;
}
.pt-company-section__body {
  padding: 1rem;
}
.pt-company-description {
  font-size: 0.9rem;
  color: var(--color-text-primary);
  line-height: 1.75;
}
.pt-company-description p {
  margin: 0 0 0.75em;
}
.pt-company-description p:last-child {
  margin-bottom: 0;
}
.pt-company-activities__group {
  margin-bottom: 1rem;
}
.pt-company-activities__group:last-child {
  margin-bottom: 0;
}
.pt-company-activities__issuer {
  font-size: 0.7rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--color-text-secondary);
  margin: 0 0 0.5rem;
}
.pt-company-activities__list {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
}
.pt-company-activity-chip {
  display: inline-flex;
  align-items: center;
  gap: 0.375rem;
  padding: 0.25rem 0.625rem;
  background: var(--color-brand-subtle);
  border: 1px solid var(--color-brand-subtle);
  border-radius: 999px;
  font-size: 0.76rem;
}
.pt-company-activity-chip__name {
  color: var(--color-brand-hover);
  font-weight: 500;
}
.pt-company-activity-chip__count {
  color: var(--color-brand);
  font-weight: 700;
  font-size: 0.7rem;
}
.pt-company-cert-list {
  display: flex;
  flex-direction: column;
  gap: 0.625rem;
}
.pt-company-cert-card {
  padding: 0.625rem 0.75rem;
  background: var(--color-surface-2);
  border: 1px solid var(--color-border);
  border-radius: 0.5rem;
  border-left: 3px solid var(--color-brand);
}
.pt-company-cert-card__title {
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--color-text-primary);
  margin-bottom: 0.2rem;
}
.pt-company-cert-card__meta {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem 1rem;
  font-size: 0.75rem;
  color: var(--color-text-secondary);
  margin-top: 0.1rem;
}
.pt-company-cert-card__issuer a {
  color: var(--color-brand);
  text-decoration: none;
}
.pt-company-cert-card__issuer a:hover {
  text-decoration: underline;
}
.pt-company-award-list {
  display: flex;
  flex-direction: column;
  gap: 0.625rem;
}
.pt-company-award-card {
  display: flex;
  align-items: center;
  gap: 1rem;
  padding: 0.625rem 0.75rem;
  background: var(--color-warning-subtle);
  border: 1px solid var(--color-warning-subtle);
  border-radius: 0.5rem;
  border-left: 3px solid var(--color-warning);
}
.pt-company-award-card__name {
  flex: 1;
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--color-text-primary);
}
.pt-company-award-card__meta {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 2px;
  font-size: 0.75rem;
  color: var(--color-text-secondary);
  white-space: nowrap;
}
.pt-company-office-list {
  display: flex;
  flex-direction: column;
  gap: 0;
}
.pt-company-office-item {
  padding: 0.75rem 0;
  border-bottom: 1px solid var(--color-surface-2);
}
.pt-company-office-item:first-child {
  padding-top: 0;
}
.pt-company-office-item:last-child {
  padding-bottom: 0;
  border-bottom: none;
}
.pt-company-office-item p {
  margin: 0 0 2px;
  font-size: 0.8rem;
  color: var(--color-text-secondary);
}
.pt-company-office-item__location strong {
  color: var(--color-text-primary);
  font-size: 0.85rem;
}
.pt-company-office-item__website a {
  color: var(--color-brand);
  text-decoration: none;
  font-size: 0.78rem;
  word-break: break-all;
}
.pt-company-office-item__website a:hover {
  text-decoration: underline;
}
.pt-company-empty-state {
  font-size: 0.85rem;
  color: var(--color-text-muted);
  font-style: italic;
  margin: 0;
}
.pt-company-profile {
  background: var(--color-surface-2);
  min-height: 100vh;
}
.pt-company-hero .pt-tag-popup {
  z-index: 30;
}
.pt-company-content {
  padding: 1.5rem;
}
.pt-company-profile-body {
  display: flex;
  flex-direction: column;
  gap: 1.25rem;
  width: 100%;
  max-width: none;
  margin: 0;
  min-width: 0;
}
.pt-company-section {
  border-radius: 1rem;
  box-shadow: 0 12px 30px oklch(0% 0 0 / 5%);
  margin-bottom: 0;
}
.pt-company-section__header {
  justify-content: flex-start;
  background: linear-gradient(180deg, oklch(99% 0 0), oklch(97% 0.004 250));
  padding: 0.85rem 1rem;
}
.pt-company-section__header--with-action {
  justify-content: space-between;
  gap: 1rem;
}
.pt-company-section__heading {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  min-width: 0;
  margin-right: auto;
}
.pt-company-section__title {
  font-size: 0.78rem;
  letter-spacing: 0.08em;
}
.pt-company-section__body {
  padding: 1.1rem;
}
.pt-company-section__body--flush-mobile {
  padding: 0;
}
.pt-company-empty-state--compact {
  font-size: 0.78rem;
}
.pt-company-activities-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1rem;
}
.pt-company-activity-column {
  border: 1px solid var(--color-border);
  border-radius: 0.85rem;
  padding: 1rem;
  background: oklch(99% 0.003 250);
}
.pt-company-activity-column__title {
  margin: 0 0 0.75rem;
  font-size: 0.78rem;
  font-weight: 800;
  letter-spacing: 0.07em;
  text-transform: uppercase;
  color: var(--color-text-secondary);
}
.pt-company-activity-column__title a, .pt-company-activity-list__count {
  color: var(--color-brand);
  text-decoration: none;
}
.pt-company-activity-column__title a:hover, .pt-company-activity-list__count:hover, .pt-company-activity-list__count:focus-visible {
  text-decoration: underline;
}
.pt-company-activity-list {
  display: grid;
  gap: 0.55rem;
  margin: 0;
  padding: 0;
  list-style: none;
}
.pt-company-activity-list__item {
  display: flex;
  flex-wrap: wrap;
  gap: 0.35rem;
  align-items: baseline;
  color: var(--color-text-primary);
  font-size: 0.9rem;
}
.pt-company-activity-list__count::before {
  content: "[";
}
.pt-company-activity-list__count::after {
  content: "]";
}
.pt-company-cert-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.85rem;
}
.pt-company-cert-card {
  display: flex;
  gap: 0.75rem;
  padding: 0.95rem;
  border-radius: 0.9rem;
  background: oklch(99% 0.003 250);
  border: 1px solid var(--color-border);
  border-left: 4px solid var(--color-brand);
}
.pt-company-cert-card__icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 2.25rem;
  height: 2.25rem;
  flex: 0 0 auto;
  border-radius: 0.7rem;
  color: var(--color-brand);
  background: var(--color-brand-subtle);
}
.pt-company-cert-card__icon-svg {
  width: 1.15rem;
  height: 1.15rem;
}
.pt-company-cert-card__content {
  min-width: 0;
}
.pt-company-cert-card__title {
  margin: 0 0 0.35rem;
  font-size: 0.95rem;
  font-weight: 750;
  color: var(--color-text-primary);
}
.pt-company-cert-card__meta {
  margin: 0.15rem 0 0;
  font-size: 0.8rem;
  color: var(--color-text-secondary);
}
.pt-company-cert-card__label {
  font-weight: 700;
  color: var(--color-text-primary);
}
.pt-company-awards-table-wrap {
  width: 100%;
  overflow-x: auto;
}
.pt-company-awards-table {
  width: 100%;
  min-width: 680px;
  border-collapse: collapse;
  font-size: 0.86rem;
}
.pt-company-awards-table th {
  padding: 0.8rem 1rem;
  text-align: left;
  color: var(--color-text-secondary);
  background: oklch(97% 0.004 250);
  font-size: 0.72rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}
.pt-company-awards-table td {
  padding: 0.85rem 1rem;
  border-top: 1px solid var(--color-border);
  color: var(--color-text-secondary);
  vertical-align: top;
}
.pt-company-awards-table__name, .pt-company-awards-table__name a {
  font-weight: 700;
  color: var(--color-text-primary);
}
.pt-company-awards-table__name a {
  color: var(--color-brand);
  text-decoration: none;
}
.pt-company-awards-table__name a:hover, .pt-company-awards-table__name a:focus-visible {
  text-decoration: underline;
}
.pt-company-office-selector {
  display: flex;
  align-items: center;
  gap: 0.5rem;
}
.pt-company-office-selector__label {
  font-size: 0.72rem;
  font-weight: 700;
  color: var(--color-text-secondary);
  text-transform: uppercase;
  letter-spacing: 0.06em;
}
.pt-company-office-selector__select {
  min-width: 14rem;
  border: 1px solid var(--color-border);
  border-radius: 0.55rem;
  background: var(--color-surface);
  padding: 0.45rem 0.7rem;
  color: var(--color-text-primary);
  font: inherit;
  font-size: 0.85rem;
}
.pt-company-office-panel {
  display: grid;
  grid-template-columns: minmax(18rem, 0.7fr) minmax(28rem, 1.55fr);
  gap: 1rem;
  align-items: stretch;
}
.pt-company-office-panel[hidden] {
  display: none;
}
.pt-company-office-panel__details {
  border: 1px solid var(--color-border);
  border-radius: 0.9rem;
  padding: 1rem;
  background: oklch(99% 0.003 250);
}
.pt-company-office-panel__title {
  margin: 0 0 0.85rem;
  color: var(--color-text-primary);
  font-size: 1rem;
  font-weight: 800;
}
.pt-company-office-detail {
  display: grid;
  grid-template-columns: 1.25rem minmax(0, 1fr);
  gap: 0.55rem;
  margin-top: 0.65rem;
  color: var(--color-text-secondary);
  font-size: 0.86rem;
}
.pt-company-office-detail__icon {
  width: 1rem;
  height: 1rem;
  margin-top: 0.1rem;
  color: var(--color-brand);
}
.pt-company-office-detail__content {
  display: grid;
  gap: 0.18rem;
  font-style: normal;
}
.pt-company-office-detail__link {
  color: var(--color-brand);
  text-decoration: none;
  word-break: break-word;
}
.pt-company-office-detail__link:hover, .pt-company-office-detail__link:focus-visible {
  text-decoration: underline;
}
.pt-company-office-panel__map .pt-map-viewer {
  min-height: 420px;
}
.pt-company-office-map-placeholder {
  display: flex;
  min-height: 420px;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  border: 1px dashed var(--color-border);
  border-radius: 0.9rem;
  background: oklch(97% 0.004 250);
  color: var(--color-text-muted);
  text-align: center;
}
.pt-company-office-map-placeholder__icon {
  width: 2rem;
  height: 2rem;
}
@media (max-width: 900px) {
  .pt-company-hero__identity {
    flex-direction: column;
  }
  .pt-company-hero__actions {
    top: 1rem;
    left: 1rem;
    right: 1rem;
    width: auto;
    justify-content: flex-start;
  }
  .pt-company-activities-grid, .pt-company-cert-grid, .pt-company-office-panel {
    grid-template-columns: 1fr;
  }
  .pt-company-section__header--with-action {
    align-items: flex-start;
    flex-direction: column;
  }
  .pt-company-office-selector {
    width: 100%;
    align-items: stretch;
    flex-direction: column;
  }
  .pt-company-office-selector__select {
    width: 100%;
  }
}
@media (max-width: 640px) {
  .pt-company-content {
    padding: 1rem;
  }
  .pt-company-hero__identity, .pt-company-tabs {
    padding-left: 1rem;
    padding-right: 1rem;
  }
  .pt-company-cert-card {
    flex-direction: column;
  }
}
.pt-company-profile__sticky-header {
  position: sticky;
  top: 0;
  z-index: 25;
  background: var(--color-surface);
  box-shadow: 0 2px 12px oklch(0% 0 0 / 8%);
}
.pt-company-content {
  padding: 1.5rem;
}
.pt-company-profile-body {
  width: 100%;
  max-width: none;
  margin: 0;
}
.pt-company-profile-body > .pt-company-section {
  width: 100%;
  box-sizing: border-box;
}
.pt-company-section {
  width: 100%;
  border-radius: 0.25rem;
  box-shadow: 0 6px 16px oklch(0% 0 0 / 4%);
}
.pt-company-section__header {
  border-radius: 0;
  justify-content: flex-start;
}
.pt-company-section__title {
  text-align: left;
}
.pt-company-section__body {
  min-height: 4rem;
}
.pt-company-activities-grid, .pt-company-cert-grid, .pt-company-office-panel {
  width: 100%;
}
.pt-company-activity-column, .pt-company-cert-card, .pt-company-office-panel__details, .pt-company-office-panel__map, .pt-company-office-map-placeholder {
  border-radius: 0.25rem;
}
.pt-company-cert-card {
  align-items: flex-start;
}
.pt-company-cert-card__icon {
  margin-top: 0.20rem;
}
.pt-company-activity-list {
  list-style: disc;
  padding-left: 1.15rem;
}
.pt-company-activity-list__item {
  display: list-item;
  padding-left: 0.15rem;
}
.pt-company-activity-list__item::marker {
  color: var(--color-text-secondary);
}
.pt-company-cert-card {
  border-left-color: var(--color-border);
}
.pt-company-cert-card__link {
  color: var(--color-brand);
  text-decoration: none;
}
.pt-company-cert-card__link:hover, .pt-company-cert-card__link:focus-visible {
  text-decoration: underline;
}
.pt-company-awards-table tbody tr {
  transition: background-color 0.15s ease, color 0.15s ease;
}
.pt-company-awards-table tbody tr:hover {
  background: var(--color-brand-subtle);
}
.pt-company-awards-table tbody tr:hover td {
  color: var(--color-text-primary);
}
.pt-company-awards-table tbody tr:hover .pt-company-awards-table__name, .pt-company-awards-table tbody tr:hover .pt-company-awards-table__name a {
  color: var(--color-brand);
}
.pt-company-office-selector__select-wrap {
  position: relative;
  min-width: 18rem;
}
.pt-company-office-selector__select-wrap::after {
  content: "";
  position: absolute;
  right: 0.85rem;
  top: 50%;
  width: 0.45rem;
  height: 0.45rem;
  border-right: 1.5px solid var(--color-text-secondary);
  border-bottom: 1.5px solid var(--color-text-secondary);
  transform: translateY(-65%) rotate(45deg);
  pointer-events: none;
}
.pt-company-office-selector__select {
  width: 100%;
  padding-right: 2.25rem;
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
}
.pt-company-office-panel {
  grid-template-columns: minmax(18rem, 0.45fr) minmax(38rem, 1.55fr);
}
.pt-company-office-panel__map {
  min-height: 460px;
  overflow: hidden;
  border: 1px solid var(--color-border);
  background: var(--color-surface);
}
.pt-company-office-panel__map .pt-map-viewer, .pt-company-office-panel__map .leaflet-container {
  width: 100%;
  height: 460px !important;
  min-height: 460px;
  display: block;
}
.pt-company-office-panel__map .leaflet-container {
  border-radius: 0;
}
.pt-company-office-panel__map .leaflet-control-attribution {
  margin-bottom: 0;
}
.pt-company-office-map-placeholder {
  min-height: 460px;
}
@media (max-width: 900px) {
  .pt-company-profile__sticky-header {
    position: relative;
    top: auto;
    z-index: auto;
  }
  .pt-company-office-panel {
    grid-template-columns: 1fr;
  }
  .pt-company-office-selector__select-wrap {
    min-width: 100%;
    width: 100%;
  }
}
.pt-company-profile__sticky-header {
  position: sticky;
  top: 0;
  z-index: 10000;
  background: var(--color-surface);
  box-shadow: 0 2px 12px oklch(0% 0 0 / 8%);
}
.pt-company-profile__sticky-header .pt-company-hero {
  position: relative;
  z-index: 10001;
  min-height: 300px;
  overflow: hidden;
  background: var(--color-brand-dark);
}
.pt-company-hero__banner {
  position: absolute;
  inset: 0;
  z-index: 0;
  height: 100%;
  background: radial-gradient(125% 130% at 12% -15%, rgba(255, 255, 255, 0.14), rgba(255, 255, 255, 0) 55%), repeating-linear-gradient(135deg, rgba(255, 255, 255, 0.035) 0, rgba(255, 255, 255, 0.035) 2px, transparent 2px, transparent 24px), linear-gradient(135deg, var(--color-brand-hover) 0%, var(--color-brand-dark) 100%);
  background-size: cover;
  background-position: center;
}
.pt-company-profile__sticky-header .pt-company-hero::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 1;
  background: linear-gradient(180deg, rgba(15, 23, 42, 0.04) 0%, rgba(15, 23, 42, 0.10) 45%, rgba(15, 23, 42, 0.34) 100%), linear-gradient(90deg, rgba(15, 23, 42, 0.18) 0%, rgba(15, 23, 42, 0.04) 55%, rgba(15, 23, 42, 0.14) 100%);
  pointer-events: none;
}
.pt-company-hero__identity {
  position: relative;
  z-index: 2;
  display: flex;
  align-items: flex-end;
  gap: 1.15rem;
  min-height: 300px;
  width: 100%;
  box-sizing: border-box;
  padding: 1.5rem 1.75rem 2rem;
  margin-top: 0;
}
.pt-company-hero__logo-wrap {
  flex: 0 0 auto;
  align-self: flex-end;
}
.pt-company-hero__logo, .pt-company-hero__logo-placeholder {
  height: 118px;
  border-radius: 999px;
  border: 4px solid rgba(255, 255, 255, 0.98);
  background: rgba(255, 255, 255, 0.98);
  box-shadow: 0 12px 28px rgba(15, 23, 42, 0.24);
}
.pt-company-hero__logo-placeholder {
  width: 118px;
}
.pt-company-hero__logo {
  width: 118px;
  max-width: 118px;
  min-width: 118px;
  padding: 0.7rem;
  object-fit: contain;
}
.pt-company-hero__logo-initials {
  font-size: 1.75rem;
  color: var(--color-brand-dark);
}
.pt-company-hero__meta {
  flex: 1 1 auto;
  min-width: 0;
  max-width: calc(100% - 640px);
  padding: 0;
  background: transparent;
  border: 0;
  box-shadow: none;
  backdrop-filter: none;
}
.pt-company-hero__name {
  display: inline-flex;
  width: fit-content;
  max-width: 100%;
  margin: 0 0 0.35rem;
  padding: 0.42rem 0.72rem;
  border-radius: 0.35rem;
  background: rgba(255, 255, 255, 0.92);
  color: var(--color-text-primary);
  box-shadow: 0 8px 20px rgba(15, 23, 42, 0.16);
  font-size: 1.45rem;
  font-weight: 800;
  line-height: 1.18;
}
.pt-company-hero__category {
  display: flex;
  width: fit-content;
  max-width: 100%;
  margin: 0 0 0.45rem;
  padding: 0.28rem 0.62rem;
  border-radius: 0.3rem;
  background: rgba(255, 255, 255, 0.88);
  color: var(--color-text-secondary);
  box-shadow: 0 6px 16px rgba(15, 23, 42, 0.12);
  font-size: 0.84rem;
  font-weight: 600;
  text-transform: capitalize;
}
.pt-company-hero__details {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.4rem;
}
.pt-company-hero__detail-item {
  display: inline-flex;
  align-items: center;
  gap: 0.3rem;
  width: fit-content;
  max-width: 100%;
  padding: 0.28rem 0.58rem;
  border-radius: 0.3rem;
  background: rgba(255, 255, 255, 0.86);
  color: var(--color-text-secondary);
  box-shadow: 0 6px 16px rgba(15, 23, 42, 0.10);
  font-size: 0.8rem;
  line-height: 1.35;
}
.pt-company-hero__detail-item a {
  color: var(--color-text-secondary);
  text-decoration: none;
}
.pt-company-hero__detail-item a:hover, .pt-company-hero__detail-item a:focus-visible {
  color: var(--color-brand);
  text-decoration: underline;
}
.pt-company-hero__detail-icon {
  width: 0.86rem;
  height: 0.86rem;
  color: var(--color-text-secondary);
  opacity: 0.75;
}
.pt-company-profile__sticky-header .pt-company-tabs {
  position: relative;
  z-index: 10001;
  background: #ffffff;
  border-top: 1px solid rgba(229, 231, 235, 0.9);
  border-bottom: 1px solid var(--color-border);
  padding: 0 1.75rem;
  box-shadow: 0 1px 0 rgba(15, 23, 42, 0.04);
}
.pt-company-tab {
  padding-top: 0.9rem;
  padding-bottom: 0.9rem;
}
.pt-company-tab--active {
  color: var(--pt-primary, var(--color-brand));
  border-bottom-color: var(--pt-primary, var(--color-brand));
}
@media (max-width: 1420px) {
  .pt-company-hero__meta {
    max-width: calc(100% - 540px);
  }
  .pt-company-hero__actions {
    grid-template-columns: repeat(2, max-content);
  }
  .pt-company-hero__actions .pt-company-tags {
    grid-column: 1;
    grid-row: 1;
  }
  .pt-company-hero__actions .pt-btn:nth-child(1) {
    grid-column: 2;
    grid-row: 1;
  }
  .pt-company-hero__actions .pt-btn:nth-child(2) {
    grid-column: 1;
    grid-row: 2;
  }
  .pt-company-hero__actions .pt-btn:nth-child(3) {
    grid-column: 2;
    grid-row: 2;
  }
  .pt-company-hero__actions .pt-btn:nth-child(4) {
    grid-column: 1 / span 2;
    grid-row: 3;
    justify-content: center;
  }
}
@media (max-width: 1200px) {
  .pt-company-profile__sticky-header .pt-company-hero {
    min-height: 360px;
  }
  .pt-company-hero__identity {
    align-items: flex-end;
    padding-top: 4.5rem;
  }
  .pt-company-hero__meta {
    max-width: calc(100% - 160px);
  }
  .pt-company-hero__actions {
    left: auto;
    right: 1.75rem;
    width: min(34rem, calc(100% - 3.5rem));
    justify-content: flex-end;
  }
}
@media (max-width: 900px) {
  .pt-company-profile__sticky-header {
    position: relative;
    top: auto;
    z-index: 10000;
  }
  .pt-company-profile__sticky-header .pt-company-hero {
    min-height: 480px;
  }
  .pt-company-hero__identity {
    flex-direction: column;
    align-items: flex-start;
    justify-content: flex-end;
    min-height: 480px;
    gap: 0.9rem;
    padding: 7.75rem 1rem 1.25rem;
  }
  .pt-company-hero__actions {
    top: 1rem;
    left: 1rem;
    right: 1rem;
    grid-template-columns: repeat(2, max-content);
    justify-content: start;
  }
  .pt-company-hero__logo, .pt-company-hero__logo-placeholder {
    height: 104px;
  }
  .pt-company-hero__logo-placeholder, .pt-company-hero__logo {
    width: 104px;
    max-width: 104px;
    min-width: 104px;
  }
  .pt-company-hero__meta {
    width: 100%;
    max-width: none;
    box-sizing: border-box;
  }
  .pt-company-hero__name {
    font-size: 1.28rem;
  }
  .pt-company-profile__sticky-header .pt-company-tabs {
    padding-left: 1rem;
    padding-right: 1rem;
  }
}
@media (max-width: 640px) {
  .pt-company-profile__sticky-header .pt-company-hero {
    min-height: 540px;
  }
  .pt-company-hero__identity {
    min-height: 540px;
    padding-top: 9.5rem;
  }
  .pt-company-hero__actions {
    gap: 0.4rem;
  }
  .pt-company-hero__actions .pt-btn, .pt-company-tags {
    min-height: 2.05rem;
    padding: 0.42rem 0.66rem;
    font-size: 0.76rem;
  }
  .pt-company-hero__details {
    align-items: flex-start;
  }
  .pt-company-hero__detail-item {
    font-size: 0.76rem;
  }
}
.pt-intelligence-dashboard {
  position: relative;
  min-height: calc(100vh - 4rem);
}
.pt-intelligence-dashboard__layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 1.5rem;
  align-items: stretch;
}
.pt-intelligence-dashboard__main {
  display: flex;
  flex-direction: column;
  gap: 0;
  min-width: 0;
  padding: 0 0 1.5rem;
}
.pt-intelligence-dashboard__sidebar {
  position: sticky;
  top: 0;
  align-self: stretch;
  height: 100vh;
  min-height: 100vh;
  margin: -1.5rem -1.5rem -1.5rem 0;
  border-left: 1px solid var(--color-border-subtle);
  background: var(--color-surface);
}
.pt-intelligence-dashboard__sidebar .pt-context-sidebar {
  height: 100%;
  min-height: 0;
}
.pt-intelligence-dashboard__sidebar .pt-context-sidebar:not(.pt-context-sidebar--collapsed) {
  width: 24rem;
  min-width: 24rem;
}
.pt-intelligence-dashboard__sidebar .pt-context-sidebar__body, .pt-intelligence-dashboard__sidebar .pt-context-sidebar__panels, .pt-intelligence-dashboard__sidebar .pt-context-sidebar__panel--active {
  min-height: 0;
}
.pt-intelligence-dashboard__sidebar .pt-context-sidebar__body {
  overflow: hidden;
}
.pt-intelligence-dashboard__sidebar .pt-context-sidebar__panels {
  overflow-y: auto;
}
.pt-intelligence-dashboard .pt-dropdown {
  position: relative;
}
.pt-intelligence-dashboard .pt-dropdown__menu {
  position: absolute;
  top: 100%;
  right: 0;
  left: auto;
  z-index: 50;
  display: none;
  width: 10.5rem;
  min-width: 10.5rem;
  border: 1px solid var(--color-border-subtle);
  border-radius: 0;
  background: var(--color-surface);
  box-shadow: 0 4px 10px rgba(15, 23, 42, 0.18);
  overflow: hidden;
}
.pt-intelligence-dashboard .pt-dropdown__menu--open {
  display: block;
}
.pt-intelligence-dashboard__section-header {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: end;
  gap: 1rem;
  margin-bottom: 0.5rem;
  padding-top: 0;
  padding-bottom: 0.625rem;
  border-bottom: 1px solid var(--color-border-subtle);
}
.pt-intelligence-dashboard__section-title {
  display: flex;
  flex-direction: column;
  gap: 0.375rem;
  min-width: 0;
}
.pt-intelligence-dashboard__heading {
  margin: 0;
  color: var(--color-text-primary);
  font-size: 1.375rem;
  font-weight: 700;
  line-height: 1.25;
}
.pt-intelligence-dashboard__subheading {
  margin: 0;
  color: var(--color-text-secondary);
  font-size: 0.875rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}
.pt-intelligence-dashboard__section-actions {
  flex: 0 0 auto;
  align-self: end;
}
.pt-intelligence-dashboard__mode-trigger {
  white-space: nowrap;
}
.pt-intelligence-dashboard__mode-menu {
  display: flex;
  flex-direction: column;
  gap: 0;
  width: 100%;
  min-width: 100%;
  padding: 0;
}
.pt-intelligence-dashboard__mode-option {
  width: 100%;
  min-height: 2.5rem;
  border: 0;
  border-radius: 0;
  background: transparent;
  color: var(--color-text-primary);
  cursor: pointer;
  font-family: inherit;
  font-size: 0.875rem;
  font-weight: 400;
  line-height: 1.2;
  padding: 0.625rem 0.875rem;
  text-align: left;
  white-space: nowrap;
}
.pt-intelligence-dashboard__mode-option:hover, .pt-intelligence-dashboard__mode-option:focus-visible {
  background: color-mix(in srgb, oklch(60% 0.15 250) 14%, transparent);
  @supports (color: color-mix(in lab, red, red)) {
    background: color-mix(in srgb, var(--color-brand-light) 14%, transparent);
  }
  outline: none;
}
.pt-intelligence-dashboard__results {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}
.pt-intelligence-dashboard__scroller {
  overflow-x: auto;
  padding-bottom: 0.25rem;
}
.pt-intelligence-dashboard__feed {
  min-width: 100%;
}
.pt-intelligence-dashboard__pagination {
  display: flex;
  justify-content: center;
  padding-top: 0.25rem;
}
.pt-intelligence-dashboard__pagination:empty {
  display: none;
}
.pt-intelligence-dashboard__list {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  list-style: none;
  margin: 0;
  padding: 0;
}
.pt-intelligence-dashboard__item {
  min-width: 46rem;
}
.pt-intelligence-project-update-card {
  display: grid;
  grid-template-columns: 15rem minmax(28rem, 1fr);
  gap: 0;
  min-height: 10.75rem;
  padding: 0;
  overflow: hidden;
  border: 1px solid color-mix(in srgb, oklch(75% 0.01 250) 18%, transparent);
  @supports (color: color-mix(in lab, red, red)) {
    border: 1px solid color-mix(in srgb, var(--color-border-strong) 18%, transparent);
  }
  border-radius: 0.25rem;
  background: var(--color-surface);
  box-shadow: 0 8px 22px rgba(15, 23, 42, 0.055);
  transition: transform 120ms ease-out, box-shadow 120ms ease-out, border-color 120ms ease-out;
}
.pt-intelligence-project-update-card:hover {
  border-color: oklch(82% 0 0);
  box-shadow: 0 0.45rem 1rem oklch(20% 0 0 / 12%);
  transform: translateY(-1px);
}
.pt-intelligence-project-update-card__media {
  position: relative;
  min-height: 10.75rem;
  height: 100%;
}
.pt-intelligence-project-update-card__media-link {
  display: block;
  height: 100%;
  min-height: inherit;
}
.pt-intelligence-project-update-card__photo, .pt-intelligence-project-update-card__photo-placeholder {
  width: 100%;
  height: 100%;
  min-height: inherit;
  border-radius: 0;
}
.pt-intelligence-project-update-card__photo {
  display: block;
  object-fit: cover;
  background: var(--color-surface-inverse);
}
.pt-intelligence-project-update-card__photo-placeholder {
  display: flex;
  align-items: center;
  justify-content: center;
  border: 1px dashed color-mix(in srgb, oklch(75% 0.01 250) 20%, transparent);
  @supports (color: color-mix(in lab, red, red)) {
    border: 1px dashed color-mix(in srgb, var(--color-border-strong) 20%, transparent);
  }
  background: linear-gradient(135deg, color-mix(in srgb, oklch(60% 0.15 250) 14%, white) 0%, color-mix(in srgb, oklch(18% 0.02 250) 92%, white) 100%);
  @supports (color: color-mix(in lab, red, red)) {
    background: linear-gradient(135deg, color-mix(in srgb, var(--color-brand-light) 14%, white) 0%, color-mix(in srgb, var(--color-surface-inverse) 92%, white) 100%);
  }
  color: var(--color-brand-light);
}
.pt-intelligence-project-update-card__topline {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 0.5rem;
}
.pt-intelligence-project-update-card .pt-project-card__actions {
  position: static;
  display: flex;
  flex: 0 0 auto;
  gap: 0.375rem;
  margin-left: 0.5rem;
}
.pt-intelligence-project-update-card .pt-project-card__actions .pt-card-action-btn {
  opacity: 1;
  transform: none;
}
.pt-intelligence-project-update-card__content {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  min-width: 0;
  padding: 0.75rem 1rem;
}
.pt-intelligence-project-update-card__header {
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
  min-width: 0;
}
.pt-intelligence-project-update-card__title {
  margin: 0;
  min-width: 0;
  overflow: hidden;
  color: var(--color-text-primary);
  display: -webkit-box;
  font-size: 1.05rem;
  font-weight: 700;
  line-height: 1.25;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
}
.pt-intelligence-project-update-card__title-link {
  color: inherit;
  text-decoration: none;
}
.pt-intelligence-project-update-card__title-link:hover, .pt-intelligence-project-update-card__title-link:focus-visible {
  color: var(--color-brand-light);
  text-decoration: underline;
  outline: none;
}
.pt-intelligence-project-update-card__meta {
  display: inline-flex;
  align-items: center;
  gap: 0.375rem;
  margin: 0;
  color: var(--color-text-secondary);
  font-size: 0.82rem;
}
.pt-intelligence-project-update-card__status-location {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 0.5rem;
  min-height: 1.375rem;
}
.pt-intelligence-project-update-card__status {
  display: inline-flex;
  align-items: center;
  flex: 0 0 auto;
  max-width: 100%;
  min-height: 1.375rem;
  padding: 0.2rem 0.625rem;
  border-radius: 999px;
  color: #fff;
  font-size: 0.72rem;
  font-weight: 700;
  line-height: 1;
  text-transform: uppercase;
  white-space: nowrap;
}
.pt-intelligence-project-update-card__status--on_hold {
  background: #6f56a6;
}
.pt-intelligence-project-update-card__status--tender, .pt-intelligence-project-update-card__status--in_tender {
  background: #f5a623;
}
.pt-intelligence-project-update-card__status--under_construction {
  background: #f47b20;
}
.pt-intelligence-project-update-card__status--completed {
  background: #00a878;
}
.pt-intelligence-project-update-card__status--ongoing, .pt-intelligence-project-update-card__status--planning, .pt-intelligence-project-update-card__status--under_design {
  background: #0b82d8;
}
.pt-intelligence-project-update-card__status--cancelled {
  background: #6c757d;
}
.pt-intelligence-project-update-card__updated {
  margin: 0;
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  color: var(--color-text-secondary);
}
.pt-intelligence-project-update-card__updates {
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
}
.pt-intelligence-project-update-card__update-line {
  position: relative;
  margin: 0;
  padding-left: 1rem;
  color: var(--color-text-primary);
  font-size: 0.8125rem;
  line-height: 1.35;
}
.pt-intelligence-project-update-card__update-line::before {
  content: "";
  position: absolute;
  top: 0.35rem;
  left: 0.125rem;
  width: 0.5rem;
  height: 0.75rem;
  border-bottom: 1px solid #c8cdd3;
  border-left: 1px solid #c8cdd3;
  border-radius: 0 0 0 0.25rem;
}
.pt-intelligence-project-update-card__footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.5rem;
  flex-wrap: wrap;
  margin-top: auto;
  padding-top: 0;
}
.pt-intelligence-project-update-card__sector {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
}
.pt-intelligence-project-update-card__sector-count {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 2rem;
  height: 2rem;
  padding: 0 0.625rem;
  border-radius: 999px;
  background: #f1f2f4;
  color: #6b7280;
  font-size: 0.85rem;
  font-weight: 700;
}
.pt-intelligence-project-update-card__metrics {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 0.375rem;
}
.pt-intelligence-project-update-card .pt-metric-pill {
  gap: 0.25rem;
  padding: 0.25rem 0.5rem;
  font-size: 0.72rem;
}
.pt-intelligence-project-update-card .pt-metric-pill__label {
  display: inline;
}
.pt-intelligence-dashboard__empty-wrap {
  width: 100%;
}
.pt-intelligence-dashboard__empty {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.75rem;
  padding: 2rem 1.25rem;
  border: 1px dashed var(--color-border-subtle);
  border-radius: 0.75rem;
  background: var(--color-surface);
  color: var(--color-text-primary);
  text-align: center;
}
.pt-intelligence-dashboard__empty-icon {
  color: var(--color-brand-light);
}
.pt-intelligence-dashboard__empty-title {
  margin: 0;
  font-size: 1rem;
  font-weight: 700;
  color: var(--color-text-primary);
}
.pt-intelligence-dashboard__empty-copy {
  margin: 0;
  max-width: 30rem;
  color: var(--color-text-secondary);
}
.pt-intelligence-sidebar {
  display: flex;
  flex-direction: column;
  gap: 0.625rem;
  min-height: 0;
}
.pt-intelligence-sidebar__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
}
.pt-intelligence-sidebar__count {
  margin: 0;
  color: var(--color-text-secondary);
  font-size: 0.8rem;
}
.pt-intelligence-sidebar__all-link {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  color: var(--color-brand-light);
  font-size: 0.82rem;
  font-weight: 600;
  text-decoration: none;
}
.pt-intelligence-sidebar__all-link:hover, .pt-intelligence-sidebar__all-link:focus-visible {
  text-decoration: underline;
  outline: none;
}
.pt-intelligence-sidebar .pt-oppo-panel__list {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  border: 0;
  background: transparent;
}
.pt-intelligence-task-card {
  display: flex;
  flex-direction: column;
  gap: 0.625rem;
  padding: 0.75rem;
  border: 1px solid var(--color-border-subtle);
  border-radius: 0.25rem;
  background: var(--color-surface);
  color: var(--color-text-primary);
}
.pt-intelligence-task-card__header {
  display: grid;
  grid-template-columns: 1.25rem minmax(0, 1fr);
  gap: 0.5rem;
  align-items: start;
}
.pt-intelligence-task-card__icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1.25rem;
  height: 1.5rem;
  margin-top: -0.0325rem;
  color: var(--color-text-primary);
}
.pt-intelligence-task-card__icon-svg {
  width: 1rem;
  height: 1rem;
}
.pt-intelligence-task-card__body {
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
  min-width: 0;
}
.pt-intelligence-task-card__title {
  margin: 0;
  color: var(--color-text-primary);
  font-size: 0.875rem;
  font-weight: 700;
  line-height: 1.35;
}
.pt-intelligence-task-card__line {
  margin: 0;
  color: var(--color-text-primary);
  font-size: 0.8rem;
  line-height: 1.35;
}
.pt-intelligence-task-card__label {
  color: var(--color-text-primary);
}
.pt-intelligence-task-card__link {
  color: var(--color-brand-light);
  text-decoration: none;
}
.pt-intelligence-task-card__link:hover, .pt-intelligence-task-card__link:focus-visible {
  text-decoration: underline;
  outline: none;
}
.pt-intelligence-task-card__footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.5rem;
  padding-left: 1.75rem;
}
.pt-intelligence-task-card__footer-left {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  min-width: 0;
}
.pt-intelligence-task-card__assignee {
  display: inline-flex;
  align-items: center;
  flex: 0 0 auto;
  min-width: 2rem;
}
.pt-intelligence-task-card__status {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 auto;
  min-width: 3.5rem;
  min-height: 1.375rem;
  padding: 0.2rem 0.625rem;
  border-radius: 999px;
  background: #0b5596;
  color: #fff;
  font-size: 0.68rem;
  font-weight: 700;
  line-height: 1;
  text-transform: uppercase;
}
.pt-intelligence-task-card__due {
  display: inline-flex;
  align-items: center;
  justify-content: flex-end;
  gap: 0.25rem;
  flex: 0 0 auto;
  margin-left: auto;
  color: var(--color-text-secondary);
  font-size: 0.75rem;
  line-height: 1.3;
  white-space: nowrap;
}
.pt-intelligence-task-card__due-icon {
  color: var(--color-text-secondary);
}
.pt-intelligence-task-card__due--overdue, .pt-intelligence-task-card__due--overdue .pt-intelligence-task-card__due-icon {
  color: var(--color-text-secondary);
}
.pt-intelligence-dashboard .pt-tag-popup {
  z-index: 80;
}
.pt-intelligence-dashboard .pt-tag-popup__footer {
  color: #6b7280;
  font-weight: 600;
  text-align: center;
  text-decoration: none;
}
.pt-intelligence-dashboard .pt-tag-popup__footer:hover, .pt-intelligence-dashboard .pt-tag-popup__footer:focus-visible {
  text-decoration: underline;
  outline: none;
}
@media (max-width: 1180px) {
  .pt-intelligence-dashboard__layout {
    grid-template-columns: minmax(0, 1fr);
  }
  .pt-intelligence-dashboard__sidebar {
    position: relative;
    top: auto;
    height: auto;
    min-height: 0;
    margin: 0;
    border-left: 0;
    border-top: 1px solid var(--color-border-subtle);
  }
  .pt-intelligence-dashboard__sidebar .pt-context-sidebar {
    height: auto;
    width: 100%;
    min-width: 0;
  }
}
@media (max-width: 1024px) {
  .pt-intelligence-project-update-card {
    grid-template-columns: 13.5rem minmax(28rem, 1fr);
  }
}
@media (max-width: 768px) {
  .pt-intelligence-dashboard__main {
    padding: 1rem;
  }
  .pt-intelligence-dashboard__section-header {
    grid-template-columns: minmax(0, 1fr);
    align-items: stretch;
  }
  .pt-intelligence-dashboard__section-actions {
    width: 100%;
  }
  .pt-intelligence-dashboard .pt-dropdown {
    width: 100%;
  }
  .pt-intelligence-dashboard__mode-trigger {
    width: 100%;
    justify-content: space-between;
  }
  .pt-intelligence-dashboard .pt-dropdown__menu {
    left: 0;
    right: auto;
    width: 100%;
    min-width: 100%;
  }
}
@media (max-width: 640px) {
  .pt-intelligence-dashboard__item {
    min-width: 40rem;
  }
  .pt-intelligence-project-update-card {
    grid-template-columns: 13.5rem minmax(24rem, 1fr);
  }
}
.pt-intelligence-dashboard .pt-card-action-btn--tag.pt-card-action-btn--active, .pt-intelligence-dashboard .pt-card-action-btn--tag.pt-card-action-btn--active:hover, .pt-intelligence-dashboard .pt-card-action-btn--tag.pt-card-action-btn--active:focus-visible {
  color: #6b7280;
}
.pt-intelligence-dashboard .pt-card-action-btn--tag.pt-card-action-btn--active .pt-card-action-btn__icon, .pt-intelligence-dashboard .pt-card-action-btn--tag.pt-card-action-btn--active svg {
  color: #6b7280;
  fill: #6b7280;
  stroke: #6b7280;
}
.pt-dashboard-profile {
  position: relative;
  min-height: calc(100vh - 4rem);
}
.pt-dashboard-profile__content {
  display: flex;
  flex-direction: column;
  gap: 1.25rem;
  min-width: 0;
  padding: 0 0 1.5rem;
}
.pt-dashboard-profile-filters {
  display: flex;
  flex-direction: column;
  gap: 1.25rem;
  padding-top: 1.25rem;
}
.pt-dashboard-profile-filters__company-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: start;
  gap: 1rem;
}
.pt-dashboard-profile-filters__company-block {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 0.875rem;
  min-width: 0;
}
.pt-dashboard-profile-filters__company {
  margin: 0;
  padding-top: 0.35rem;
  color: var(--color-text-primary);
  font-size: 1.25rem;
  font-weight: 700;
  line-height: 1.25;
}
.pt-dashboard-profile-filters__form {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  flex-wrap: wrap;
  gap: 0.5rem;
}
.pt-dashboard-profile-filters__control {
  min-width: 0;
}
.pt-dashboard-profile-filters__control--company {
  width: 15rem;
}
.pt-dashboard-profile-filters__control--date-range {
  width: 17rem;
}
.pt-dashboard-profile-filters__grouping {
  width: 5.875rem;
}
.pt-dashboard-profile-filters__grouping select, .pt-dashboard-profile-filters__grouping .pt-select, .pt-dashboard-profile-filters__grouping .pt-select__input {
  min-width: 5.875rem;
}
.pt-dashboard-profile-filters__actions {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
}
.pt-dashboard-profile-filters__clear {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.35rem;
  min-height: 2.5rem;
  padding: 0 0.75rem;
  border: 1px solid var(--color-border);
  border-radius: 0.25rem;
  background: var(--color-surface);
  color: var(--color-brand);
  font-size: 0.8125rem;
  font-weight: 700;
  line-height: 1;
  text-decoration: none;
  white-space: nowrap;
  box-shadow: 0 1px 1px rgba(15, 23, 42, 0.035);
}
.pt-dashboard-profile-filters__clear:hover, .pt-dashboard-profile-filters__clear:focus-visible {
  border-color: color-mix(in srgb, oklch(45% 0.18 250) 45%, oklch(88% 0 0));
  @supports (color: color-mix(in lab, red, red)) {
    border-color: color-mix(in srgb, var(--color-brand) 45%, var(--color-border));
  }
  background: color-mix(in srgb, oklch(60% 0.15 250) 8%, oklch(99% 0 0));
  @supports (color: color-mix(in lab, red, red)) {
    background: color-mix(in srgb, var(--color-brand-light) 8%, var(--color-surface));
  }
  color: var(--color-brand);
  outline: none;
}
.pt-dashboard-profile-date-range {
  position: relative;
  display: grid;
  grid-template-columns: minmax(0, 1fr) 2.5rem;
  min-height: 2.5rem;
  border: 1px solid var(--color-border);
  border-radius: 0.25rem;
  background: var(--color-surface);
  box-shadow: 0 1px 1px rgba(15, 23, 42, 0.035);
}
.pt-dashboard-profile-date-range:focus-within {
  border-color: color-mix(in srgb, oklch(45% 0.18 250) 55%, oklch(88% 0 0));
  @supports (color: color-mix(in lab, red, red)) {
    border-color: color-mix(in srgb, var(--color-brand) 55%, var(--color-border));
  }
  box-shadow: 0 0 0 2px color-mix(in srgb, oklch(45% 0.18 250) 16%, transparent);
  @supports (color: color-mix(in lab, red, red)) {
    box-shadow: 0 0 0 2px color-mix(in srgb, var(--color-brand) 16%, transparent);
  }
}
.pt-dashboard-profile-date-range__input {
  width: 100%;
  min-width: 0;
  border: 0;
  border-radius: 0.25rem 0 0 0.25rem;
  background: transparent;
  color: var(--color-text-primary);
  cursor: pointer;
  font: inherit;
  font-size: 0.875rem;
  padding: 0 0.75rem;
  outline: none;
}
.pt-dashboard-profile-date-range__button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 0;
  border-left: 1px solid var(--color-border);
  border-radius: 0 0.25rem 0.25rem 0;
  background: transparent;
  color: var(--color-text-secondary);
  cursor: pointer;
}
.pt-dashboard-profile-date-range__button:hover, .pt-dashboard-profile-date-range__button:focus-visible {
  color: var(--color-brand);
  outline: none;
}
.pt-dashboard-profile-date-range__popover {
  position: absolute;
  top: calc(100% + 0.35rem);
  right: 0;
  z-index: 80;
  display: none;
  width: 31rem;
  max-width: calc(100vw - 3rem);
  border: 1px solid var(--color-border);
  border-radius: 0.375rem;
  background: var(--color-surface);
  box-shadow: 0 16px 36px rgba(15, 23, 42, 0.22);
  overflow: hidden;
}
.pt-dashboard-profile-date-range__popover--open {
  display: block;
}
.pt-dashboard-profile-date-range__calendar {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.75rem;
  padding: 1rem;
  border-bottom: 1px solid var(--color-border);
}
.pt-dashboard-profile-date-range__field {
  display: grid;
  gap: 0.35rem;
}
.pt-dashboard-profile-date-range__label {
  color: var(--color-text-secondary);
  font-size: 0.75rem;
  font-weight: 800;
  text-transform: uppercase;
}
.pt-dashboard-profile-date-range__date {
  width: 100%;
  min-height: 2.4rem;
  border: 1px solid var(--color-border);
  border-radius: 0.25rem;
  background: var(--color-surface);
  color: var(--color-text-primary);
  font: inherit;
  padding: 0 0.625rem;
}
.pt-dashboard-profile-date-range__quick {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0;
  padding: 0.5rem 0;
  border-bottom: 1px solid var(--color-border);
}
.pt-dashboard-profile-date-range__quick-button {
  min-height: 2.15rem;
  border: 0;
  background: transparent;
  color: var(--color-text-primary);
  cursor: pointer;
  font: inherit;
  font-size: 0.875rem;
  padding: 0.4rem 1rem;
  text-align: left;
}
.pt-dashboard-profile-date-range__quick-button:hover, .pt-dashboard-profile-date-range__quick-button:focus-visible {
  background: color-mix(in srgb, oklch(60% 0.15 250) 12%, transparent);
  @supports (color: color-mix(in lab, red, red)) {
    background: color-mix(in srgb, var(--color-brand-light) 12%, transparent);
  }
  outline: none;
}
.pt-dashboard-profile-date-range__footer {
  display: flex;
  justify-content: flex-end;
  gap: 0.5rem;
  padding: 0.75rem 1rem;
}
.pt-dashboard-profile-date-range__footer-button {
  min-height: 2.1rem;
  border: 1px solid var(--color-border);
  border-radius: 0.25rem;
  background: var(--color-surface);
  color: var(--color-text-primary);
  cursor: pointer;
  font: inherit;
  font-size: 0.8125rem;
  font-weight: 700;
  padding: 0 0.875rem;
}
.pt-dashboard-profile-date-range__footer-button--primary {
  border-color: var(--color-brand);
  background: var(--color-brand);
  color: #fff;
}
.pt-dashboard-profile__main {
  display: grid;
  gap: 1.25rem;
}
.pt-dashboard-profile__pie-grid, .pt-dashboard-profile__table-grid {
  display: grid;
  gap: 1.25rem;
}
.pt-dashboard-chart-card {
  border: 1px solid var(--color-border);
  border-radius: 0.25rem;
  background: var(--color-surface);
  box-shadow: 0 1px 2px rgba(15, 23, 42, 0.055);
  overflow: hidden;
}
.pt-dashboard-chart-card__heading {
  padding: 1rem 1.25rem;
  border-bottom: 1px solid var(--color-border);
  background: var(--color-surface);
}
.pt-dashboard-chart-card__title {
  margin: 0;
  color: var(--color-text-primary);
  font-size: 0.875rem;
  font-weight: 800;
  letter-spacing: 0;
  line-height: 1.2;
  text-transform: uppercase;
}
.pt-dashboard-chart-card__body {
  position: relative;
  padding: 1rem;
  background: var(--color-surface);
}
.pt-dashboard-chart-card__body--timeline {
  min-height: 24rem;
}
.pt-dashboard-chart-card__body--pie {
  min-height: 21rem;
}
.pt-dashboard-chart-card__body--donut {
  min-height: 21rem;
}
.pt-dashboard-chart-card__total {
  display: inline-flex;
  align-items: baseline;
  gap: 0.25rem;
  margin: 0 0 0.5rem;
  color: var(--color-text-primary);
  font-size: 0.8125rem;
  font-weight: 600;
}
.pt-dashboard-chart-card__total strong {
  font-weight: 800;
}
.pt-dashboard-chart-card__chart--timeline {
  min-height: 22rem;
}
.pt-dashboard-chart-card__chart--pie {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 19.5rem;
}
.pt-dashboard-chart-card__chart--donut {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 19.5rem;
}
.pt-dashboard-chart-card__chart--donut .pt-ag-donut-chart {
  width: 100%;
}
.pt-dashboard-pie-wrap {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
}
.pt-dashboard-pie {
  width: 100%;
  max-width: 29rem;
  height: auto;
  overflow: visible;
}
.pt-dashboard-pie__slice {
  cursor: pointer;
  transform-box: fill-box;
  transform-origin: center;
  transition: transform 0.18s ease, opacity 0.18s ease, filter 0.18s ease;
  outline: none;
}
.pt-dashboard-pie--has-hover .pt-dashboard-pie__slice, .pt-dashboard-pie:focus-within .pt-dashboard-pie__slice {
  opacity: 0.18;
}
.pt-dashboard-pie--has-hover .pt-dashboard-pie__slice:hover, .pt-dashboard-pie:focus-within .pt-dashboard-pie__slice:focus-visible, .pt-dashboard-pie .pt-dashboard-pie__slice--active {
  opacity: 1;
}
.pt-dashboard-pie__slice:hover, .pt-dashboard-pie__slice:focus-visible, .pt-dashboard-pie__slice--active {
  transform: translate(var(--pt-pie-explode-x), var(--pt-pie-explode-y));
  filter: drop-shadow(0 5px 8px rgba(15, 23, 42, 0.22));
}
.pt-dashboard-pie__sector {
  stroke: #fff;
  stroke-width: 1.35;
  transition: stroke-width 0.18s ease, opacity 0.18s ease;
}
.pt-dashboard-pie__slice:hover .pt-dashboard-pie__sector, .pt-dashboard-pie__slice:focus-visible .pt-dashboard-pie__sector, .pt-dashboard-pie__slice--active .pt-dashboard-pie__sector {
  stroke-width: 2.5;
}
.pt-dashboard-pie__label {
  fill: var(--color-text-primary);
  cursor: pointer;
  font-size: 0.66rem;
  font-weight: 600;
  letter-spacing: 0.005em;
  line-height: 1.2;
  pointer-events: visiblePainted;
}
.pt-dashboard-pie__callout {
  fill: none;
  stroke: #b8c0ca;
  stroke-width: 1;
  cursor: pointer;
  pointer-events: stroke;
}
.pt-dashboard-pie__slice:hover .pt-dashboard-pie__callout, .pt-dashboard-pie__slice:focus-visible .pt-dashboard-pie__callout, .pt-dashboard-pie__slice--active .pt-dashboard-pie__callout {
  stroke: color-mix(in srgb, oklch(45% 0.18 250) 70%, #7b8794);
  @supports (color: color-mix(in lab, red, red)) {
    stroke: color-mix(in srgb, var(--color-brand) 70%, #7b8794);
  }
  stroke-width: 1.25;
}
.pt-dashboard-pie__slice:hover .pt-dashboard-pie__label, .pt-dashboard-pie__slice:focus-visible .pt-dashboard-pie__label, .pt-dashboard-pie__slice--active .pt-dashboard-pie__label {
  fill: var(--color-text-primary);
  font-weight: 700;
}
.pt-dashboard-pie-tooltip {
  position: absolute;
  z-index: 10;
  display: grid;
  gap: 0.1rem;
  min-width: 7.5rem;
  padding: 0.5rem 0.625rem;
  border: 1px solid color-mix(in srgb, oklch(45% 0.18 250) 55%, oklch(88% 0 0));
  @supports (color: color-mix(in lab, red, red)) {
    border: 1px solid color-mix(in srgb, var(--color-brand) 55%, var(--color-border));
  }
  border-radius: 0.25rem;
  background: var(--color-surface);
  color: var(--color-text-primary);
  box-shadow: 0 8px 22px rgba(15, 23, 42, 0.2);
  font-size: 0.75rem;
  line-height: 1.25;
  pointer-events: none;
}
.pt-dashboard-pie-tooltip[hidden] {
  display: none;
}
.pt-dashboard-pie-tooltip strong {
  font-weight: 700;
}
.pt-dashboard-pie-tooltip span {
  color: var(--color-text-secondary);
}
.pt-dashboard-table-card {
  background: transparent;
  border: 0;
  box-shadow: none;
  overflow: visible;
}
.pt-dashboard-table-card__shell {
  border: 1px solid var(--color-border);
  border-radius: 0.25rem;
  background: var(--color-surface);
  box-shadow: 0 1px 2px rgba(15, 23, 42, 0.055);
  overflow: hidden;
}
.pt-dashboard-table-card__section-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  min-height: 3.25rem;
  padding: 0.875rem 1rem;
  border-bottom: 1px solid var(--color-border);
  background: var(--color-surface);
}
.pt-dashboard-table-card__section-title {
  display: inline-flex;
  align-items: center;
  gap: 0.625rem;
  color: var(--color-text-primary);
  font-size: 0.875rem;
  font-weight: 800;
  line-height: 1.2;
}
.pt-dashboard-table-card__count {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 1.35rem;
  height: 1.35rem;
  padding: 0 0.35rem;
  border-radius: 999px;
  background: color-mix(in srgb, oklch(45% 0.02 250) 14%, transparent);
  @supports (color: color-mix(in lab, red, red)) {
    background: color-mix(in srgb, var(--color-text-secondary) 14%, transparent);
  }
  color: var(--color-text-secondary);
  font-size: 0.75rem;
  font-weight: 800;
}
.pt-dashboard-table-card__inner {
  background: var(--color-surface);
  overflow: hidden;
}
.pt-dashboard-table-card__inner--rankings {
  min-height: 5rem;
}
.pt-dashboard-grid {
  width: 100%;
  min-width: 0;
  padding: 0.75rem;
}
.pt-dashboard-grid .pt-ag-grid-container {
  height: auto;
  min-height: 9rem;
  border-color: var(--color-border);
  border-radius: 0.25rem;
  box-shadow: none;
}
.pt-dashboard-grid .pt-ag-grid-container .ag-root-wrapper {
  border-radius: 0.25rem;
}
.pt-dashboard-grid .ag-theme-quartz {
  --ag-row-hover-color: var(--color-surface-2);
}
.pt-dashboard-grid .ag-header-cell-text {
  font-size: 0.6875rem;
  font-weight: 700;
  letter-spacing: 0.03em;
  text-transform: uppercase;
}
.pt-dashboard-grid .ag-cell {
  display: flex;
  align-items: center;
  cursor: default;
}
.pt-dashboard-grid .ag-row {
  cursor: default;
}
.pt-dashboard-grid .ag-row-hover {
  background-color: var(--color-surface-2);
}
.pt-dashboard-table__link, .pt-dashboard-table__action {
  color: var(--color-brand);
  font-weight: 700;
  text-decoration: none;
}
.pt-dashboard-table__action {
  display: inline-flex;
  align-items: center;
  gap: 0.25rem;
}
.pt-dashboard-table__link:hover, .pt-dashboard-table__link:focus-visible, .pt-dashboard-table__action:hover, .pt-dashboard-table__action:focus-visible {
  text-decoration: underline;
  outline: none;
}
.pt-dashboard-table__muted {
  color: var(--color-text-muted);
  font-weight: 400;
}
.pt-dashboard-sparkline {
  display: inline-flex;
  align-items: center;
  justify-content: flex-start;
  min-width: 6rem;
  min-height: 1.75rem;
}
.pt-dashboard-sparkline__svg {
  width: 6rem;
  height: 1.75rem;
  overflow: visible;
}
.pt-dashboard-sparkline__area {
  fill: color-mix(in srgb, oklch(45% 0.18 250) 14%, transparent);
  @supports (color: color-mix(in lab, red, red)) {
    fill: color-mix(in srgb, var(--color-brand) 14%, transparent);
  }
}
.pt-dashboard-sparkline__line {
  fill: none;
  stroke: var(--color-brand);
  stroke-linecap: round;
  stroke-linejoin: round;
  stroke-width: 2;
}
.pt-dashboard-sparkline__empty {
  color: var(--color-text-muted);
}
.pt-dashboard-upsell {
  padding: var(--spacing-xl);
  border: 1px solid var(--color-border);
  border-radius: 0.25rem;
  background: linear-gradient(135deg, var(--color-surface), var(--color-brand-subtle));
}
.pt-dashboard-upsell__content {
  max-width: 42rem;
}
.pt-dashboard-upsell__eyebrow {
  color: var(--color-brand);
  font-size: 0.75rem;
  font-weight: 800;
  text-transform: uppercase;
}
.pt-dashboard-upsell__title {
  margin: var(--spacing-sm) 0;
  color: var(--color-text-primary);
  font-size: 1.25rem;
  font-weight: 800;
}
.pt-dashboard-upsell__body {
  margin: 0 0 var(--spacing-lg);
  color: var(--color-text-secondary);
}
.pt-dashboard-profile .ag-chart-wrapper, .pt-dashboard-profile canvas {
  border-radius: 0;
}
.pt-dashboard-visitor-details__trigger {
  display: inline-flex;
  align-items: center;
  max-width: 100%;
  border: 0;
  background: transparent;
  cursor: pointer;
  font: inherit;
  padding: 0;
  text-align: left;
}
.pt-dashboard-visitor-details__trigger:hover, .pt-dashboard-visitor-details__trigger:focus-visible {
  text-decoration: underline;
  outline: none;
}
.pt-dashboard-modal-open {
  overflow: hidden;
}
.pt-dashboard-visitor-modal[hidden] {
  display: none !important;
}
.pt-dashboard-visitor-modal {
  position: fixed;
  inset: 0;
  z-index: 120;
  display: flex;
  align-items: flex-start;
  justify-content: center;
  padding: 5rem 1.5rem 1.5rem;
}
.pt-dashboard-visitor-modal__backdrop {
  position: absolute;
  inset: 0;
  background: rgba(15, 23, 42, 0.58);
  backdrop-filter: blur(2px);
}
.pt-dashboard-visitor-modal__dialog {
  position: relative;
  z-index: 1;
  width: min(34rem, 100%);
  border: 1px solid var(--color-border);
  border-radius: 0.5rem;
  background: var(--color-surface);
  box-shadow: 0 24px 64px rgba(15, 23, 42, 0.28);
  overflow: hidden;
  outline: none;
}
.pt-dashboard-visitor-modal__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  min-height: 3.5rem;
  padding: 1rem 1.25rem;
  border-bottom: 1px solid var(--color-border);
  background: color-mix(in srgb, oklch(18% 0.02 250) 4%, oklch(99% 0 0));
  @supports (color: color-mix(in lab, red, red)) {
    background: color-mix(in srgb, var(--color-surface-inverse) 4%, var(--color-surface));
  }
}
.pt-dashboard-visitor-modal__title {
  margin: 0;
  color: var(--color-text-primary);
  font-size: 1rem;
  font-weight: 800;
  line-height: 1.25;
  text-transform: capitalize;
}
.pt-dashboard-visitor-modal__close {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2rem;
  height: 2rem;
  border: 0;
  border-radius: 999px;
  background: transparent;
  color: var(--color-text-secondary);
  cursor: pointer;
}
.pt-dashboard-visitor-modal__close:hover, .pt-dashboard-visitor-modal__close:focus-visible {
  background: color-mix(in srgb, oklch(18% 0.02 250) 8%, transparent);
  @supports (color: color-mix(in lab, red, red)) {
    background: color-mix(in srgb, var(--color-surface-inverse) 8%, transparent);
  }
  color: var(--color-text-primary);
  outline: none;
}
.pt-dashboard-visitor-modal__body {
  display: grid;
  gap: 0;
  padding: 0.5rem 1.25rem;
}
.pt-dashboard-visitor-modal__row {
  display: grid;
  grid-template-columns: 2rem minmax(0, 1fr);
  gap: 0.875rem;
  align-items: start;
  padding: 0.875rem 0;
}
.pt-dashboard-visitor-modal__row + .pt-dashboard-visitor-modal__row {
  border-top: 1px solid color-mix(in srgb, oklch(88% 0 0) 65%, transparent);
  @supports (color: color-mix(in lab, red, red)) {
    border-top: 1px solid color-mix(in srgb, var(--color-border) 65%, transparent);
  }
}
.pt-dashboard-visitor-modal__icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2rem;
  height: 2rem;
  border-radius: 999px;
  background: color-mix(in srgb, oklch(60% 0.15 250) 12%, transparent);
  @supports (color: color-mix(in lab, red, red)) {
    background: color-mix(in srgb, var(--color-brand-light) 12%, transparent);
  }
  color: var(--color-brand);
}
.pt-dashboard-visitor-modal__content {
  display: grid;
  gap: 0.25rem;
  min-width: 0;
}
.pt-dashboard-visitor-modal__label {
  color: var(--color-text-secondary);
  font-size: 0.72rem;
  font-weight: 800;
  letter-spacing: 0.045em;
  text-transform: uppercase;
}
.pt-dashboard-visitor-modal__value {
  color: var(--color-text-primary);
  font-size: 0.925rem;
  line-height: 1.45;
  overflow-wrap: anywhere;
}
.pt-dashboard-visitor-modal__footer {
  display: flex;
  justify-content: flex-end;
  gap: 0.5rem;
  padding: 0.875rem 1.25rem;
  border-top: 1px solid var(--color-border);
  background: color-mix(in srgb, oklch(18% 0.02 250) 4%, oklch(99% 0 0));
  @supports (color: color-mix(in lab, red, red)) {
    background: color-mix(in srgb, var(--color-surface-inverse) 4%, var(--color-surface));
  }
}
@media (max-width: 768px) {
  .pt-dashboard-visitor-modal {
    align-items: flex-start;
    padding: 4rem 1rem 1rem;
  }
  .pt-dashboard-visitor-modal__dialog {
    width: 100%;
  }
}
@media (width >= 64rem) {
  .pt-dashboard-profile__pie-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
  .pt-dashboard-profile__table-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}
@media (max-width: 1024px) {
  .pt-dashboard-profile-filters__company-row {
    grid-template-columns: minmax(0, 1fr);
  }
  .pt-dashboard-profile-filters__form {
    justify-content: flex-start;
  }
}
@media (max-width: 768px) {
  .pt-dashboard-profile__content {
    padding: 0 1rem 1rem;
  }
  .pt-dashboard-profile-filters__form, .pt-dashboard-profile-filters__control--company, .pt-dashboard-profile-filters__control--date-range, .pt-dashboard-profile-filters__grouping, .pt-dashboard-profile-filters__actions {
    width: 100%;
  }
  .pt-dashboard-profile-date-range__popover {
    left: 0;
    right: auto;
    width: calc(100vw - 2rem);
  }
  .pt-dashboard-profile-date-range__calendar, .pt-dashboard-profile-date-range__quick {
    grid-template-columns: minmax(0, 1fr);
  }
}
.pt-new-resource {
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
}
.pt-new-resource__section {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}
.pt-new-resource__heading {
  margin: 0;
  font-size: var(--text-base);
  font-weight: 600;
  color: var(--color-text-primary);
}
.pt-opportunities-directory {
  display: flex;
  flex-direction: column;
  gap: 0;
  width: 100%;
}
.pt-opportunities-directory__header {
  position: sticky;
  top: 0;
  z-index: 20;
  margin: -1rem -1.5rem 0.875rem;
  padding: 0.75rem 1.5rem 1.875rem;
  background: var(--color-surface);
}
.pt-opportunities-directory__header .pt-page-header {
  min-height: 0;
  margin: 0;
  padding: 0.375rem 0 0.875rem;
  border-bottom: 1px solid oklch(88% 0 0);
}
.pt-opportunities-directory__header .pt-page-header__title {
  font-size: 1.1875rem;
  line-height: 1.25;
}
.pt-opportunities-directory__header .pt-page-header__icon {
  width: 1.25rem;
  height: 1.25rem;
  color: oklch(42% 0 0);
}
.pt-opportunities-description-toggle {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  margin-top: 0.625rem;
  color: oklch(45% 0 0);
  cursor: pointer;
  font-size: 0.8125rem;
}
.pt-opportunities-description-toggle .pt-checkbox__input {
  position: absolute;
  opacity: 0;
  pointer-events: none;
}
.pt-opportunity-hits {
  min-width: 0;
}
.pt-opportunity-hits-inner, .pt-opportunity-list {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
  margin: 0;
  padding: 0;
  list-style: none;
}
.pt-opportunity-list__item {
  margin: 0;
  padding: 0;
}
.pt-opportunity-card {
  position: relative;
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 1rem;
  min-width: 0;
  padding: 1rem;
  border: 1px solid oklch(90% 0 0);
  border-radius: 0.5rem;
  background: var(--color-surface);
  box-shadow: 0 1px 2px oklch(0% 0 0 / 4%);
  transition: background-color 0.12s ease, border-color 0.12s ease, box-shadow 0.12s ease;
}
.pt-opportunity-card:hover {
  border-color: color-mix(in srgb, oklch(45% 0.18 250) 45%, white);
  @supports (color: color-mix(in lab, red, red)) {
    border-color: color-mix(in oklch, var(--color-brand) 45%, white);
  }
  background: color-mix(in srgb, oklch(45% 0.18 250) 5%, white);
  @supports (color: color-mix(in lab, red, red)) {
    background: color-mix(in oklch, var(--color-brand) 5%, white);
  }
  box-shadow: 0 10px 26px oklch(40% 0.05 250 / 10%);
}
.pt-opportunity-card__main {
  min-width: 0;
}
.pt-opportunity-card__header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 1rem;
  min-width: 0;
  padding-right: 4rem;
}
.pt-opportunity-card__title-row {
  display: flex;
  align-items: center;
  gap: 0.625rem;
  min-width: 0;
}
.pt-opportunity-card__title-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 auto;
  width: 1.25rem;
  height: 1.25rem;
  margin-top: 0.0625rem;
  border-radius: 0;
  background: transparent;
  color: oklch(24% 0 0);
  opacity: 0.86;
}
.pt-opportunity-card__title-icon .pt-icon {
  width: 1rem;
  height: 1rem;
}
.pt-opportunity-card__title {
  min-width: 0;
  margin: 0;
  color: oklch(24% 0 0);
  font-size: 0.9375rem;
  font-weight: 700;
  line-height: 1.35;
}
.pt-opportunity-card__title-link {
  color: inherit;
  text-decoration: none;
}
.pt-opportunity-card__title-link:hover {
  color: var(--color-brand);
  text-decoration: underline;
}
.pt-opportunity-card__title-link mark, .pt-opportunity-card__title-link em {
  display: inline;
  padding: 0 0.0625rem;
  border-radius: 0.125rem;
  background: #ffeb7a;
  color: inherit;
  font-style: normal;
}
.pt-opportunity-card__comments {
  position: absolute;
  top: 1rem;
  right: 1rem;
  display: inline-flex;
  align-items: center;
  gap: 0.25rem;
  flex: 0 0 auto;
  color: oklch(42% 0 0);
  font-size: 0.75rem;
  font-weight: 600;
  pointer-events: none;
}
.pt-opportunity-card__comments .pt-icon {
  width: 1rem;
  height: 1rem;
}
.pt-opportunity-card__project-line {
  display: flex;
  align-items: baseline;
  gap: 0.375rem;
  min-width: 0;
  margin-top: 0.5rem;
  font-size: 0.8125rem;
  line-height: 1.4;
}
.pt-opportunity-card__project-label {
  flex: 0 0 auto;
  color: oklch(48% 0 0);
  font-weight: 600;
}
.pt-opportunity-card__project-link {
  min-width: 0;
  overflow: hidden;
  color: var(--color-brand);
  text-overflow: ellipsis;
  text-decoration: none;
  white-space: nowrap;
}
.pt-opportunity-card__project-link:hover {
  text-decoration: underline;
}
.pt-opportunity-card__meta {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 0.5rem;
  margin-top: 0.75rem;
  color: oklch(38% 0 0);
  font-size: 0.8125rem;
}
.pt-opportunity-card__value {
  font-weight: 700;
}
.pt-opportunity-card__separator {
  color: oklch(72% 0 0);
}
.pt-opportunity-card__tasks {
  color: oklch(43% 0 0);
}
.pt-opportunity-card__footer {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  margin-top: 0.875rem;
}
.pt-opportunity-card__avatar {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1.75rem;
  height: 1.75rem;
  border-radius: 999px;
  background: oklch(91% 0 0);
  color: oklch(28% 0 0);
  font-size: 0.6875rem;
  font-weight: 800;
}
.pt-opportunity-card__status, .pt-opportunity-status-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 4.875rem;
  min-height: 1.25rem;
  padding: 0 0.625rem;
  border-radius: 999px;
  font-size: 0.625rem;
  font-weight: 800;
  line-height: 1;
  text-align: center;
  text-transform: uppercase;
  white-space: nowrap;
}
.pt-opportunity-card__status--on_radar, .pt-opportunity-status-badge--dark {
  background: oklch(20% 0 0);
  color: var(--color-surface);
}
.pt-opportunity-card__status--ongoing, .pt-opportunity-status-badge--warning {
  background: #f47b20;
  color: #ffffff;
}
.pt-opportunity-card__status--qualified, .pt-opportunity-status-badge--qualified {
  background: #7c3aed;
  color: #ffffff;
}
.pt-opportunity-card__status--won, .pt-opportunity-status-badge--success {
  background: #16a34a;
  color: #ffffff;
}
.pt-opportunity-card__status--lost, .pt-opportunity-status-badge--danger {
  background: #dc2626;
  color: #ffffff;
}
.pt-opportunity-card__status--unknown, .pt-opportunity-status-badge--unknown {
  background: oklch(95% 0 0);
  color: oklch(46% 0 0);
}
.pt-opportunity-card__aside {
  display: flex;
  align-items: flex-end;
  justify-content: flex-end;
  min-width: 8rem;
}
.pt-opportunity-card__date {
  display: inline-flex;
  align-items: center;
  gap: 0.375rem;
  color: oklch(52% 0 0);
  font-size: 0.75rem;
  white-space: nowrap;
}
.pt-opportunity-card__date .pt-icon {
  width: 0.875rem;
  height: 0.875rem;
}
.pt-opportunity-card__date--overdue {
  color: var(--color-danger);
  font-weight: 700;
}
.pt-opportunities-directory .pt-clear-refinements__icon {
  display: none;
}
.pt-opportunities-directory .ais-ClearRefinements-button {
  min-height: 2.25rem;
  padding: 0.5rem 0.875rem;
  border-radius: 0.25rem;
}
.pt-opportunity-empty {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  min-height: 22rem;
  padding: 3rem 1.5rem;
  border: 1px dashed oklch(85% 0 0);
  border-radius: 0.5rem;
  background: oklch(98% 0 0);
  text-align: center;
}
.pt-opportunity-empty__icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 3rem;
  height: 3rem;
  margin-bottom: 1rem;
  border-radius: 999px;
  background: oklch(93% 0 0);
  color: oklch(42% 0 0);
}
.pt-opportunity-empty__title {
  margin: 0;
  color: oklch(24% 0 0);
  font-size: 1.125rem;
  font-weight: 800;
}
.pt-opportunity-empty__text {
  max-width: 28rem;
  margin: 0.5rem 0 1rem;
  color: oklch(48% 0 0);
  font-size: 0.875rem;
  line-height: 1.5;
}
.pt-opportunity-value-range {
  display: flex;
  flex-direction: column;
  gap: 0.625rem;
  padding: 0.25rem 0.125rem 0;
}
.pt-opportunity-value-range__labels, .pt-opportunity-value-range__bounds {
  display: flex;
  align-items: center;
  justify-content: space-between;
  color: oklch(45% 0 0);
  font-size: 0.75rem;
  font-weight: 700;
}
.pt-opportunity-value-range__bounds {
  color: oklch(60% 0 0);
  font-size: 0.6875rem;
  font-weight: 600;
}
.pt-opportunity-value-range__slider {
  position: relative;
  height: 1.5rem;
}
.pt-opportunity-value-range__track, .pt-opportunity-value-range__track-fill {
  position: absolute;
  top: 50%;
  right: 0;
  left: 0;
  height: 0.25rem;
  border-radius: 999px;
  transform: translateY(-50%);
}
.pt-opportunity-value-range__track {
  background: oklch(88% 0 0);
}
.pt-opportunity-value-range__track-fill {
  background: var(--color-brand);
}
.pt-opportunity-value-range__input {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 1.5rem;
  margin: 0;
  background: none;
  pointer-events: none;
  appearance: none;
}
.pt-opportunity-value-range__input::-webkit-slider-thumb {
  width: 1rem;
  height: 1rem;
  border: 2px solid var(--color-brand);
  border-radius: 999px;
  background: var(--color-surface);
  box-shadow: 0 1px 4px oklch(0% 0 0 / 16%);
  cursor: pointer;
  pointer-events: auto;
  appearance: none;
}
.pt-opportunity-value-range__input::-moz-range-thumb {
  width: 1rem;
  height: 1rem;
  border: 2px solid var(--color-brand);
  border-radius: 999px;
  background: var(--color-surface);
  box-shadow: 0 1px 4px oklch(0% 0 0 / 16%);
  cursor: pointer;
  pointer-events: auto;
}
.pt-opportunity-value-range__input::-webkit-slider-runnable-track {
  background: transparent;
}
.pt-opportunity-value-range__input::-moz-range-track {
  background: transparent;
}
@media (max-width: 768px) {
  .pt-opportunity-card {
    grid-template-columns: 1fr;
  }
  .pt-opportunity-card__aside {
    justify-content: flex-start;
    min-width: 0;
  }
}
.pt-opportunity-date-range, .pt-opportunity-status-filter__label, .pt-opportunity-owner-filter__label, .pt-opportunity-date-filter__label {
  width: 100%;
}
.pt-opportunity-date-range {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}
.pt-opportunity-status-filter__label .pt-opportunity-status-badge {
  grid-column: 2;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.pt-opportunities-directory .pt-opportunity-filter-search {
  position: relative;
  display: block;
  width: 100%;
  min-width: 0;
  margin-bottom: 0.75rem;
}
.pt-opportunities-directory .pt-opportunity-filter-search__icon {
  position: absolute;
  top: 50%;
  left: 0.75rem;
  z-index: 2;
  display: block;
  width: 1rem;
  height: 1rem;
  margin: 0;
  padding: 0;
  color: oklch(46% 0 0);
  line-height: 1;
  pointer-events: none;
  transform: translateY(-50%);
}
.pt-opportunities-directory .pt-opportunity-filter-search__input {
  display: block;
  width: 100%;
  min-width: 0;
  min-height: 2.25rem;
  padding: 0.5rem 0.75rem 0.5rem 2.375rem;
  border: 1px solid oklch(86% 0 0);
  border-radius: 0.5rem;
  background: var(--color-surface);
  box-shadow: none;
  box-sizing: border-box;
}
.pt-opportunities-directory .pt-opportunity-filter-search__input:focus {
  border-color: var(--color-brand);
  outline: 2px solid color-mix(in srgb, oklch(45% 0.18 250) 16%, transparent);
  @supports (color: color-mix(in lab, red, red)) {
    outline: 2px solid color-mix(in oklch, var(--color-brand) 16%, transparent);
  }
  outline-offset: 0;
}
.pt-opportunities-directory .pt-opportunities-description-toggle {
  margin-top: 0.75rem;
}
.pt-project-rail .pt-context-sidebar {
  --ctx-width-expanded: 25.5rem;
  overflow-x: hidden;
}
.pt-opportunities-sidebar, .pt-opportunity-task-sidebar {
  display: flex;
  flex-direction: column;
  gap: 0.875rem;
  width: 100%;
  min-width: 0;
  max-width: 100%;
}
.pt-opportunities-sidebar {
  --opportunities-sidebar-control-radius: 0.375rem;
}
.pt-opportunities-sidebar *, .pt-opportunity-task-sidebar *, .pt-opportunity-sidebar-form *, .pt-opportunity-task-form * {
  box-sizing: border-box;
}
.pt-opportunities-sidebar__list-view, .pt-opportunities-sidebar__form-view, .pt-opportunities-sidebar__edit-view {
  width: 100%;
  min-width: 0;
  max-width: 100%;
  margin: 0;
  padding: 0;
  overflow-x: hidden;
}
.pt-opportunities-sidebar__form-view > .pt-opportunity-sidebar-form, .pt-opportunities-sidebar__edit-view > .pt-opportunity-sidebar-form, .pt-opportunity-task-sidebar > .pt-opportunity-sidebar-form {
  align-self: stretch;
  width: 100%;
  min-width: 0;
  max-width: 100%;
  margin: 0;
}
.pt-opportunities-sidebar__header {
  display: none;
}
.pt-opportunities-sidebar__toolbar {
  position: relative;
  display: grid;
  grid-template-columns: 2.25rem minmax(0, 1fr) auto;
  gap: 0.5rem;
  align-items: center;
}
.pt-opportunities-sidebar__filter-button, .pt-opportunities-sidebar__new-primary {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1px solid var(--color-border);
  border-radius: var(--opportunities-sidebar-control-radius);
  cursor: pointer;
}
.pt-opportunities-sidebar__filter-button {
  width: 2.25rem;
  height: 2.25rem;
  background: #fff;
  color: var(--color-text);
}
.pt-opportunities-sidebar__new-primary {
  gap: 0.375rem;
  min-height: 2.25rem;
  padding: 0 0.75rem;
  border-color: #00a978;
  background: #00a978;
  color: #fff;
  font-size: 0.8125rem;
  font-weight: 800;
}
.pt-opportunities-sidebar__new-primary:hover {
  border-color: #00966b;
  background: #00966b;
}
.pt-opportunities-sidebar__search {
  position: relative;
  min-width: 0;
}
.pt-opportunities-sidebar__search-input {
  width: 100%;
  height: 2.25rem;
  padding: 0 2.25rem 0 0.75rem;
  border: 1px solid var(--color-border);
  border-radius: var(--opportunities-sidebar-control-radius);
  background: #fff;
  color: var(--color-text);
  font-size: 0.8125rem;
}
.pt-opportunities-sidebar__search-input:focus {
  border-color: var(--color-primary);
  outline: 2px solid var(--color-primary);
  @supports (color: color-mix(in lab, red, red)) {
    outline: 2px solid color-mix(in srgb, var(--color-primary) 18%, transparent);
  }
  outline-offset: 0;
}
.pt-opportunities-sidebar__search-icon {
  position: absolute;
  top: 50%;
  right: 0.625rem;
  color: var(--color-text-muted);
  pointer-events: none;
  transform: translateY(-50%);
}
.pt-opportunities-sidebar__filters {
  position: relative;
  z-index: 30;
  width: 100%;
  max-width: 100%;
  margin-top: 0.625rem;
  padding: 1.25rem;
  border: 1px solid var(--color-border);
  background: #fff;
  box-shadow: 0 12px 28px rgb(15 23 42 / 14%);
}
.pt-opportunities-sidebar__filters-arrow {
  position: absolute;
  top: -0.55rem;
  right: 4.25rem;
  width: 1rem;
  height: 1rem;
  border-top: 1px solid var(--color-border);
  border-left: 1px solid var(--color-border);
  background: #fff;
  transform: rotate(45deg);
}
.pt-opportunity-task-sidebar .pt-opportunities-sidebar__filters-arrow {
  right: auto;
  left: 0.625rem;
}
.pt-opportunities-sidebar__filter-field, .pt-opportunities-sidebar__filter-group {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  min-width: 0;
}
.pt-opportunities-sidebar__filter-label {
  color: var(--color-text-muted);
  font-size: 0.75rem;
  font-weight: 800;
  letter-spacing: 0.02em;
  line-height: 1.2;
  text-transform: uppercase;
}
.pt-opportunities-sidebar__filter-select {
  position: relative;
  width: 100%;
  min-width: 0;
}
.pt-opportunities-sidebar__filter-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1.5rem;
  margin-top: 1.25rem;
}
.pt-opportunities-sidebar__check {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  min-width: 0;
  color: var(--color-text);
  cursor: pointer;
  font-size: 0.875rem;
  line-height: 1.3;
}
.pt-opportunities-sidebar__check-input {
  flex: 0 0 auto;
  width: 1rem;
  height: 1rem;
  margin: 0;
  cursor: pointer;
  accent-color: var(--color-primary);
}
.pt-opportunities-sidebar__filter-actions {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 1rem;
  margin-top: 1.5rem;
}
.pt-opportunities-sidebar__clear-button, .pt-opportunities-sidebar__apply-button {
  border: 0;
  background: transparent;
  cursor: pointer;
  font: inherit;
  font-size: 0.875rem;
  font-weight: 700;
}
.pt-opportunities-sidebar__clear-button {
  color: var(--color-text);
}
.pt-opportunities-sidebar__apply-button {
  min-height: 2.5rem;
  padding: 0 1rem;
  border-radius: var(--opportunities-sidebar-control-radius);
  background: #00a978;
  color: #fff;
}
.pt-opportunities-sidebar__apply-button:hover {
  background: #00966b;
}
.pt-opportunities-sidebar__result-count {
  margin-top: 0.75rem;
  color: var(--color-text);
  font-size: 0.8125rem;
  font-weight: 700;
}
.pt-opportunities-sidebar__no-results {
  padding: 1rem 0;
  color: var(--color-text-muted);
  font-size: 0.8125rem;
}
.pt-opportunities-sidebar__filter-select .pt-opportunity-sidebar-form__custom-select-button {
  width: 100%;
  height: 2.875rem;
  min-height: 2.875rem;
  padding: 0 0.875rem;
  border: 1px solid var(--color-border);
  border-radius: var(--opportunities-sidebar-control-radius);
  background: #fff;
  color: var(--color-text);
  cursor: pointer;
  font: inherit;
  font-size: 0.875rem;
  text-align: left;
}
.pt-opportunities-sidebar__filter-select .pt-opportunity-sidebar-form__custom-select-menu {
  z-index: 90;
  border: 1px solid var(--color-border);
  border-radius: var(--opportunities-sidebar-control-radius);
  background: #fff;
  box-shadow: 0 12px 28px rgb(15 23 42 / 16%);
}
.pt-opportunities-sidebar__filter-select .pt-opportunity-sidebar-form__custom-select-option {
  display: flex;
  align-items: center;
  gap: 0.625rem;
  width: 100%;
  min-height: 2.875rem;
  padding: 0 0.875rem;
  border: 0;
  border-bottom: 1px solid var(--color-border);
  background: #fff;
  color: var(--color-text);
  cursor: pointer;
  font: inherit;
  font-size: 0.875rem;
  text-align: left;
}
.pt-opportunities-sidebar__filter-select .pt-opportunity-sidebar-form__custom-select-option:last-child {
  border-bottom: 0;
}
.pt-opportunities-sidebar__filter-select .pt-opportunity-sidebar-form__custom-select-option:hover, .pt-opportunities-sidebar__filter-select .pt-opportunity-sidebar-form__custom-select-option:focus {
  background: var(--color-primary);
  @supports (color: color-mix(in lab, red, red)) {
    background: color-mix(in srgb, var(--color-primary) 10%, #fff);
  }
  outline: none;
}
.pt-opportunities-sidebar__empty {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: flex-start;
  min-height: 22rem;
  padding: 3.5rem 1.25rem 2.25rem;
  text-align: center;
}
.pt-opportunities-sidebar__empty-title {
  margin: 0;
  color: var(--color-text);
  font-size: 1.5rem;
  font-weight: 800;
  line-height: 1.2;
}
.pt-opportunities-sidebar__empty-description {
  max-width: 18rem;
  margin: 0.875rem auto 0.25rem;
  color: var(--color-text);
  font-size: 0.875rem;
  line-height: 1.5;
}
.pt-opportunities-sidebar__empty-image {
  display: block;
  width: 34rem;
  max-width: 100%;
  height: auto;
  margin: 0 auto 0.875rem;
}
.pt-opportunities-sidebar__cta {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  width: 100%;
  min-height: 2.75rem;
  padding: 0 1.25rem;
  border: 0;
  border-radius: var(--opportunities-sidebar-control-radius);
  background: #00a978;
  color: #fff;
  cursor: pointer;
  font-size: 0.875rem;
  font-weight: 800;
  line-height: 1;
  text-align: center;
  text-decoration: none;
}
.pt-opportunities-sidebar__cta:hover {
  background: #00966b;
  color: #fff;
  text-decoration: none;
}
.pt-opportunities-sidebar__cta .pt-icon {
  display: block;
  flex: 0 0 auto;
}
.pt-opportunities-sidebar__list {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
  margin-top: 0.625rem;
}
.pt-opportunity-sidebar-card {
  display: grid;
  grid-template-columns: 1.5rem minmax(0, 1fr);
  gap: 0.55rem;
  width: 100%;
  min-width: 0;
  padding: 0.875rem;
  border: 1px solid var(--color-border);
  border-radius: 0.625rem;
  background: var(--color-surface);
  color: inherit;
  cursor: pointer;
  text-align: left;
  text-decoration: none;
  transition: background-color 0.16s ease, border-color 0.16s ease, box-shadow 0.16s ease;
}
.pt-opportunity-sidebar-card:hover {
  border-color: var(--color-primary);
  @supports (color: color-mix(in lab, red, red)) {
    border-color: color-mix(in srgb, var(--color-primary) 36%, var(--color-border));
  }
  background: var(--color-primary);
  @supports (color: color-mix(in lab, red, red)) {
    background: color-mix(in srgb, var(--color-primary) 5%, var(--color-surface));
  }
  box-shadow: 0 8px 18px rgb(15 23 42 / 8%);
  color: inherit;
  text-decoration: none;
}
.pt-opportunity-sidebar-card__lead {
  display: inline-flex;
  align-items: flex-start;
  justify-content: center;
  width: 1.5rem;
  min-width: 1.5rem;
  padding-top: 0.0625rem;
  color: var(--color-text);
}
.pt-opportunity-sidebar-card__content {
  min-width: 0;
}
.pt-opportunity-sidebar-card__header, .pt-opportunity-sidebar-card__owner-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 0.5rem;
  align-items: center;
}
.pt-opportunity-sidebar-card__title {
  min-width: 0;
  min-height: 1.25rem;
  margin: 0;
  color: var(--color-text);
  font-size: 0.9375rem;
  font-weight: 800;
  line-height: 1.25;
}
.pt-opportunity-sidebar-card__comments {
  display: inline-flex;
  align-items: center;
  justify-self: end;
  gap: 0.25rem;
  color: var(--color-text-muted);
  font-size: 0.75rem;
  font-weight: 600;
}
.pt-opportunity-sidebar-card__comments-icon, .pt-opportunity-sidebar-card__meta-icon {
  color: var(--color-text-muted);
}
.pt-opportunity-sidebar-card__meta {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.35rem 0.75rem;
  margin-top: 0.45rem;
}
.pt-opportunity-sidebar-card__value, .pt-opportunity-sidebar-card__tasks {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  color: var(--color-text-muted);
  font-size: 0.8125rem;
  font-weight: 700;
}
.pt-opportunity-sidebar-card__owner-row {
  gap: 0.75rem;
  margin-top: 0.6rem;
}
.pt-opportunity-sidebar-card__owner {
  display: inline-flex;
  align-items: center;
  gap: 0.6rem;
  min-width: 0;
  color: var(--color-text);
  font-size: 0.8125rem;
  font-weight: 800;
}
.pt-opportunity-sidebar-card__owner .pt-avatar {
  margin-left: -0.1875rem;
  background: #e5e7eb;
  color: #6b7280;
}
.pt-opportunity-sidebar-card__owner-name {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.pt-opportunity-sidebar-card__status {
  justify-self: end;
}
.pt-opportunity-sidebar-card__status .pt-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 4.875rem;
  min-height: 1.25rem;
  padding: 0 0.625rem;
  border: 0;
  border-radius: 999px;
  font-size: 0.625rem;
  font-weight: 800;
  line-height: 1;
  text-align: center;
  text-transform: uppercase;
  white-space: nowrap;
}
.pt-opportunity-sidebar-card__date-row {
  display: flex;
  justify-content: flex-end;
  margin-top: 0.55rem;
}
.pt-opportunity-sidebar-card__date {
  display: inline-flex;
  align-items: center;
  justify-content: flex-end;
  gap: 0.35rem;
  color: var(--color-text-muted);
  font-size: 0.8125rem;
  font-weight: 700;
}
.pt-opportunity-sidebar-card__date--overdue {
  color: var(--color-danger);
}
.pt-opportunity-sidebar-card__status--on_radar .pt-badge {
  background: oklch(20% 0 0);
  color: var(--color-surface);
}
.pt-opportunity-sidebar-card__status--ongoing .pt-badge {
  background: #f47b20;
  color: #fff;
}
.pt-opportunity-sidebar-card__status--qualified .pt-badge {
  background: #7c3aed;
  color: #fff;
}
.pt-opportunity-sidebar-card__status--won .pt-badge, .pt-opportunity-sidebar-card__status--completed .pt-badge {
  background: #16a34a;
  color: #fff;
}
.pt-opportunity-sidebar-card__status--lost .pt-badge, .pt-opportunity-sidebar-card__status--cancelled .pt-badge {
  background: #dc2626;
  color: #fff;
}
.pt-opportunity-sidebar-card__status--new .pt-badge {
  background: oklch(95% 0 0);
  color: oklch(35% 0 0);
}
.pt-opportunity-sidebar-card__status--on_hold .pt-badge {
  background: #0b5596;
  color: #fff;
}
.pt-opportunity-sidebar-form {
  display: flex;
  flex-direction: column;
  width: 100%;
  min-width: 0;
  max-width: 100%;
  min-height: 100%;
  margin: 0;
  padding: 1.5rem 1.25rem 2rem;
  overflow-x: hidden;
  background: var(--color-surface);
}
.pt-opportunity-sidebar-form__header, .pt-opportunity-sidebar-form__back-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  min-width: 0;
}
.pt-opportunity-sidebar-form__back-row {
  justify-content: flex-start;
}
.pt-opportunity-sidebar-form__back {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0;
  border: 0;
  background: transparent;
  color: var(--color-primary);
  cursor: pointer;
  font: inherit;
  font-size: 0.9375rem;
  font-weight: 600;
}
.pt-opportunity-sidebar-form__title {
  min-width: 0;
  margin: 0;
  color: var(--color-text);
  font-size: 1.125rem;
  font-weight: 800;
  line-height: 1.25;
}
.pt-opportunity-sidebar-form__close {
  display: inline-flex;
  flex: 0 0 auto;
  align-items: center;
  justify-content: center;
  width: 2rem;
  height: 2rem;
  border: 0;
  border-radius: 999px;
  background: transparent;
  color: var(--color-text);
  cursor: pointer;
}
.pt-opportunity-sidebar-form__close:hover {
  background: var(--color-surface-muted);
}
.pt-opportunity-sidebar-form__divider {
  margin: 1.25rem 0 1.5rem;
  border-top: 1px dotted var(--color-border);
}
.pt-opportunity-sidebar-form__errors {
  width: 100%;
  margin-bottom: 1rem;
  padding: 0.75rem;
  border: 1px solid color-mix(in srgb, oklch(52% 0.18 25) 35%, oklch(88% 0 0));
  @supports (color: color-mix(in lab, red, red)) {
    border: 1px solid color-mix(in srgb, var(--color-danger) 35%, var(--color-border));
  }
  border-radius: 0.375rem;
  background: color-mix(in srgb, oklch(52% 0.18 25) 8%, oklch(99% 0 0));
  @supports (color: color-mix(in lab, red, red)) {
    background: color-mix(in srgb, var(--color-danger) 8%, var(--color-surface));
  }
  color: var(--color-danger);
  font-size: 0.8125rem;
  line-height: 1.4;
}
.pt-opportunity-sidebar-form__body {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  width: 100%;
  min-width: 0;
  max-width: 100%;
}
.pt-opportunity-sidebar-form__field {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  width: 100%;
  min-width: 0;
  max-width: 100%;
}
.pt-opportunity-sidebar-form__label {
  display: inline-flex;
  align-items: flex-start;
  gap: 0.375rem;
  width: fit-content;
  max-width: 100%;
  margin: 0;
  color: var(--color-text-muted);
  font-size: 0.75rem;
  font-weight: 800;
  letter-spacing: 0.02em;
  line-height: 1.2;
  text-transform: uppercase;
}
.pt-opportunity-sidebar-form__required {
  flex: 0 0 auto;
  color: var(--color-danger);
}
.pt-opportunity-sidebar-form__input, .pt-opportunity-sidebar-form__textarea {
  width: 100%;
  max-width: 100%;
  border: 1px solid var(--color-border);
  border-radius: var(--opportunities-sidebar-control-radius);
  background: #fff;
  color: var(--color-text);
  font-size: 0.875rem;
}
.pt-opportunity-sidebar-form__input {
  height: 2.875rem;
  min-height: 2.875rem;
  padding: 0 0.875rem;
}
.pt-opportunity-sidebar-form__textarea {
  min-height: 14rem;
  padding: 0.75rem;
  resize: vertical;
}
.pt-opportunity-sidebar-form__input:focus, .pt-opportunity-sidebar-form__custom-select-button:focus {
  border-color: var(--color-primary);
  outline: 2px solid var(--color-primary);
  @supports (color: color-mix(in lab, red, red)) {
    outline: 2px solid color-mix(in srgb, var(--color-primary) 18%, transparent);
  }
  outline-offset: 0;
}
.pt-opportunity-sidebar-form__money {
  display: grid;
  grid-template-columns: 5.5rem minmax(0, 1fr);
  width: 100%;
  min-width: 0;
}
.pt-opportunity-sidebar-form__money .pt-opportunity-sidebar-form__input {
  border-left: 0;
  border-radius: 0 var(--opportunities-sidebar-control-radius) var(--opportunities-sidebar-control-radius) 0;
}
.pt-opportunity-sidebar-form__row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 0.82fr);
  gap: 0.75rem;
  align-items: start;
  width: 100%;
  min-width: 0;
}
.pt-opportunity-sidebar-form__row--type-date {
  grid-template-columns: minmax(0, 0.9fr) minmax(0, 1fr);
}
.pt-opportunity-sidebar-form__row--assignee-status {
  grid-template-columns: minmax(0, 1fr) minmax(7rem, 0.72fr);
}
.pt-opportunity-sidebar-form__row .pt-opportunity-sidebar-form__field {
  display: grid;
  grid-template-rows: minmax(2.25rem, auto) 2.875rem;
  height: 100%;
}
.pt-opportunity-sidebar-form__row .pt-opportunity-sidebar-form__label {
  align-items: flex-end;
  min-height: 2.25rem;
}
.pt-opportunity-sidebar-form__date-wrap, .pt-opportunity-sidebar-form__custom-select {
  position: relative;
  width: 100%;
  min-width: 0;
  max-width: 100%;
}
.pt-opportunity-sidebar-form__date {
  padding-right: 2.5rem;
  color-scheme: light;
}
.pt-opportunity-sidebar-form__date-icon {
  position: absolute;
  top: 50%;
  right: 0.75rem;
  width: 1rem;
  height: 1rem;
  color: var(--color-text-muted);
  pointer-events: none;
  transform: translateY(-50%);
}
.pt-opportunity-sidebar-form__date::-webkit-calendar-picker-indicator {
  position: absolute;
  right: 0.625rem;
  z-index: 2;
  width: 1.25rem;
  height: 1.25rem;
  cursor: pointer;
  opacity: 0;
}
.pt-opportunity-sidebar-form__custom-select-button {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.625rem;
  width: 100%;
  max-width: 100%;
  height: 2.875rem;
  padding: 0 0.875rem;
  border: 1px solid var(--color-border);
  border-radius: var(--opportunities-sidebar-control-radius);
  background: #fff;
  color: var(--color-text);
  cursor: pointer;
  font: inherit;
  font-size: 0.875rem;
  text-align: left;
}
.pt-opportunity-sidebar-form__custom-select-button--currency {
  border-radius: var(--opportunities-sidebar-control-radius) 0 0 var(--opportunities-sidebar-control-radius);
}
.pt-opportunity-sidebar-form__custom-select-label {
  flex: 1;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.pt-opportunity-sidebar-form__custom-select--assignee .pt-opportunity-sidebar-form__custom-select-button {
  display: grid;
  grid-template-columns: 1.625rem minmax(0, 1fr) 1rem;
  gap: 0.5rem;
  min-width: 0;
  padding-right: 0.75rem;
}
.pt-opportunity-sidebar-form__custom-select--assignee .pt-opportunity-sidebar-form__custom-select-label {
  font-size: 0.75rem;
  line-height: 1.2;
}
.pt-opportunity-sidebar-form__owner-avatar {
  display: inline-flex;
  flex: 0 0 auto;
  align-items: center;
  justify-content: center;
  width: 1.625rem;
  height: 1.625rem;
  border-radius: 999px;
  background: #d1d5db;
  color: #6b7280;
  font-size: 0.6875rem;
  font-weight: 800;
  line-height: 1;
}
.pt-opportunity-sidebar-form__custom-select-menu {
  position: absolute;
  z-index: 80;
  top: calc(100% + 0.125rem);
  right: 0;
  left: 0;
  width: auto;
  max-width: 100%;
  max-height: 23.75rem;
  overflow-x: hidden;
  overflow-y: auto;
  border: 1px solid var(--color-border);
  border-radius: var(--opportunities-sidebar-control-radius);
  background: #fff;
  box-shadow: 0 12px 28px rgb(15 23 42 / 16%);
}
.pt-opportunity-sidebar-form__custom-select-menu--currency {
  width: 8.75rem;
  right: auto;
}
.pt-opportunity-sidebar-form__custom-select-option {
  display: flex;
  align-items: center;
  gap: 0.625rem;
  width: 100%;
  min-width: 0;
  min-height: 2.375rem;
  padding: 0 0.875rem;
  border: 0;
  border-bottom: 1px solid var(--color-border);
  background: #fff;
  color: var(--color-text);
  cursor: pointer;
  font: inherit;
  font-size: 0.875rem;
  text-align: left;
}
.pt-opportunity-sidebar-form__custom-select-option:last-child {
  border-bottom: 0;
}
.pt-opportunity-sidebar-form__custom-select-option:hover, .pt-opportunity-sidebar-form__custom-select-option:focus {
  background: var(--color-primary);
  @supports (color: color-mix(in lab, red, red)) {
    background: color-mix(in srgb, var(--color-primary) 10%, #fff);
  }
  outline: none;
}
.pt-opportunity-sidebar-form__custom-select-option--owner {
  min-height: 2.875rem;
}
.pt-opportunity-sidebar-form__custom-select-option--owner > span:last-child {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.pt-opportunity-sidebar-form__custom-select--status .pt-opportunity-sidebar-form__custom-select-button {
  padding: 0 0.625rem;
}
.pt-opportunity-sidebar-form__custom-select--status .pt-opportunity-sidebar-form__custom-select-option {
  min-height: 2.625rem;
  padding: 0 0.75rem;
}
.pt-opportunity-sidebar-form__status-pill {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 4rem;
  min-height: 1.25rem;
  padding: 0 0.5rem;
  border-radius: 999px;
  font-size: 0.5625rem;
  font-weight: 800;
  line-height: 1;
  text-align: center;
  text-transform: uppercase;
  white-space: nowrap;
}
.pt-opportunity-sidebar-form__status-pill--on_radar, .pt-opportunity-sidebar-form__status-pill--new {
  background: rgb(17 24 39);
  color: #fff;
}
.pt-opportunity-sidebar-form__status-pill--ongoing {
  background: #f47b20;
  color: #fff;
}
.pt-opportunity-sidebar-form__status-pill--on_hold {
  background: #f59e0b;
  color: #fff;
}
.pt-opportunity-sidebar-form__status-pill--completed, .pt-opportunity-sidebar-form__status-pill--won {
  background: #16a34a;
  color: #fff;
}
.pt-opportunity-sidebar-form__status-pill--cancelled, .pt-opportunity-sidebar-form__status-pill--lost {
  background: #dc2626;
  color: #fff;
}
.pt-opportunity-sidebar-form__status-pill--qualified {
  background: #7c3aed;
  color: #fff;
}
.pt-opportunity-sidebar-form__status-pill--unknown {
  background: #e5e7eb;
  color: #4b5563;
}
.pt-opportunity-sidebar-form__note-field {
  gap: 0.75rem;
}
.pt-opportunity-sidebar-form__note-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  min-width: 0;
}
.pt-opportunity-sidebar-form__add-note, .pt-opportunity-sidebar-form__cancel-note {
  display: inline-flex;
  align-items: center;
  align-self: flex-start;
  gap: 0.375rem;
  padding: 0;
  border: 0;
  background: transparent;
  cursor: pointer;
  font: inherit;
  font-weight: 600;
}
.pt-opportunity-sidebar-form__add-note {
  color: var(--color-primary);
  font-size: 0.9375rem;
}
.pt-opportunity-sidebar-form__add-note--inline {
  align-self: center;
  font-size: 0.8125rem;
  white-space: nowrap;
}
.pt-opportunity-sidebar-form__cancel-note {
  margin-top: 0.5rem;
  color: var(--color-text-muted);
  font-size: 0.875rem;
}
.pt-opportunity-sidebar-form__add-note--inline:hover, .pt-opportunity-sidebar-form__cancel-note:hover {
  color: var(--color-primary);
  text-decoration: underline;
}
.pt-opportunity-sidebar-form__notes {
  width: 100%;
  min-width: 0;
  max-width: 100%;
}
.pt-opportunity-sidebar-form .pt-markdown-field {
  width: 100%;
  max-width: 100%;
  overflow: hidden;
  border: 1px solid var(--color-border);
  border-radius: 0.375rem;
  background: #fff;
}
.pt-opportunity-sidebar-form .pt-markdown-field__textarea {
  width: 100%;
  min-height: 14rem;
  border: 0;
  border-radius: 0;
  background: #fff;
}
.pt-opportunity-sidebar-form .pt-markdown-field__textarea:focus {
  outline: none;
}
.pt-opportunity-sidebar-form__notes-actions {
  display: flex;
  justify-content: flex-end;
  margin-top: 0.25rem;
}
.pt-opportunity-sidebar-form__notes-cancel {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 2.25rem;
  padding: 0 0.875rem;
  border: 1px solid var(--color-border);
  border-radius: var(--opportunities-sidebar-control-radius);
  background: #fff;
  color: var(--color-text);
  cursor: pointer;
  font: inherit;
  font-size: 0.8125rem;
  font-weight: 700;
}
.pt-opportunity-sidebar-form__notes-cancel:hover {
  background: var(--color-surface-muted);
}
.pt-opportunity-sidebar-form__submit, .pt-opportunity-sidebar-form__task-section-action {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  width: 100%;
  border: 0;
  border-radius: var(--opportunities-sidebar-control-radius);
  background: #00a978;
  color: #fff;
  cursor: pointer;
  font-weight: 800;
}
.pt-opportunity-sidebar-form__submit {
  min-height: 2.875rem;
  margin-top: 1rem;
  font-size: 0.875rem;
}
.pt-opportunity-sidebar-form__task-section-action {
  min-height: 2.75rem;
  margin-top: 0.75rem;
  padding: 0 1rem;
  font-size: 0.875rem;
}
.pt-opportunity-sidebar-form__submit:hover, .pt-opportunity-sidebar-form__task-section-action:hover {
  background: #00966b;
}
.pt-opportunity-sidebar-form__submit:disabled, .pt-opportunity-sidebar-form__submit--loading {
  cursor: wait;
  opacity: 0.65;
}
.pt-opportunity-sidebar-form__task-section, .pt-opportunity-sidebar-form__detail-tabs, .pt-opportunity-task-form__tabs {
  display: flex;
  flex-direction: column;
  gap: 0.875rem;
  width: 100%;
  min-width: 0;
  max-width: 100%;
  margin-top: 1.25rem;
  padding-top: 0;
  border-top: 1px solid var(--color-border);
}
.pt-opportunity-sidebar-form__detail-tabs .pt-opportunity-sidebar-form__task-section {
  margin: 0;
  padding: 0;
  border: 0;
}
.pt-opportunity-sidebar-form__task-section-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  min-width: 0;
}
.pt-opportunity-sidebar-form__task-section-title {
  margin: 0;
  color: var(--color-text);
  font-size: 1rem;
  font-weight: 800;
  line-height: 1.25;
}
.pt-opportunity-sidebar-form__task-section-empty-title {
  margin: 0;
  color: var(--color-text);
  font-size: 1rem;
  font-weight: 800;
  line-height: 1.35;
}
.pt-opportunity-sidebar-form__task-section-empty {
  margin: 0.625rem 0 0;
  color: var(--color-text-muted);
  font-size: 0.8125rem;
  line-height: 1.45;
  overflow-wrap: anywhere;
}
.pt-opportunity-sidebar-form__task-list {
  display: flex;
  flex-direction: column;
  gap: 0.625rem;
  width: 100%;
  min-width: 0;
  margin: 0;
}
.pt-opportunity-sidebar-form__task-card {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 0.75rem;
  width: 100%;
  min-width: 0;
  padding: 0.75rem;
  border: 1px solid var(--color-border);
  border-radius: 0.5rem;
  background: #fff;
  color: inherit;
  cursor: pointer;
  text-align: left;
  transition: background-color 0.16s ease, border-color 0.16s ease, box-shadow 0.16s ease;
}
.pt-opportunity-sidebar-form__task-card:hover {
  border-color: var(--color-primary);
  @supports (color: color-mix(in lab, red, red)) {
    border-color: color-mix(in srgb, var(--color-primary) 36%, var(--color-border));
  }
  background: var(--color-primary);
  @supports (color: color-mix(in lab, red, red)) {
    background: color-mix(in srgb, var(--color-primary) 5%, #fff);
  }
  box-shadow: 0 8px 18px rgb(15 23 42 / 8%);
}
.pt-opportunity-sidebar-form__task-card-main, .pt-opportunity-sidebar-form__task-card-meta {
  display: flex;
  flex-direction: column;
  gap: 0.375rem;
  min-width: 0;
}
.pt-opportunity-sidebar-form__task-card-meta {
  align-items: flex-end;
}
.pt-opportunity-sidebar-form__task-card-type, .pt-opportunity-sidebar-form__task-card-assignee, .pt-opportunity-sidebar-form__task-card-date {
  color: var(--color-text-muted);
  font-size: 0.75rem;
  line-height: 1.35;
}
.pt-opportunity-sidebar-form__task-card-title, .pt-opportunity-sidebar-form__task-card-assignee {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.pt-opportunity-sidebar-form__task-card-title {
  color: var(--color-text);
  font-size: 0.875rem;
  font-weight: 800;
}
.pt-opportunity-sidebar-form__task-card-date {
  display: inline-flex;
  align-items: center;
  justify-content: flex-end;
  gap: 0.25rem;
  white-space: nowrap;
}
.pt-opportunity-sidebar-form__task-card-date--overdue {
  color: var(--color-danger);
  font-weight: 800;
}
.pt-opportunity-task-sidebar__filter-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1.25rem;
}
.pt-opportunity-task-sidebar .pt-opportunities-sidebar__check {
  display: grid;
  grid-template-columns: 1rem minmax(0, 1fr) 2.25rem;
  width: 100%;
}
.pt-opportunity-task-sidebar .pt-opportunities-sidebar__check-label, .pt-opportunity-task-form__option-label, .pt-opportunity-task-sidebar .pt-opportunity-sidebar-form__custom-select-label {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.pt-opportunity-task-sidebar__filter-count {
  justify-self: end;
  min-width: 1.625rem;
  padding: 0.0625rem 0.375rem;
  border-radius: 999px;
  background: var(--color-surface-muted);
  color: var(--color-text-muted);
  font-size: 0.6875rem;
  font-weight: 800;
  line-height: 1.25;
  text-align: center;
}
.pt-opportunity-task-sidebar .pt-opportunities-sidebar__filter-select .pt-opportunity-sidebar-form__custom-select-option {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  gap: 0.625rem;
  align-items: center;
}
.pt-opportunity-task-sidebar .pt-opportunities-sidebar__filter-select .pt-opportunity-sidebar-form__custom-select-option:not(.pt-opportunity-sidebar-form__custom-select-option--owner) {
  grid-template-columns: minmax(0, 1fr) auto;
}
.pt-opportunity-task-form__inline-link {
  align-self: flex-end;
  padding: 0;
  border: 0;
  background: transparent;
  color: var(--color-primary);
  cursor: pointer;
  font: inherit;
  font-size: 0.8125rem;
  font-weight: 700;
}
.pt-opportunity-task-form__inline-link:hover, .pt-opportunity-task-form__inline-link:focus-visible {
  text-decoration: underline;
  outline: none;
}
.pt-opportunity-task-form .pt-opportunity-sidebar-form__row, .pt-opportunity-task-form .pt-opportunity-sidebar-form__row--type-date, .pt-opportunity-task-form .pt-opportunity-sidebar-form__row--assignee-status {
  display: contents;
}
.pt-opportunity-task-form .pt-opportunity-sidebar-form__row .pt-opportunity-sidebar-form__field {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  height: auto;
}
.pt-opportunity-task-form .pt-opportunity-sidebar-form__row .pt-opportunity-sidebar-form__label {
  min-height: 0;
}
.pt-opportunity-task-form__tab-list {
  display: flex;
  align-items: stretch;
  gap: 0;
  width: 100%;
  min-width: 0;
  overflow-x: auto;
  border-bottom: 1px solid oklch(88% 0 0);
}
.pt-opportunity-task-form__tab {
  display: inline-flex;
  flex: 1 1 0;
  align-items: center;
  justify-content: center;
  gap: 0.375rem;
  min-width: max-content;
  min-height: 2.375rem;
  padding: 0.5625rem 0.625rem;
  border: 0;
  border-bottom: 1px solid transparent;
  border-radius: 0;
  background: transparent;
  color: var(--pt-text-secondary, var(--color-text-secondary));
  cursor: pointer;
  font: inherit;
  font-size: 0.6875rem;
  font-weight: 600;
  letter-spacing: 0.03em;
  line-height: 1;
  text-transform: uppercase;
  white-space: nowrap;
}
.pt-opportunity-task-form__tab--active {
  border-bottom-color: oklch(66% 0 0);
  color: var(--color-text);
}
.pt-opportunity-task-form__tab .pt-icon {
  flex: 0 0 auto;
  width: 1rem;
  height: 1rem;
}
.pt-opportunity-task-form__tab-panel, .pt-opportunity-task-form__comments-section {
  width: 100%;
  min-width: 0;
  max-width: 100%;
}
.pt-opportunity-task-form__comments-section, .pt-opportunity-task-form__comments, .pt-opportunity-task-form__history {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}
.pt-opportunity-task-form__comments-empty {
  margin: 0;
  color: var(--color-text-muted);
  font-size: 0.6875rem;
  line-height: 1.4;
}
.pt-opportunity-task-form__comment {
  display: block;
  width: 100%;
  min-width: 0;
}
.pt-opportunity-task-form__comment-avatar, .pt-opportunity-task-form__history-dot {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  background: oklch(91% 0 0);
  color: oklch(38% 0 0);
  font-size: 0.6875rem;
  font-weight: 800;
}
.pt-opportunity-task-form__comment-avatar {
  width: 2rem;
  height: 2rem;
}
.pt-opportunity-task-form__comment-body {
  display: grid;
  grid-template-columns: 2rem minmax(0, 1fr);
  column-gap: 0.625rem;
  align-items: start;
  width: 100%;
  min-width: 0;
  padding: 0.625rem 0.75rem;
  border: 1px solid var(--color-border);
  border-radius: 0.5rem;
  background: #fff;
}
.pt-opportunity-task-form__comment-avatar--inside {
  grid-row: 1 / span 2;
  align-self: start;
}
.pt-opportunity-task-form__comment-meta, .pt-opportunity-task-form__comment-text {
  grid-column: 2;
  min-width: 0;
}
.pt-opportunity-task-form__comment-meta, .pt-opportunity-task-form__history-body {
  display: flex;
  flex-direction: column;
  gap: 0.125rem;
  color: var(--color-text-muted);
  font-size: 0.6875rem;
}
.pt-opportunity-task-form__comment-meta strong, .pt-opportunity-task-form__history-body strong {
  color: var(--color-text);
  font-size: 0.75rem;
}
.pt-opportunity-task-form__comment-text {
  margin-top: 0.375rem;
  color: var(--color-text);
  font-size: 0.6875rem;
  line-height: 1.4;
  overflow-wrap: anywhere;
}
.pt-opportunity-task-form__comment-text p {
  margin: 0 0 0.5rem;
}
.pt-opportunity-task-form__comment-text p:last-child {
  margin-bottom: 0;
}
.pt-opportunity-task-form__history-item {
  display: grid;
  grid-template-columns: 0.625rem minmax(0, 1fr);
  gap: 0.5rem;
  width: 100%;
  min-width: 0;
}
.pt-opportunity-task-form__history-dot {
  width: 0.625rem;
  height: 0.625rem;
  margin-top: 0.2rem;
  background: var(--color-primary);
}
.pt-opportunity-task-form__history-body {
  min-width: 0;
  overflow-wrap: anywhere;
  word-break: break-word;
}
.pt-opportunity-task-form__empty {
  padding: 0.75rem;
  border: 1px dashed var(--color-border);
  border-radius: 0.375rem;
  color: var(--color-text-muted);
  font-size: 0.75rem;
}
.pt-opportunity-task-form__comment-form {
  width: 100%;
  min-width: 0;
  margin: 0;
}
.pt-opportunity-task-form__composer {
  display: grid;
  grid-template-columns: 2rem minmax(0, 1fr) 2rem;
  gap: 0.625rem;
  width: 100%;
  max-width: 100%;
  margin: 0;
  padding: 0.625rem;
  border: 1px solid var(--color-border);
  border-radius: 0.5rem;
  background: #fff;
  box-shadow: none;
}
.pt-opportunity-task-form__composer:focus-within {
  border-color: var(--color-border);
  box-shadow: none;
}
.pt-opportunity-task-form__comment-avatar--composer {
  width: 2rem;
  height: 2rem;
  margin-top: 0;
}
.pt-opportunity-task-form__comment-input, .pt-opportunity-task-form__comment-input:focus {
  width: 100%;
  min-width: 0;
  min-height: 2rem;
  max-height: none;
  padding: 0.125rem 0 0;
  border: 0;
  outline: none !important;
  background: transparent;
  box-shadow: none !important;
  color: var(--color-text);
  font: inherit;
  font-size: 0.875rem;
  line-height: 1.45;
  resize: none;
  overflow: hidden;
}
.pt-opportunity-task-form__comment-input::placeholder {
  color: var(--color-text-muted);
  opacity: 1;
}
.pt-opportunity-task-form__comment-submit {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2rem;
  height: 2rem;
  padding: 0;
  border: 1px solid transparent;
  border-radius: 0.3125rem;
  background: transparent;
  color: var(--color-text-muted);
  cursor: not-allowed;
  opacity: 0.55;
}
.pt-opportunity-task-form__comment-submit:disabled {
  cursor: not-allowed;
  pointer-events: none;
}
.pt-opportunity-task-form__comment-submit--ready {
  border-color: #00a978;
  background: #00a978;
  color: #fff;
  cursor: pointer;
  opacity: 1;
  pointer-events: auto;
}
.pt-opportunity-task-form__comment-submit--ready:hover, .pt-opportunity-task-form__comment-submit--ready:focus-visible {
  border-color: #00966b;
  background: #00966b;
  color: #fff;
  outline: none;
}
.pt-opportunity-task-form__comment-submit .pt-icon {
  width: 0.875rem;
  height: 0.875rem;
}
.pt-opportunity-task-form__detail-pagination {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 1rem;
  width: 100%;
  margin: 1rem auto 0;
}
.pt-opportunity-task-form__detail-pagination-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.5rem;
  height: 2.5rem;
  padding: 0;
  border: 1px solid var(--color-border);
  border-radius: 0.5rem;
  background: #fff;
  color: var(--color-text);
  cursor: pointer;
}
.pt-opportunity-task-form__detail-pagination-button:hover:not(:disabled) {
  border-color: var(--color-primary);
  color: var(--color-primary);
}
.pt-opportunity-task-form__detail-pagination-button:disabled {
  cursor: not-allowed;
  opacity: 0.45;
}
.pt-opportunity-task-form__detail-pagination-label {
  min-width: 3rem;
  color: var(--color-text-muted);
  font-size: 0.875rem;
  font-weight: 800;
  text-align: center;
}
@media (max-width: 640px) {
  .pt-opportunities-sidebar__toolbar {
    grid-template-columns: 2.25rem minmax(0, 1fr);
  }
  .pt-opportunities-sidebar__new-primary {
    grid-column: 1 / -1;
  }
  .pt-opportunities-sidebar__filter-grid, .pt-opportunity-sidebar-form__row, .pt-opportunity-sidebar-form__row--type-date, .pt-opportunity-sidebar-form__row--assignee-status {
    grid-template-columns: 1fr;
  }
  .pt-opportunity-sidebar-form__row .pt-opportunity-sidebar-form__field {
    grid-template-rows: auto 2.875rem;
  }
  .pt-opportunity-sidebar-form__row .pt-opportunity-sidebar-form__label {
    min-height: 0;
  }
  .pt-opportunity-sidebar-form__money {
    grid-template-columns: 1fr;
  }
  .pt-opportunity-sidebar-form__money .pt-opportunity-sidebar-form__input, .pt-opportunity-sidebar-form__custom-select-button--currency {
    border: 1px solid var(--color-border);
    border-radius: var(--opportunities-sidebar-control-radius);
  }
  .pt-opportunity-sidebar-form__task-card {
    grid-template-columns: 1fr;
  }
  .pt-opportunity-sidebar-form__task-card-meta {
    align-items: flex-start;
  }
  .pt-opportunity-sidebar-form__detail-tabs {
    padding-top: 1.25rem;
  }
  .pt-opportunity-sidebar-form__task-section {
    margin: 0;
    padding: 0;
    border: 0;
  }
  .pt-opportunity-task-form__inline-link {
    margin-bottom: -0.25rem;
  }
}
.pt-task-directory {
  display: flex;
  flex-direction: column;
  gap: 0;
  width: 100%;
}
.pt-task-directory__header {
  position: sticky;
  top: 0;
  z-index: 20;
  margin: -1rem -1.5rem 0.875rem;
  padding: 0.75rem 1.5rem 0;
  border-bottom: 0;
  background: var(--color-surface);
}
.pt-task-directory__header .pt-page-header {
  min-height: 0;
  margin: 0;
  padding: 0.375rem 0 0.625rem;
  border-bottom: 0;
}
.pt-task-directory__header .pt-page-header__title {
  font-size: 1.1875rem;
  line-height: 1.25;
}
.pt-task-directory__tabs {
  margin-top: 0.25rem;
  margin-right: -1.5rem;
  margin-left: -1.5rem;
  border-bottom: 1px solid oklch(88% 0 0);
}
.pt-task-directory__tabs .pt-task-directory__tab {
  min-height: 2.5rem;
  padding: 0.625rem 0.875rem;
  border-bottom-width: 2px;
  font-size: 0.75rem;
}
.pt-task-directory__tabs .pt-task-directory__tab:not(.pt-task-directory__tab--active) {
  border-bottom-color: transparent;
}
.pt-task-directory__tabs .pt-task-directory__tab--active {
  color: var(--pt-primary, var(--color-brand));
  border-bottom-color: var(--pt-primary, var(--color-brand));
}
.pt-task-directory__tabs .pt-project-tab__icon {
  width: 1.25rem;
  height: 1.25rem;
}
.pt-task-directory-filters, .pt-task-directory-filters__checks, .pt-task-directory-filters__field, .pt-task-directory-filters__actions {
  display: flex;
  flex-direction: column;
}
.pt-task-directory-filters {
  gap: 1rem;
}
.pt-task-directory-filters__checks {
  gap: 0.5rem;
}
.pt-task-directory-filters__field {
  gap: 0.375rem;
}
.pt-task-directory-filters__option {
  font-size: 0.8125rem;
}
.pt-task-directory-filters__input {
  width: 100%;
}
.pt-task-directory-filters__search {
  width: 100%;
  height: 2rem;
  padding: 0 0.625rem;
  border: 1px solid var(--color-border);
  border-radius: 0.375rem;
  background: #fff;
  color: var(--color-text);
  font-size: 0.8125rem;
}
.pt-task-directory-filters__search:focus {
  border-color: var(--color-primary);
  outline: 2px solid var(--color-primary);
  @supports (color: color-mix(in lab, red, red)) {
    outline: 2px solid color-mix(in srgb, var(--color-primary) 18%, transparent);
  }
  outline-offset: 0;
}
.pt-task-directory-filters__date-grid {
  display: grid;
  gap: 0.75rem;
}
.pt-task-directory-filters__date-grid .pt-date-range__inputs {
  display: grid;
  grid-template-columns: 1fr;
  gap: 0.75rem;
}
.pt-task-directory-filters__date-grid .pt-date-range__separator {
  display: none;
}
.pt-task-directory-filters__actions {
  flex-direction: row;
  align-items: center;
  justify-content: flex-end;
  gap: 0.625rem;
  padding-top: 0.25rem;
  border-top: 1px solid oklch(92% 0 0);
}
.pt-task-hits {
  min-width: 0;
}
.pt-task-hits-inner, .pt-task-list {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
  margin: 0;
  padding: 0;
  list-style: none;
}
.pt-task-list__item {
  margin: 0;
  padding: 0;
}
.pt-intelligence-task-card--directory {
  position: relative;
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 1rem;
  min-width: 0;
  padding: 1rem;
  border-color: oklch(90% 0 0);
  border-radius: 0.5rem;
  background: var(--color-surface);
  box-shadow: 0 1px 2px oklch(0% 0 0 / 4%);
  transition: background-color 0.12s ease, border-color 0.12s ease, box-shadow 0.12s ease;
}
.pt-intelligence-task-card--directory:hover {
  border-color: color-mix(in srgb, oklch(45% 0.18 250) 45%, white);
  @supports (color: color-mix(in lab, red, red)) {
    border-color: color-mix(in oklch, var(--color-brand) 45%, white);
  }
  background: color-mix(in srgb, oklch(45% 0.18 250) 5%, white);
  @supports (color: color-mix(in lab, red, red)) {
    background: color-mix(in oklch, var(--color-brand) 5%, white);
  }
  box-shadow: 0 10px 26px oklch(40% 0.05 250 / 10%);
  cursor: pointer;
}
.pt-intelligence-task-card--directory .pt-intelligence-task-card__header {
  min-width: 0;
  padding-right: 4rem;
}
.pt-intelligence-task-card--directory .pt-intelligence-task-card__icon {
  width: 1.25rem;
  height: 1.25rem;
  margin-top: 0.0625rem;
  border-radius: 0;
  background: transparent;
  color: oklch(24% 0 0);
  opacity: 0.86;
}
.pt-intelligence-task-card--directory .pt-intelligence-task-card__icon-svg {
  width: 1rem;
  height: 1rem;
}
.pt-intelligence-task-card--directory .pt-intelligence-task-card__title {
  color: oklch(24% 0 0);
  font-size: 0.9375rem;
  font-weight: 700;
  line-height: 1.35;
}
.pt-intelligence-task-card--directory .pt-intelligence-task-card__line {
  margin-top: 0.5rem;
  font-size: 0.8125rem;
  line-height: 1.4;
}
.pt-intelligence-task-card--directory .pt-intelligence-task-card__footer {
  grid-column: 1 / -1;
  margin-top: 0;
}
.pt-intelligence-task-card__comments {
  position: absolute;
  top: 1rem;
  right: 1rem;
  display: inline-flex;
  align-items: center;
  gap: 0.25rem;
  flex: 0 0 auto;
  color: oklch(42% 0 0);
  font-size: 0.75rem;
  font-weight: 600;
  pointer-events: none;
}
.pt-intelligence-task-card__comments .pt-icon {
  width: 1rem;
  height: 1rem;
}
.pt-intelligence-task-card__details {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  margin-top: 0.5rem;
}
.pt-intelligence-task-card__line {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 0.375rem;
}
.pt-intelligence-task-card__label {
  color: oklch(48% 0 0);
  font-weight: 700;
}
.pt-intelligence-task-card__footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  margin-top: 0.875rem;
}
.pt-intelligence-task-card__footer-left {
  display: inline-flex;
  align-items: center;
  min-width: 0;
}
.pt-intelligence-task-card--directory .pt-intelligence-task-card__status {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 4.875rem;
  min-height: 1.25rem;
  padding: 0 0.625rem;
  border-radius: 999px;
  font-size: 0.625rem;
  font-weight: 800;
  line-height: 1;
  text-align: center;
  text-transform: uppercase;
  white-space: nowrap;
}
.pt-intelligence-task-card__due {
  display: inline-flex;
  align-items: center;
  justify-content: flex-end;
  gap: 0.25rem;
  flex: 0 0 auto;
  margin-left: auto;
  color: var(--color-text-secondary);
  font-size: 0.75rem;
  line-height: 1.3;
  white-space: nowrap;
}
.pt-intelligence-task-card__due-icon {
  width: 1rem;
  height: 1rem;
  color: var(--color-text-secondary);
}
.pt-intelligence-task-card__type {
  color: oklch(42% 0 0);
  font-size: 0.75rem;
  font-weight: 700;
}
.pt-intelligence-task-card__status--new {
  background: oklch(95% 0 0);
  color: oklch(35% 0 0);
}
.pt-intelligence-task-card__status--ongoing {
  background: #f47b20;
  color: #ffffff;
}
.pt-intelligence-task-card__status--on_hold {
  background: #0b5596;
  color: #ffffff;
}
.pt-intelligence-task-card__status--completed, .pt-intelligence-task-card__status--current {
  background: #16a34a;
  color: #ffffff;
}
.pt-intelligence-task-card__status--cancelled, .pt-intelligence-task-card__status--overdue {
  background: #dc2626;
  color: #ffffff;
}
.pt-intelligence-task-card__status--upcoming {
  background: #0b5596;
  color: #ffffff;
}
.pt-intelligence-task-card__due--overdue, .pt-intelligence-task-card__due--overdue .pt-intelligence-task-card__due-icon {
  color: var(--color-danger);
  font-weight: 800;
}
.pt-task-search-highlight {
  padding: 0 0.0625rem;
  border-radius: 0.125rem;
  background: #ffeb7a;
  color: inherit;
  font-style: normal;
}
.pt-task-empty {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  min-height: 22rem;
  padding: 3rem 1.5rem;
  border: 1px dashed oklch(85% 0 0);
  border-radius: 0.5rem;
  background: oklch(98% 0 0);
  text-align: center;
}
.pt-task-empty__icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 3rem;
  height: 3rem;
  margin-bottom: 1rem;
  border-radius: 999px;
  background: oklch(93% 0 0);
  color: oklch(42% 0 0);
}
.pt-task-empty__title {
  margin: 0;
  color: oklch(24% 0 0);
  font-size: 1.125rem;
  font-weight: 800;
}
.pt-task-empty__text {
  max-width: 28rem;
  margin: 0.5rem 0 1rem;
  color: oklch(48% 0 0);
  font-size: 0.875rem;
  line-height: 1.5;
}
.pt-task-directory .pt-pagination {
  display: inline-flex;
  align-items: center;
  gap: 0.75rem;
  padding: 0;
}
.pt-task-directory .pt-directory-pagination {
  display: flex;
  justify-content: center;
  width: 100%;
  margin-top: 1.25rem;
}
.pt-task-directory .pt-pagination__link {
  color: var(--color-brand);
  font-size: 0.8125rem;
  font-weight: 800;
  text-decoration: none;
}
.pt-task-directory .pt-pagination__link:hover, .pt-task-directory .pt-pagination__link:focus-visible {
  text-decoration: underline;
  outline: none;
}
.pt-task-directory .pt-pagination__status {
  color: oklch(42% 0 0);
  font-size: 0.8125rem;
  font-weight: 700;
}
.pt-task-directory .pt-search-input--algolia {
  width: 100%;
}
.pt-task-directory .pt-search-input--algolia .pt-search-input__form {
  width: 100%;
}
.pt-task-directory .pt-search-input--algolia .pt-search-input__field {
  width: 100%;
  min-height: 2.25rem;
  padding-left: 2.25rem;
  box-sizing: border-box;
}
.pt-task-directory .pt-task-directory-filters--parity {
  gap: 0;
}
.pt-task-directory .pt-task-directory-filters--parity .pt-filter-section__body {
  padding-bottom: 0.875rem;
}
.pt-task-directory .pt-task-directory-filters__field, .pt-task-directory .pt-task-directory-filters__keyword-search, .pt-task-directory .pt-task-directory-filters__filter-search {
  width: 100%;
}
.pt-task-directory .pt-task-directory-filters__keyword-search, .pt-task-directory .pt-task-directory-filters__filter-search {
  position: relative;
  display: block;
  min-width: 0;
}
.pt-task-directory .pt-task-directory-filters__keyword-search > .pt-icon-wrap, .pt-task-directory .pt-task-directory-filters__filter-search > .pt-icon-wrap, .pt-task-directory .pt-task-directory-filters__keyword-icon, .pt-task-directory .pt-task-directory-filters__filter-search-icon {
  position: absolute;
  top: 50%;
  left: 0.75rem;
  z-index: 2;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1rem;
  height: 1rem;
  margin: 0;
  padding: 0;
  color: oklch(46% 0 0);
  line-height: 1;
  pointer-events: none;
  transform: translateY(-50%);
}
.pt-task-directory .pt-task-directory-filters__keyword-search > .pt-icon-wrap, .pt-task-directory .pt-task-directory-filters__filter-search > .pt-icon-wrap {
  overflow: visible;
}
.pt-task-directory .pt-task-directory-filters__keyword-icon, .pt-task-directory .pt-task-directory-filters__filter-search-icon, .pt-task-directory .pt-task-directory-filters__keyword-search > .pt-icon-wrap svg, .pt-task-directory .pt-task-directory-filters__filter-search > .pt-icon-wrap svg {
  display: block;
  width: 1rem;
  height: 1rem;
}
.pt-task-directory .pt-task-directory-filters__keyword-input, .pt-task-directory .pt-task-directory-filters__filter-search-input {
  display: block;
  width: 100%;
  min-width: 0;
  min-height: 2.25rem;
  padding: 0.5rem 0.75rem 0.5rem 2.375rem;
  border: 1px solid oklch(86% 0 0);
  border-radius: 0.5rem;
  background: var(--color-surface);
  box-shadow: none;
  box-sizing: border-box;
}
.pt-task-directory .pt-task-directory-filters__keyword-input:focus, .pt-task-directory .pt-task-directory-filters__filter-search-input:focus {
  border-color: var(--color-brand);
  outline: 2px solid color-mix(in srgb, oklch(45% 0.18 250) 16%, transparent);
  @supports (color: color-mix(in lab, red, red)) {
    outline: 2px solid color-mix(in oklch, var(--color-brand) 16%, transparent);
  }
  outline-offset: 0;
}
.pt-task-directory .pt-opportunities-description-toggle {
  display: inline-flex;
  align-items: center;
  margin-top: 0.75rem;
}
.pt-task-directory .pt-task-directory-filter-option {
  display: grid;
  grid-template-columns: 1rem minmax(0, 1fr) auto;
  align-items: center;
  column-gap: 0.5rem;
  width: 100%;
  min-width: 0;
  min-height: 1.625rem;
}
.pt-task-directory .pt-task-directory-filter-option .pt-checkbox__indicator {
  grid-column: 1;
}
.pt-task-directory .pt-task-directory-filter-option .pt-filter-option__label {
  grid-column: 2;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.pt-task-directory .pt-task-directory-filter-option .pt-filter-option__count {
  grid-column: 3;
  justify-self: end;
  min-width: 1.5rem;
  margin-left: 0.25rem;
}
.pt-task-directory .pt-task-directory-filter-option--status {
  grid-template-columns: 1rem minmax(0, 1fr) auto;
}
.pt-task-directory .pt-task-directory-filter-option--status .pt-task-directory-filter-option__status {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  grid-column: 2;
  width: 100%;
  max-width: 100%;
  min-height: 1.25rem;
  padding: 0 0.625rem;
  border-radius: 999px;
  font-size: 0.625rem;
  font-weight: 800;
  line-height: 1;
  letter-spacing: 0.02em;
  text-align: center;
  text-transform: uppercase;
  white-space: nowrap;
  box-sizing: border-box;
}
.pt-task-directory .pt-task-directory-filter-option--status .pt-task-directory-filter-option__status--new, .pt-task-directory .pt-task-directory-filter-option--status:has(.pt-checkbox__input:checked) .pt-task-directory-filter-option__status--new {
  background: oklch(95% 0 0);
  color: oklch(35% 0 0);
}
.pt-task-directory .pt-task-directory-filter-option--status .pt-task-directory-filter-option__status--ongoing, .pt-task-directory .pt-task-directory-filter-option--status:has(.pt-checkbox__input:checked) .pt-task-directory-filter-option__status--ongoing {
  background: #f47b20;
  color: #ffffff;
}
.pt-task-directory .pt-task-directory-filter-option--status .pt-task-directory-filter-option__status--on_hold, .pt-task-directory .pt-task-directory-filter-option--status:has(.pt-checkbox__input:checked) .pt-task-directory-filter-option__status--on_hold {
  background: #0b5596;
  color: #ffffff;
}
.pt-task-directory .pt-task-directory-filter-option--status .pt-task-directory-filter-option__status--completed, .pt-task-directory .pt-task-directory-filter-option--status:has(.pt-checkbox__input:checked) .pt-task-directory-filter-option__status--completed {
  background: #16a34a;
  color: #ffffff;
}
.pt-task-directory .pt-task-directory-filter-option--status .pt-task-directory-filter-option__status--cancelled, .pt-task-directory .pt-task-directory-filter-option--status .pt-task-directory-filter-option__status--overdue, .pt-task-directory .pt-task-directory-filter-option--status:has(.pt-checkbox__input:checked) .pt-task-directory-filter-option__status--cancelled, .pt-task-directory .pt-task-directory-filter-option--status:has(.pt-checkbox__input:checked) .pt-task-directory-filter-option__status--overdue {
  background: #dc2626;
  color: #ffffff;
}
.pt-task-directory .pt-task-directory-filters__date-grid--parity .pt-date-picker__label {
  display: none;
}
.pt-task-directory .pt-task-directory-filters__filter-search {
  margin-bottom: 0.75rem;
}
.pt-task-directory .pt-task-directory-filters__keyword-search {
  margin-bottom: 0.25rem;
}
.pt-task-directory .pt-task-directory__active-filters {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 0.625rem;
  width: 100%;
  margin-top: 0.625rem;
}
.pt-task-directory .pt-task-directory__active-filter-group {
  display: inline-flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 0.375rem;
  min-width: 0;
}
.pt-task-directory .pt-task-directory__active-filter-label {
  color: oklch(42% 0 0);
  font-size: 0.75rem;
  font-weight: 500;
  white-space: nowrap;
}
.pt-task-directory .pt-task-directory__active-filter {
  display: inline-flex;
  align-items: center;
  gap: 0.375rem;
  min-height: 1.75rem;
  max-width: 100%;
  padding: 0.22rem 0.5rem 0.22rem 0.625rem;
  border: 1px solid oklch(45% 0.18 250 / 25%);
  border-radius: 999px;
  background: oklch(45% 0.18 250 / 10%);
  color: oklch(28% 0.12 250);
  font-size: 0.75rem;
  font-weight: 500;
  line-height: 1.25;
  text-decoration: none;
  white-space: nowrap;
}
.pt-task-directory .pt-task-directory__active-filter:hover, .pt-task-directory .pt-task-directory__active-filter:focus-visible {
  border-color: oklch(45% 0.18 250 / 48%);
  background: oklch(45% 0.18 250 / 17%);
  outline: none;
}
.pt-task-directory .pt-task-directory__active-filter-value {
  overflow: hidden;
  text-overflow: ellipsis;
}
.pt-task-directory .pt-task-directory__active-filter-icon, .pt-task-directory .pt-task-directory__active-filter-icon .pt-icon, .pt-task-directory .pt-task-directory__active-filter-icon svg {
  flex: 0 0 auto;
  width: 0.75rem;
  height: 0.75rem;
}
.pt-task-directory .pt-task-directory__clear-filters {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 2.25rem;
  padding: 0.5rem 0.875rem;
  border: 1px solid oklch(84% 0 0);
  border-radius: 0.25rem;
  background: transparent;
  color: oklch(24% 0 0);
  font-size: 0.75rem;
  font-weight: 500;
  line-height: 1.25;
  text-decoration: none;
  white-space: nowrap;
}
.pt-task-directory .pt-task-directory__clear-filters:hover, .pt-task-directory .pt-task-directory__clear-filters:focus-visible {
  border-color: oklch(74% 0 0);
  background: transparent;
  color: var(--color-brand);
  outline: none;
}
.pt-saved-searches__liked-icon {
  color: oklch(55% 0.22 10);
  flex-shrink: 0;
}
.pt-product-hits {
  position: relative;
}
.pt-product-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(min(100%, 13rem), 1fr));
  gap: 1rem;
  list-style: none;
  margin: 0;
  padding: 0;
}
.pt-product-grid__item {
  display: flex;
}
.pt-product-hits--list .pt-product-grid {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}
.pt-product-card {
  position: relative;
  flex: 1;
  display: flex;
  flex-direction: column;
  background: var(--color-surface);
  border: 1px solid oklch(90% 0 0);
  border-radius: 0.75rem;
  overflow: hidden;
  box-shadow: 0 0.25rem 0.75rem oklch(20% 0 0 / 6%);
  transition: box-shadow 0.15s ease, transform 0.15s ease, border-color 0.15s ease;
  &:hover {
    border-color: oklch(82% 0 0);
    box-shadow: 0 0.5rem 1.25rem oklch(20% 0 0 / 10%);
    transform: translateY(-1px);
  }
}
.pt-product-card__header {
  position: relative;
  display: flex;
  align-items: flex-start;
  padding: 1.25rem 4.5rem 0 1.25rem;
  min-width: 0;
  flex-shrink: 0;
}
.pt-product-card__photo-link {
  flex: 1;
  min-width: 0;
  max-width: 11.25rem;
  display: block;
  text-decoration: none;
}
.pt-product-card__photo {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  aspect-ratio: 1 / 1;
  border: 1px solid oklch(86% 0 0);
  border-radius: 0.875rem;
  background: oklch(98% 0 0);
  overflow: hidden;
  img {
    width: 100%;
    height: 100%;
    object-fit: contain;
    display: block;
    transition: transform 200ms ease;
  }
  .pt-product-card:hover & img {
    transform: scale(1.03);
  }
}
.pt-product-card__photo-placeholder {
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  color: oklch(78% 0 0);
  svg {
    width: 2.5rem;
    height: 2.5rem;
  }
}
.pt-product-card__actions {
  position: absolute;
  top: 1.25rem;
  right: 1.25rem;
  z-index: 10;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.45rem;
}
.pt-product-card__body {
  padding: 0.875rem 1.25rem;
  display: flex;
  flex-direction: column;
  gap: 0.35rem;
  flex: 1;
}
.pt-product-card__title {
  font-size: 1.1rem;
  font-weight: 750;
  color: oklch(18% 0 0);
  margin: 0 0 0.1rem;
  line-height: 1.3;
  min-height: calc(2 * 1.1rem * 1.3);
  display: -webkit-box;
  -webkit-line-clamp: 2;
  line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.pt-product-card__name-link {
  color: inherit;
  text-decoration: none;
  &:hover {
    color: oklch(45% 0.18 250);
  }
}
.pt-product-card__manufacturer {
  font-size: 0.9rem;
  font-weight: 500;
  color: oklch(35% 0 0);
  margin: 0;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.pt-product-card__supplier {
  font-size: 0.9rem;
  color: oklch(55% 0 0);
  margin: 0;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.pt-category-chip {
  display: inline-flex;
  align-items: center;
  font-size: 0.8rem;
  font-weight: 500;
  background: oklch(91% 0.055 250);
  color: oklch(35% 0.18 250);
  border-radius: 99px;
  padding: 0.24rem 0.65rem;
  width: fit-content;
  margin-top: 0.25rem;
}
.pt-product-card__stats {
  display: flex;
  flex-wrap: wrap;
  gap: 0.35rem;
  margin-top: auto;
  padding-top: 0.5rem;
}
.pt-product-card__project-strip {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 0.5rem;
  padding: 0.95rem 1.25rem 1.1rem;
  border-top: 1px solid oklch(93% 0 0);
  background: oklch(98% 0 0);
}
.pt-product-card__no-projects {
  padding: 0.95rem 1.25rem 1.1rem;
  border-top: 1px solid oklch(93% 0 0);
  background: oklch(98% 0 0);
  font-size: 0.8rem;
  color: oklch(55% 0 0);
}
.pt-product-hits--list .pt-product-card {
  display: grid;
  grid-template-columns: 12rem minmax(0, 1fr);
  grid-template-areas: "header body" "header strip";
  min-height: 12rem;
  height: auto;
  border-radius: 0.5rem;
  &:hover {
    transform: none;
  }
}
.pt-product-hits--list .pt-product-card__header {
  position: static;
  grid-area: header;
  padding: 0.75rem;
  border-right: 1px solid oklch(91% 0 0);
  display: flex;
  align-items: stretch;
}
.pt-product-hits--list .pt-product-card__photo-link {
  flex: 1;
  min-width: 0;
  max-width: none;
  display: flex;
}
.pt-product-hits--list .pt-product-card__photo {
  flex: 1;
  min-width: 0;
  aspect-ratio: unset;
  border: 1px solid oklch(86% 0 0);
  border-radius: 0.75rem;
  background: oklch(98% 0 0);
}
.pt-product-hits--list .pt-product-card__actions {
  display: flex;
  flex-direction: row;
  top: 0.75rem;
  right: 0.875rem;
  gap: 0.35rem;
}
.pt-product-hits--list .pt-product-card__body {
  grid-area: body;
  flex: unset;
  padding: 0.875rem 6.5rem 0.5rem 1rem;
  gap: 0.2rem;
}
.pt-product-hits--list .pt-product-card__title {
  font-size: 0.95rem;
  -webkit-line-clamp: 2;
  line-clamp: 2;
  min-height: 0;
}
.pt-product-hits--list .pt-product-card__stats {
  display: none;
}
.pt-product-hits--list .pt-product-card__project-strip {
  grid-area: strip;
  display: grid;
  grid-template-columns: repeat(5, 2.5rem);
  justify-content: start;
  gap: 0.35rem;
  padding: 0.25rem 0 0.75rem 1rem;
  border-top: none;
  background: transparent;
  align-self: end;
}
.pt-product-hits--list .pt-project-thumb {
  width: 2.5rem;
  height: 2.5rem;
  aspect-ratio: auto;
  border-radius: 0.4rem;
}
.pt-product-hits--list .pt-project-thumb--count {
  font-size: 0.75rem;
}
.pt-product-hits--list .pt-product-card__no-projects {
  grid-area: strip;
  display: flex;
  justify-content: flex-start;
  align-self: end;
  padding: 0.25rem 0 0.75rem 1rem;
  border-top: none;
  background: transparent;
}
.pt-hierarchical-menu {
  .pt-hierarchical-menu__list {
    list-style: none;
    margin: 0;
    padding: 0;
  }
  .pt-hierarchical-menu__child-list {
    list-style: none;
    margin: 0;
    padding: 0;
    padding-left: 1rem;
    border-left: 2px solid oklch(92% 0 0);
    margin-left: 0.25rem;
    margin-top: 0.125rem;
  }
  .pt-hierarchical-menu__item {
    margin-bottom: 0.125rem;
  }
  .pt-hierarchical-menu__link {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0.2rem 0;
    font-size: 0.8125rem;
    color: oklch(30% 0 0);
    text-decoration: none;
    cursor: pointer;
    gap: 0.5rem;
    transition: color 100ms ease;
    &:hover {
      color: oklch(45% 0.18 250);
    }
  }
  .pt-hierarchical-menu__item--selected>.pt-hierarchical-menu__link {
    color: oklch(45% 0.18 250);
    font-weight: 600;
  }
  .pt-hierarchical-menu__label {
    flex: 1;
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
  }
  .pt-hierarchical-menu__count {
    font-size: 0.7rem;
    background: oklch(94% 0 0);
    border-radius: 99px;
    padding: 0.1em 0.5em;
    color: oklch(45% 0 0);
    flex-shrink: 0;
  }
  .pt-hierarchical-menu__show-more {
    font-size: 0.75rem;
    color: oklch(45% 0.18 250);
    background: none;
    border: none;
    padding: 0.25rem 0;
    cursor: pointer;
    text-decoration: underline;
    margin-top: 0.125rem;
  }
}
.pt-product-card__actions .pt-card-action-btn {
  color: oklch(66% 0 0);
  background: transparent;
  filter: drop-shadow(0 1px 1.5px oklch(20% 0 0 / 28%));
  transition: filter 140ms ease-out, color 120ms ease;
}
.pt-product-card__actions .pt-card-action-btn:hover, .pt-product-card__actions .pt-card-action-btn:focus-visible {
  background: transparent;
  color: oklch(55% 0 0);
  filter: drop-shadow(0 2px 4px oklch(20% 0 0 / 45%));
}
.pt-product-card__actions .pt-card-action-btn--like.pt-card-action-btn--active, .pt-product-card__actions .pt-card-action-btn--like.pt-card-action-btn--active:hover, .pt-product-card__actions .pt-card-action-btn--like.pt-card-action-btn--active:focus-visible {
  color: #ee5b4e;
}
.pt-product-card__actions .pt-card-action-btn--tag.pt-card-action-btn--active, .pt-product-card__actions .pt-card-action-btn--tag.pt-card-action-btn--active:hover, .pt-product-card__actions .pt-card-action-btn--tag.pt-card-action-btn--active:focus-visible {
  color: #3196d1;
}
.pt-product-card__actions .pt-card-action-btn--feature.pt-card-action-btn--active, .pt-product-card__actions .pt-card-action-btn--feature.pt-card-action-btn--active:hover, .pt-product-card__actions .pt-card-action-btn--feature.pt-card-action-btn--active:focus-visible {
  color: oklch(72% 0.16 75);
}
.pt-product-card__actions .pt-card-action-btn--delete:hover {
  color: oklch(55% 0.22 25);
}
.pt-product-directory .pt-directory-controls__top .pt-btn {
  height: 2.375rem;
}
.pt-product-card__actions--owner {
  gap: 0.45rem;
}
.pt-product-hits--list .pt-product-card__actions--owner {
  gap: 0.35rem;
}
.pt-card-action-menu {
  display: block;
  line-height: 0;
}
.pt-card-action-menu__panel {
  top: calc(100% + 0.25rem);
  right: 0;
  min-width: 11rem;
  z-index: 30;
}
.pt-card-action-menu__item {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  line-height: 1.2;
}
.pt-card-action-menu__item svg {
  width: 1rem;
  height: 1rem;
  flex-shrink: 0;
  color: oklch(45% 0 0);
}
.pt-card-action-menu__item--danger {
  color: oklch(55% 0.22 25);
}
.pt-card-action-menu__item--danger svg {
  color: oklch(55% 0.22 25);
}
.pt-card-action-menu__item--danger:hover, .pt-card-action-menu__item--danger:focus {
  background: oklch(95% 0.04 25);
}
@container pt-directory-results (max-width: 30rem) {
  .pt-product-hits--list .pt-product-card {
    grid-template-columns: 1fr;
    grid-template-areas: "header" "body" "strip";
    min-height: 0;
  }
  .pt-product-hits--list .pt-product-card__header {
    display: block;
    border-right: none;
    border-bottom: 1px solid oklch(91% 0 0);
    padding: 0.75rem 0.75rem 0;
  }
  .pt-product-hits--list .pt-product-card__photo-link {
    display: block;
    width: 100%;
    max-width: none;
  }
  .pt-product-hits--list .pt-product-card__photo {
    aspect-ratio: 16 / 9;
  }
  .pt-product-hits--list .pt-product-card__body {
    padding: 0.75rem 1rem 0.5rem;
  }
  .pt-product-hits--list .pt-product-card__project-strip, .pt-product-hits--list .pt-product-card__no-projects {
    padding: 0.5rem 1rem 0.75rem;
  }
  .pt-product-hits--list .pt-product-card__actions {
    flex-direction: row;
    top: 1rem;
    right: 1rem;
  }
}
.pt-product-public {
  --pt-product-sticky-top: 7.8125rem;
  padding: 1.5rem 0 3rem;
}
.pt-product-breadcrumbs {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.3rem;
  margin-bottom: 0.85rem;
  font-size: 0.8125rem;
}
.pt-product-public__actions {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: flex-end;
  gap: 0.5rem;
  margin-bottom: 1rem;
}
.pt-product-public__layout {
  display: grid;
  grid-template-columns: minmax(0, 1.3fr) minmax(0, 1fr);
  gap: 2.5rem;
  align-items: start;
}
.pt-product-public__media {
  position: sticky;
  top: var(--pt-product-sticky-top);
  align-self: start;
}
.pt-product-public__media .pt-phase-gallery {
  gap: 0.85rem;
}
.pt-product-public__content {
  display: flex;
  flex-direction: column;
  min-width: 0;
}
.pt-product-public .pt-product-description.pt-prose, .pt-product-detail .pt-product-description.pt-prose {
  font-size: 0.92rem;
  line-height: 1.7;
}
.pt-product-public__head {
  margin-bottom: 1rem;
}
.pt-product-public__block {
  padding: 1.25rem 0;
}
.pt-product-public__block--divided {
  border-bottom: 1px solid var(--color-border);
}
.pt-product-public__specs-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 0.75rem;
  margin-bottom: 0.75rem;
}
.pt-product-public__specs-title {
  margin: 0;
  padding: 0.1rem;
  font-size: 1.0625rem;
  font-weight: 600;
  letter-spacing: 0.01em;
  color: var(--color-text-primary);
}
.pt-product-public__doc-links {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
}
.pt-product-doc-btn {
  display: inline-flex;
  align-items: center;
  padding: 0.4rem 0.85rem;
  border: 1px solid var(--color-border);
  border-radius: 6px;
  font-size: 0.75rem;
  font-weight: 600;
  letter-spacing: 0.03em;
  color: var(--color-brand);
  background: var(--color-surface);
  text-decoration: none;
}
.pt-product-doc-btn:hover {
  border-color: var(--color-brand);
}
.pt-product-spec-table {
  margin: 0;
}
.pt-product-spec-row {
  display: grid;
  grid-template-columns: minmax(150px, 230px) 1fr;
  gap: 1rem;
  align-items: baseline;
  padding: 0.8rem 0.25rem;
  border-bottom: 1px solid var(--color-border);
}
.pt-product-spec-row__label {
  margin: 0;
  color: var(--color-text-secondary);
  font-size: 0.875rem;
}
.pt-product-spec-row__value {
  margin: 0;
  color: var(--color-text-primary);
  font-weight: 600;
  font-size: 0.9375rem;
  overflow-wrap: anywhere;
}
@media (max-width: 560px) {
  .pt-product-spec-row {
    grid-template-columns: minmax(0, 1fr);
    gap: 0.15rem;
  }
}
.pt-product-public__title {
  margin: 0 0 0.35rem;
  font-size: 1.75rem;
  font-weight: 700;
  line-height: 1.2;
  color: var(--color-text-primary);
}
.pt-product-public__supplier {
  color: var(--color-text-secondary);
  font-size: 0.9375rem;
}
@media (max-width: 900px) {
  .pt-product-public__layout {
    grid-template-columns: minmax(0, 1fr);
  }
  .pt-product-public__media {
    position: static;
  }
}
.pt-product-usage-cta {
  margin: 1.25rem 0;
  padding: 2.5rem 2.25rem 2.75rem;
  border-radius: 10px;
  background: #2c6a84;
  color: #fff;
  text-align: center;
}
.pt-product-usage-cta__title {
  margin: 0 0 1.25rem;
  font-size: 1.5rem;
  font-weight: 700;
  color: #fff;
}
.pt-product-usage-cta__count {
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 0.15rem;
  width: 96px;
  height: 96px;
  margin-bottom: 1.5rem;
  background: oklch(97% 0 0);
  border-radius: 8px;
}
.pt-product-usage-cta__count-number {
  font-size: 1.75rem;
  font-weight: 700;
  line-height: 1;
  color: var(--color-text-primary);
}
.pt-product-usage-cta__count-label {
  font-size: 0.8125rem;
  color: var(--color-text-secondary);
}
.pt-product-usage-cta__text {
  max-width: 38rem;
  margin: 0 auto 1.75rem;
  font-size: 1rem;
  line-height: 1.6;
  color: rgba(255, 255, 255, 0.92);
}
.pt-product-usage-cta__link {
  color: #fff;
  text-decoration: underline;
  text-underline-offset: 0.15em;
}
.pt-product-usage-cta__btn {
  display: inline-flex;
  align-items: center;
  padding: 0.7rem 1.5rem;
  border-radius: 6px;
  background: #16b37e;
  color: #fff;
  font-size: 0.8125rem;
  font-weight: 700;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  text-decoration: none;
}
.pt-product-usage-cta__btn:hover {
  filter: brightness(0.95);
}
.pt-product-categories {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.3rem;
}
.pt-product-categories__sep {
  color: var(--color-text-secondary);
}
.pt-product-categories__link {
  color: var(--pt-primary, var(--color-brand));
  text-decoration: none;
}
.pt-product-categories__link:hover {
  text-decoration: underline;
  text-underline-offset: 0.16em;
}
.pt-product-tags {
  min-width: 220px;
}
.pt-product-detail #overview .pt-card {
  overflow: visible;
}
.pt-product-detail .pt-phase-overview-grid__details {
  position: relative;
}
.pt-product-doc-links {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  flex-wrap: wrap;
  padding-right: 1.25rem;
}
.pt-product-specs {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  border-top: 1px solid var(--color-border);
  border-left: 1px solid var(--color-border);
  border-radius: 8px;
  overflow: hidden;
}
.pt-product-spec {
  padding: 0.75rem 1.1rem;
  border-right: 1px solid var(--color-border);
  border-bottom: 1px solid var(--color-border);
}
.pt-product-spec__label {
  margin-bottom: 0.25rem;
  font-size: 0.6875rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--color-text-secondary);
}
.pt-product-spec__value {
  font-size: 0.9375rem;
  font-weight: 600;
  line-height: 1.35;
  color: var(--color-text-primary);
  overflow-wrap: anywhere;
}
@media (max-width: 1024px) {
  .pt-product-specs {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}
@media (max-width: 600px) {
  .pt-product-specs {
    grid-template-columns: minmax(0, 1fr);
  }
}
.pt-product-detail__owner-actions {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
}
.pt-product-detail__owner-actions .pt-card-action-btn .pt-icon, .pt-product-detail__owner-actions .pt-card-action-btn .pt-icon-wrap {
  width: 1.25rem;
  height: 1.25rem;
}
.pt-product-detail__owner-actions .pt-card-action-btn {
  color: oklch(66% 0 0);
  background: transparent;
  filter: drop-shadow(0 1px 1.5px oklch(20% 0 0 / 28%));
  transition: filter 140ms ease-out, color 120ms ease;
}
.pt-product-detail__owner-actions .pt-card-action-btn:hover, .pt-product-detail__owner-actions .pt-card-action-btn:focus-visible {
  background: transparent;
  color: oklch(55% 0 0);
  filter: drop-shadow(0 2px 4px oklch(20% 0 0 / 45%));
}
.pt-product-detail__owner-actions .pt-card-action-btn--delete:hover {
  color: var(--color-danger, #dc2626);
}
.pt-product-detail__owner-actions .pt-card-action-btn--like.pt-follow-btn--active, .pt-product-detail__owner-actions .pt-card-action-btn--like.pt-follow-btn--active:hover, .pt-product-detail__owner-actions .pt-card-action-btn--like.pt-follow-btn--active:focus-visible {
  color: #ee5b4e;
}
.pt-product-detail__owner-actions .pt-card-action-btn--feature.pt-card-action-btn--active, .pt-product-detail__owner-actions .pt-card-action-btn--feature.pt-card-action-btn--active:hover, .pt-product-detail__owner-actions .pt-card-action-btn--feature.pt-card-action-btn--active:focus-visible {
  color: oklch(72% 0.16 75);
}
.pt-product-admin-menu {
  list-style: none;
  margin: 0;
  padding: 0.25rem;
  min-width: 160px;
}
.pt-product-admin-menu__link {
  display: block;
  padding: 0.5rem 0.75rem;
  border-radius: 8px;
  font-size: 0.875rem;
  color: var(--color-surface-inverse);
  text-decoration: none;
}
.pt-product-admin-menu__link:hover {
  background: var(--color-surface-2);
}
.pt-product-qr__img {
  display: block;
  width: 216px;
  height: 216px;
  padding: 0.5rem;
  background: #fff;
  border: 1px solid var(--color-border);
  border-radius: 10px;
}
.pt-product-quote__intro {
  margin: 0 0 1rem;
  color: var(--color-text-secondary);
  font-size: 0.9rem;
}
.pt-product-quote__rows {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}
.pt-product-quote__row {
  display: flex;
  align-items: center;
  gap: 0.5rem;
}
.pt-product-quote__product {
  flex: 1;
  min-width: 0;
}
.pt-product-quote__qty {
  width: 110px;
  flex: none;
  border-radius: var(--radius-md);
  font-size: 0.875rem;
}
.pt-product-quote__remove {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
  flex: none;
  border: none;
  border-radius: 8px;
  background: transparent;
  color: var(--color-text-secondary);
  cursor: pointer;
}
.pt-product-quote__remove:hover {
  background: var(--color-surface-2);
  color: var(--color-danger, #dc2626);
}
.pt-product-quote__add {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  margin-top: 0.75rem;
  border: none;
  background: transparent;
  color: var(--color-primary);
  font-size: 0.875rem;
  font-weight: 500;
  cursor: pointer;
  padding: 0;
}
.pt-product-quote__add:disabled {
  color: var(--color-text-secondary);
  cursor: not-allowed;
}
.pt-product-quote__body {
  margin-top: 1rem;
}
.pt-product-form-page {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  padding: 1rem 1.25rem 2rem;
}
.pt-project-show {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 var(--pt-gutter, 1.5rem) 4rem;
}
.pt-project-layout {
  display: grid;
  grid-template-columns: 420px 1fr;
  gap: 2rem;
  align-items: stretch;
}
@media (max-width: 900px) {
  .pt-project-layout {
    grid-template-columns: 1fr;
  }
}
.pt-project-image-col {
  position: relative;
}
.pt-project-image-col__sticky {
  position: sticky;
  top: 1rem;
  display: flex;
  flex-direction: column;
  gap: 1rem;
}
@media (max-width: 900px) {
  .pt-project-image-col__sticky {
    position: static;
  }
}
.pt-project-breadcrumb {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 0.85rem;
  font-weight: 500;
  color: var(--color-text-secondary);
  text-decoration: none;
  transition: color 0.15s;
}
.pt-project-breadcrumb:hover {
  color: var(--color-brand);
}
.pt-project-breadcrumb__icon {
  width: 16px;
  height: 16px;
}
.pt-project-gallery {
  position: relative;
  border-radius: 12px;
  overflow: hidden;
  background: var(--color-surface-2);
  border: 1px solid var(--color-border);
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.08);
}
.pt-project-gallery__slide {
  display: none;
}
.pt-project-gallery__slide--active {
  display: block;
}
.pt-project-gallery__img {
  width: 100%;
  height: auto;
  max-height: 500px;
  object-fit: cover;
  display: block;
}
.pt-project-gallery__placeholder {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 280px;
  color: var(--color-border-strong);
}
.pt-project-gallery__placeholder-icon {
  width: 64px;
  height: 64px;
  opacity: 0.3;
}
.pt-project-gallery__counter {
  position: absolute;
  bottom: 10px;
  right: 10px;
  display: flex;
  align-items: center;
  gap: 5px;
  background: rgba(0, 0, 0, 0.7);
  color: var(--color-surface);
  font-size: 0.78rem;
  font-weight: 600;
  padding: 5px 10px;
  border-radius: 16px;
  backdrop-filter: blur(4px);
}
.pt-project-gallery__counter-icon {
  width: 14px;
  height: 14px;
}
.pt-project-content-col {
  min-width: 0;
}
.pt-project-actions-bar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 1rem;
}
.pt-project-actions-bar__left {
  display: flex;
  align-items: center;
  gap: 0.5rem;
}
.pt-project-actions-bar__updated {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-size: 0.8rem;
  color: var(--color-text-secondary);
}
.pt-project-actions-bar__icon {
  width: 14px;
  height: 14px;
  opacity: 0.6;
}
.pt-project-actions-bar__right {
  display: flex;
  align-items: center;
  gap: 0.75rem;
}
.pt-project-title {
  font-size: 1.75rem;
  font-weight: 700;
  color: var(--color-surface-inverse);
  margin: 0 0 0.5rem;
  line-height: 1.25;
}
.pt-project-parent {
  font-size: 0.9rem;
  color: var(--color-text-secondary);
  margin-bottom: 0.75rem;
}
.pt-project-parent__link {
  color: var(--color-brand);
  text-decoration: none;
}
.pt-project-parent__link:hover {
  text-decoration: underline;
}
.pt-project-badges {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.625rem;
  margin-bottom: 1.5rem;
}
.pt-project-status-pill {
  display: inline-flex;
  padding: 4px 14px;
  border-radius: 20px;
  font-size: 0.8rem;
  font-weight: 600;
  letter-spacing: 0.02em;
  background: var(--color-surface-2);
  color: var(--color-text-secondary);
  border: 1px solid var(--color-border);
}
.pt-project-status-pill--under_construction {
  background: rgba(251, 191, 36, 0.15);
  color: var(--color-warning-hover, var(--color-warning));
  border-color: rgba(251, 191, 36, 0.35);
}
.pt-project-status-pill--completed {
  background: rgba(34, 197, 94, 0.15);
  color: var(--color-success-hover);
  border-color: rgba(34, 197, 94, 0.35);
}
.pt-project-status-pill--tender, .pt-project-status-pill--planning, .pt-project-status-pill--under_design {
  background: rgba(14, 116, 144, 0.1);
  color: var(--color-surface-inverse);
  border-color: rgba(14, 116, 144, 0.25);
}
.pt-project-status-pill--on_hold {
  background: rgba(251, 146, 60, 0.15);
  color: var(--color-danger-hover);
  border-color: rgba(251, 146, 60, 0.35);
}
.pt-project-status-pill--cancelled {
  background: rgba(239, 68, 68, 0.1);
  color: var(--color-danger);
  border-color: rgba(239, 68, 68, 0.25);
}
.pt-project-meta-chip {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 4px 12px;
  border-radius: 20px;
  font-size: 0.8rem;
  color: var(--color-text-secondary);
  background: var(--color-surface-2);
  border: 1px solid var(--color-border);
}
.pt-project-meta-chip__icon {
  width: 14px;
  height: 14px;
  opacity: 0.7;
}
.pt-project-actions {
  display: flex;
  align-items: center;
  gap: 0.75rem;
}
.pt-project-action-btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 8px 16px;
  border-radius: 8px;
  font-size: 0.82rem;
  font-weight: 600;
  text-decoration: none;
  background: var(--color-surface);
  color: var(--color-surface-inverse);
  border: 1px solid var(--color-border);
  cursor: pointer;
  transition: background 0.15s, border-color 0.15s;
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.05);
}
.pt-project-action-btn:hover {
  background: var(--color-surface-2);
  border-color: var(--color-border);
}
.pt-project-action-btn--active {
  background: rgba(239, 68, 68, 0.12);
  color: var(--color-danger);
  border-color: rgba(239, 68, 68, 0.3);
}
.pt-project-action-btn svg {
  width: 16px;
  height: 16px;
}
.pt-project-action-link {
  font-size: 0.82rem;
  color: var(--color-text-secondary);
  text-decoration: none;
  margin-left: auto;
}
.pt-project-action-link:hover {
  color: var(--color-brand);
  text-decoration: underline;
}
.pt-project-section {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: 12px;
  padding: 1.25rem 1.5rem;
  margin-bottom: 1.25rem;
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.06);
}
.pt-project-section__header {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 1rem;
  padding-bottom: 0.75rem;
  border-bottom: 1px solid var(--color-border);
}
.pt-project-section__icon {
  width: 20px;
  height: 20px;
  color: var(--color-brand);
  flex-shrink: 0;
}
.pt-project-section__title {
  font-size: 1rem;
  font-weight: 600;
  color: var(--color-surface-inverse);
  margin: 0;
  display: flex;
  align-items: center;
  gap: 8px;
}
.pt-project-section__count {
  font-size: 0.8rem;
  font-weight: 500;
  color: var(--color-text-secondary);
  background: var(--color-surface-2);
  padding: 2px 10px;
  border-radius: 12px;
}
.pt-project-description {
  font-size: 0.92rem;
  line-height: 1.7;
  color: var(--color-text-secondary);
}
.pt-project-description p {
  margin: 0 0 0.75rem;
}
.pt-project-description p:last-child {
  margin-bottom: 0;
}
.pt-project-facts {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap: 1rem;
}
.pt-project-fact {
  background: var(--color-surface-2);
  border-radius: 10px;
  padding: 1rem;
  border: 1px solid var(--color-border);
}
.pt-project-fact__label {
  font-size: 0.75rem;
  font-weight: 500;
  color: var(--color-text-secondary);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  margin-bottom: 0.4rem;
}
.pt-project-fact__value {
  font-size: 1.1rem;
  font-weight: 600;
  color: var(--color-surface-inverse);
  overflow-wrap: anywhere;
}
.pt-project-timeline {
  position: relative;
  padding-left: 1.5rem;
}
.pt-project-timeline::before {
  content: "";
  position: absolute;
  left: 5px;
  top: 8px;
  bottom: 8px;
  width: 2px;
  background: var(--color-border);
  border-radius: 1px;
}
.pt-project-timeline__item {
  display: grid;
  grid-template-columns: 80px 12px 1fr;
  gap: 0.5rem;
  align-items: start;
  padding: 0.5rem 0;
  position: relative;
}
.pt-project-timeline__date {
  font-size: 0.8rem;
  font-weight: 600;
  color: var(--color-brand);
  text-align: right;
  white-space: nowrap;
}
.pt-project-timeline__dot {
  width: 10px;
  height: 10px;
  background: var(--color-brand);
  border-radius: 50%;
  margin-top: 4px;
  position: relative;
  z-index: 1;
  box-shadow: 0 0 0 3px var(--color-surface);
}
.pt-project-timeline__text {
  font-size: 0.88rem;
  color: var(--color-text-secondary);
  line-height: 1.5;
}
.pt-project-products {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
}
.pt-phase-card-content > .pt-empty-state {
  padding: 2.25rem 1.5rem;
  gap: 0.625rem;
}
.pt-phase-card-content > .pt-empty-state .pt-empty-state__heading {
  font-size: 0.9375rem;
  font-weight: 500;
  color: var(--color-text-secondary);
}
.pt-phase-card-content > .pt-empty-state .pt-empty-state__icon {
  color: var(--color-text-muted);
}
.pt-product-list-actions {
  position: relative;
}
.pt-overview-tags {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.375rem;
}
.pt-overview-tags__list {
  display: contents;
}
.pt-tag-chip {
  display: inline-flex;
  align-items: center;
  padding: 0.125rem 0.5rem;
  border-radius: var(--radius-full);
  background: var(--color-brand-subtle);
  color: var(--color-brand);
  font-size: var(--text-xs);
  font-weight: 600;
  line-height: 1.5;
  white-space: nowrap;
}
.pt-overview-tag-add {
  border: 0;
  padding: 0;
  background: transparent;
  font: inherit;
  cursor: pointer;
}
.pt-report-form {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}
.pt-report-form__intro {
  margin: 0;
  font-size: var(--text-sm);
  color: var(--color-text-secondary);
  line-height: 1.5;
}
.pt-report-form__issues {
  border: 0;
  margin: 0;
  padding: 0;
  min-inline-size: 0;
}
.pt-report-form__legend {
  padding: 0;
  margin-bottom: 0.5rem;
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--color-text-primary);
}
.pt-report-form__checks {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.625rem 1.25rem;
}
.pt-report-form__field {
  display: flex;
  flex-direction: column;
  gap: 0.375rem;
}
.pt-report-form__label {
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--color-text-primary);
}
.pt-report-form__textarea, .pt-report-form__input {
  width: 100%;
  padding: 0.5rem 0.75rem;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  font: inherit;
  font-size: var(--text-sm);
  color: var(--color-text-primary);
  background: var(--color-surface);
  resize: vertical;
}
.pt-report-form__textarea:focus-visible, .pt-report-form__input:focus-visible {
  outline: 2px solid var(--color-brand);
  outline-offset: -1px;
  border-color: var(--color-brand);
}
.pt-report-form__file {
  font-size: var(--text-sm);
  color: var(--color-text-secondary);
}
.pt-report-form__file::file-selector-button {
  margin-right: 0.75rem;
  padding: 0.4rem 0.85rem;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  background: var(--color-surface);
  color: var(--color-text-primary);
  font: inherit;
  font-size: var(--text-sm);
  font-weight: 600;
  cursor: pointer;
  transition: background-color 0.12s ease, border-color 0.12s ease;
}
.pt-report-form__file::file-selector-button:hover {
  background: var(--color-surface-2);
  border-color: oklch(82% 0 0);
}
.pt-report-form__recaptcha {
  display: flex;
  justify-content: center;
  margin-top: 0.25rem;
}
.pt-project-list .pt-product-row.pt-project-card--list.pt-project-card--sm .pt-project-card__media {
  position: relative;
  flex: 0 0 7.25rem;
  max-width: 7.25rem;
  align-self: stretch;
  background: #fff;
  height: auto;
  aspect-ratio: auto;
  overflow: hidden;
}
.pt-product-row .pt-project-card__photo {
  position: absolute;
  top: 50%;
  left: 0;
  transform: translateY(-50%);
  width: 100%;
  height: auto;
  background: #fff;
}
.pt-product-row .pt-product-row__sub {
  display: block;
  color: var(--color-text-secondary);
}
.pt-product-row .pt-product-row__sub--muted {
  color: var(--color-text-muted);
}
.pt-project-product-card {
  display: flex;
  align-items: center;
  gap: 0.625rem;
  padding: 0.5rem 1rem 0.5rem 0.5rem;
  border-radius: 10px;
  background: var(--color-surface-2);
  border: 1px solid var(--color-border);
  text-decoration: none;
  transition: border-color 0.15s;
}
.pt-project-product-card:hover {
  border-color: var(--color-brand);
}
.pt-project-product-card__img {
  width: 48px;
  height: 48px;
  border-radius: 8px;
  overflow: hidden;
  flex-shrink: 0;
  background: var(--color-border);
  display: flex;
  align-items: center;
  justify-content: center;
}
.pt-project-product-card__img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.pt-project-product-card__placeholder-icon {
  width: 24px;
  height: 24px;
  color: var(--color-border-strong);
  opacity: 0.5;
}
.pt-project-product-card__name {
  font-size: 0.85rem;
  font-weight: 500;
  color: var(--color-surface-inverse);
}
.pt-project-related {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
  gap: 1rem;
}
.pt-project-related-card {
  border-radius: 12px;
  overflow: hidden;
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  text-decoration: none;
  transition: border-color 0.15s, transform 0.15s;
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.06);
}
.pt-project-related-card:hover {
  border-color: var(--color-brand);
  transform: translateY(-2px);
}
.pt-project-related-card__img {
  height: 140px;
  overflow: hidden;
  background: var(--color-surface-2);
}
.pt-project-related-card__img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.pt-project-related-card__placeholder {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 100%;
  color: var(--color-border-strong);
  opacity: 0.4;
}
.pt-project-related-card__placeholder svg {
  width: 36px;
  height: 36px;
}
.pt-project-related-card__body {
  padding: 0.875rem;
}
.pt-project-related-card__title {
  font-size: 0.88rem;
  font-weight: 600;
  color: var(--color-surface-inverse);
  margin: 0 0 4px;
  line-height: 1.3;
}
.pt-project-related-card__location {
  font-size: 0.78rem;
  color: var(--color-text-secondary);
  margin: 0;
}
.pt-project-developer-card {
  display: flex;
  align-items: center;
  gap: 0.875rem;
}
.pt-project-developer-card__logo img {
  width: 56px;
  height: 56px;
  border-radius: 10px;
  object-fit: cover;
}
.pt-project-developer-card__logo-placeholder {
  width: 56px;
  height: 56px;
  border-radius: 10px;
  background: var(--color-border);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.85rem;
  font-weight: 700;
  color: var(--color-text-secondary);
}
.pt-project-developer-card__name {
  font-size: 0.95rem;
  font-weight: 600;
  color: var(--color-surface-inverse);
  text-decoration: none;
  display: block;
}
.pt-project-developer-card__name:hover {
  color: var(--color-brand);
}
.pt-project-developer-card__meta {
  font-size: 0.8rem;
  color: var(--color-text-secondary);
  margin-top: 4px;
}
.pt-project-developer-card__meta a {
  color: var(--color-brand);
  text-decoration: none;
}
.pt-project-developer-card__meta a:hover {
  text-decoration: underline;
}
.pt-project-map {
  border-radius: 10px;
  overflow: hidden;
  border: 1px solid var(--color-border);
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.08);
}
.pt-project-map__frame {
  width: 100%;
  height: 220px;
  border: none;
  display: block;
}
.pt-project-map__link {
  display: block;
  padding: 8px 12px;
  font-size: 0.8rem;
  text-align: center;
  color: var(--color-brand);
  text-decoration: none;
  background: var(--color-surface-2);
}
.pt-project-map__link:hover {
  text-decoration: underline;
}
.pt-project-child-list {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}
.pt-project-child-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0.625rem 0.875rem;
  border-radius: 8px;
  background: var(--color-surface-2);
  border: 1px solid var(--color-border);
  text-decoration: none;
  transition: border-color 0.15s;
}
.pt-project-child-item:hover {
  border-color: var(--color-brand);
}
.pt-project-child-item__title {
  font-size: 0.85rem;
  font-weight: 500;
  color: var(--color-surface-inverse);
}
.pt-project-child-item__status {
  font-size: 0.75rem;
  color: var(--color-text-secondary);
}
.pt-project-detail {
  max-width: 100%;
  min-width: 0;
  container-type: inline-size;
  container-name: project;
}
.pt-project-shell {
  display: block;
}
.pt-project-shell--with-rail {
  display: flex;
  align-items: stretch;
  gap: 1.25rem;
}
.pt-project-main {
  flex: 1;
  min-width: 0;
}
.pt-project-rail {
  flex: 0 0 auto;
  display: flex;
  position: sticky;
  top: 0;
  align-self: flex-start;
  height: 100vh;
  min-height: 100vh;
  margin: -1.5rem -1.5rem -1.5rem 0;
}
.pt-main--flush .pt-project-rail {
  margin: 0;
}
.pt-project-rail .pt-context-sidebar {
  --ctx-width-expanded: 23rem;
  height: 100%;
  min-height: 0;
}
.pt-project-sticky-shell {
  position: sticky;
  top: 0;
  z-index: 20;
  margin-bottom: 1.5rem;
  background: var(--pt-surface, var(--color-surface));
  border: 1px solid var(--pt-border, var(--color-border));
  border-radius: 0.25rem;
  box-shadow: 0 1px 2px rgba(15, 23, 42, 0.035);
}
.pt-public-app .pt-project-sticky-shell {
  top: 4.75rem;
}
.pt-project-header {
  padding: 1.125rem 1.5rem 0.875rem;
}
.pt-project-header__top {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 1.25rem;
  margin-bottom: 0.75rem;
}
.pt-project-header__back {
  display: inline-flex;
  align-items: center;
  gap: 0.375rem;
  font-size: 0.8125rem;
  font-weight: 500;
  color: var(--pt-text-secondary, var(--color-text-secondary));
  text-decoration: none;
  transition: color 0.15s ease;
}
.pt-project-header__back:hover {
  color: var(--pt-text-primary, var(--color-text-primary));
}
.pt-project-header__back-icon {
  flex: 0 0 auto;
  width: 1rem;
  height: 1rem;
}
.pt-project-header__title {
  margin: 0 0 0.625rem;
  font-size: 1.625rem;
  font-weight: 700;
  line-height: 1.25;
  color: var(--pt-text-primary, var(--color-text-primary));
}
.pt-project-header__actions {
  display: flex;
  flex: 0 0 auto;
  flex-wrap: wrap;
  align-items: center;
  justify-content: flex-end;
  gap: 0.5rem;
}
.pt-project-header__actions .pt-btn {
  white-space: nowrap;
}
.pt-project-header__meta {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  column-gap: 0.875rem;
  row-gap: 0.5rem;
}
.pt-project-header__meta-item {
  display: inline-flex;
  align-items: center;
  gap: 0.3125rem;
  min-width: 0;
  font-size: 0.8125rem;
  color: var(--pt-text-secondary, var(--color-text-secondary));
}
.pt-project-header__meta-item--muted {
  color: var(--color-text-muted, var(--color-text-secondary));
}
.pt-project-header__meta-icon {
  flex: 0 0 auto;
  width: 0.9375rem;
  height: 0.9375rem;
  opacity: 0.6;
}
.pt-project-header__link {
  color: var(--pt-primary, var(--color-brand));
  font-weight: 500;
  text-decoration: none;
}
.pt-project-header__link:hover {
  text-decoration: underline;
  text-underline-offset: 0.16em;
}
.pt-project-header__meta .pt-project-status-pill {
  display: inline-flex;
  align-items: center;
  padding: 0.1875rem 0.5rem;
  border-radius: 0.25rem;
  font-size: 0.6875rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  line-height: 1;
  text-transform: uppercase;
}
.pt-project-tabs {
  display: flex;
  align-items: stretch;
  gap: 0;
  padding: 0 1.5rem;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
  border-top: 1px solid var(--pt-border, var(--color-border));
}
.pt-project-tabs::-webkit-scrollbar {
  display: none;
}
.pt-project-tab {
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: 0.4375rem;
  flex: 0 0 auto;
  padding: 0.8125rem 1.125rem;
  font-size: 0.8125rem;
  font-weight: 600;
  letter-spacing: 0.04em;
  line-height: 1;
  text-transform: uppercase;
  color: var(--pt-text-secondary, var(--color-text-secondary));
  text-decoration: none;
  white-space: nowrap;
  border-bottom: 2px solid transparent;
  transition: color 0.15s ease, border-color 0.15s ease;
}
.pt-project-tab:hover {
  color: var(--pt-text-primary, var(--color-text-primary));
}
.pt-project-tab--active {
  color: var(--pt-primary, var(--color-brand));
  border-bottom-color: var(--pt-primary, var(--color-brand));
}
.pt-project-tab__icon {
  flex: 0 0 auto;
  width: 1rem;
  height: 1rem;
}
.pt-project-content > * + * {
  margin-top: 1.25rem;
}
.pt-project-anchor > .pt-card + .pt-card {
  margin-top: 1.25rem;
}
.pt-project-anchor {
  scroll-margin-top: 13rem;
}
.pt-public-app .pt-project-anchor {
  scroll-margin-top: 17rem;
}
.pt-project-detail .pt-card {
  border-radius: var(--radius-sm);
}
.pt-project-subsection-title {
  font-size: 0.75rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--color-text-secondary);
  margin: 0 0 0.75rem;
}
.pt-project-child-list + .pt-project-subsection-title {
  margin-top: 1.5rem;
}
.pt-project-list {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}
.pt-project-list + .pt-project-subsection-title {
  margin-top: 1.5rem;
}
.pt-project-list .pt-project-card--list .pt-project-card__media {
  flex: 0 0 12rem;
  max-width: 12rem;
}
.pt-project-list-actions {
  position: relative;
}
.pt-project-card--list.pt-project-card--sm {
  border-radius: 0.625rem;
}
.pt-project-list .pt-project-card--list.pt-project-card--sm .pt-project-card__media {
  flex: 0 0 9.5rem;
  max-width: 9.5rem;
  min-height: 6.75rem;
}
.pt-project-card--list.pt-project-card--sm .pt-project-card__body {
  gap: 0.2rem;
  min-height: 0;
  padding: 0.55rem 0.85rem 0.4rem;
}
.pt-project-card--list.pt-project-card--sm .pt-project-card__title {
  margin: 0 0 0.1rem;
  font-size: 0.95rem;
  line-height: 1.2;
}
.pt-project-card--list.pt-project-card--sm .pt-project-card__meta, .pt-project-card--list.pt-project-card--sm .pt-project-card__dates {
  font-size: 0.78rem;
  gap: 0.25rem;
}
.pt-project-card--list.pt-project-card--sm .pt-project-card__dates {
  flex-direction: row;
  flex-wrap: wrap;
  align-items: center;
  min-height: 0;
  gap: 0.2rem 0.45rem;
}
.pt-project-card--list.pt-project-card--sm .pt-project-card__dates .pt-project-card__date-sep {
  display: inline;
}
.pt-project-card--list.pt-project-card--sm .pt-project-card__footer {
  gap: 0.4rem;
  padding: 0.3rem 0.85rem 0.45rem;
}
.pt-project-card--list.pt-project-card--sm .pt-project-card__sectors-row {
  min-height: 0;
}
.pt-project-card--list.pt-project-card--sm .pt-metric-pill {
  padding: 0.24rem 0.55rem;
  font-size: 0.72rem;
}
.pt-project-card--list.pt-project-card--sm .pt-metric-pill__label {
  display: none;
}
.pt-project-card--list .pt-project-card__actions--footer {
  position: static;
  top: auto;
  right: auto;
  display: inline-flex;
  flex-direction: row;
  align-items: center;
  gap: 0.15rem;
  margin-left: 0.35rem;
}
.pt-project-card--list .pt-project-card__actions--footer .pt-card-action-btn {
  color: oklch(60% 0 0);
  filter: none;
}
.pt-project-card--list .pt-project-card__actions--footer .pt-card-action-btn:hover, .pt-project-card--list .pt-project-card__actions--footer .pt-card-action-btn:focus-visible {
  color: oklch(35% 0 0);
  filter: none;
}
.pt-project-card--list .pt-project-card__actions--footer .pt-card-action-btn:hover .pt-icon, .pt-project-card--list .pt-project-card__actions--footer .pt-card-action-btn:focus-visible .pt-icon {
  opacity: 1;
}
.pt-project-card--list .pt-project-card__actions--footer .pt-card-action-btn--like.pt-card-action-btn--active, .pt-project-card--list .pt-project-card__actions--footer .pt-card-action-btn--like.pt-card-action-btn--active:hover {
  color: #ee5b4e;
}
.pt-project-card--list .pt-project-card__actions--footer .pt-card-action-btn--tag.pt-card-action-btn--active, .pt-project-card--list .pt-project-card__actions--footer .pt-card-action-btn--tag.pt-card-action-btn--active:hover {
  color: #3196d1;
}
.pt-follow-btn__heart {
  display: inline-flex;
  align-items: center;
}
.pt-follow-btn__heart-icon--solid {
  display: none;
}
.pt-follow-btn--active .pt-follow-btn__heart-icon--outline {
  display: none;
}
.pt-follow-btn--active .pt-follow-btn__heart-icon--solid {
  display: inline-flex;
}
.pt-follow-btn--active {
  border-color: #ee5b4e;
}
.pt-follow-btn--active .pt-btn__icon {
  color: #ee5b4e;
}
.pt-project-section-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
}
.pt-project-section-head__more {
  display: inline-flex;
  align-items: center;
  gap: 0.25rem;
  padding-right: 1.25rem;
  font-size: 0.8125rem;
  font-weight: 600;
  color: var(--pt-primary, var(--color-brand));
  text-decoration: none;
  white-space: nowrap;
  text-transform: none;
  letter-spacing: 0;
}
.pt-project-section-head__more:hover {
  text-decoration: underline;
  text-underline-offset: 0.16em;
}
.pt-project-section-head__more-icon {
  width: 1rem;
  height: 1rem;
}
.pt-project-map__open {
  position: absolute;
  top: 0.625rem;
  right: 0.625rem;
  z-index: 1000;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.125rem;
  height: 2.125rem;
  background: var(--pt-surface, var(--color-surface));
  color: var(--pt-text-secondary, var(--color-text-secondary));
  border: 1px solid rgba(0, 0, 0, 0.2);
  border-radius: 0.25rem;
  box-shadow: 0 1px 4px rgba(0, 0, 0, 0.18);
  transition: color 0.15s ease, background-color 0.15s ease;
}
.pt-project-map__open:hover {
  color: var(--pt-primary, var(--color-brand));
  background: var(--color-surface-2);
}
.pt-project-map__open-icon {
  width: 1.125rem;
  height: 1.125rem;
}
@media (max-width: 720px) {
  .pt-project-header__top {
    flex-direction: column;
    align-items: flex-start;
    gap: 0.875rem;
  }
  .pt-project-header__actions {
    justify-content: flex-start;
  }
  .pt-project-header__title {
    font-size: 1.375rem;
  }
  .pt-project-list .pt-project-card--list .pt-project-card__media {
    flex: none;
    max-width: 100%;
  }
}
#location .leaflet-control-layers {
  margin-top: 2.875rem;
}
.pt-project-list .pt-card {
  border: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
  overflow: visible;
}
.pt-project-list .pt-card--clickable:hover {
  box-shadow: none;
  transform: none;
  border-color: transparent;
}
.pt-project-list .pt-project-card--list.pt-project-card--sm .pt-project-card__media {
  flex: 0 0 11.5rem;
  max-width: 11.5rem;
  min-height: 0;
  align-self: stretch;
}
.pt-project-card--list.pt-project-card--sm .pt-project-card__content {
  padding: 0.45rem 4.25rem 0.45rem 0.85rem;
  justify-content: center;
  gap: 0.18rem;
}
.pt-project-card--list.pt-project-card--sm .pt-project-card__body {
  padding: 0;
  gap: 0.18rem;
  min-height: 0;
}
.pt-project-card--list.pt-project-card--sm .pt-project-card__title {
  margin: 0 0 0.35rem;
  font-size: 0.9rem;
  line-height: 1.2;
}
.pt-project-card--list.pt-project-card--sm .pt-project-card__meta, .pt-project-card--list.pt-project-card--sm .pt-project-card__dates {
  justify-content: flex-start;
  align-items: center;
  flex-wrap: wrap;
  min-height: 0;
  gap: 0.1rem 0.55rem;
  font-size: 0.76rem;
}
.pt-project-list .pt-project-card__meta {
  justify-content: flex-start;
}
.pt-project-list .pt-project-card__meta-type {
  margin-left: 0;
}
.pt-project-card--list.pt-project-card--sm .pt-project-card__footer {
  padding: 0;
  margin-top: 0.1rem;
  gap: 0.5rem;
  justify-content: flex-start;
  align-items: center;
}
.pt-project-card--list.pt-project-card--sm .pt-project-card__sectors-row {
  min-height: 0;
}
.pt-project-card--list.pt-project-card--sm .pt-project-card__metrics {
  margin-left: 0;
  gap: 0.4rem;
}
.pt-project-list .pt-sector-icon {
  width: 1.65rem;
  height: 1.65rem;
}
.pt-project-list .pt-sector-icon .pt-icon {
  width: 1.05rem;
  height: 1.05rem;
}
.pt-project-card--list .pt-project-card__actions {
  position: absolute;
  top: 0.45rem;
  right: 0.6rem;
  bottom: auto;
  left: auto;
  z-index: 3;
  margin: 0;
  display: inline-flex;
  flex-direction: row;
  align-items: center;
  gap: 0.1rem;
}
.pt-project-card--list .pt-project-card__actions .pt-card-action-btn, .pt-project-card--list:hover .pt-project-card__actions .pt-card-action-btn {
  background: transparent;
  color: white;
  filter: drop-shadow(0 1px 2px oklch(20% 0 0 / 45%));
}
.pt-project-card--list .pt-project-card__actions .pt-card-action-btn:hover, .pt-project-card--list .pt-project-card__actions .pt-card-action-btn:focus-visible {
  color: white;
  filter: drop-shadow(0 1px 3px oklch(20% 0 0 / 55%));
}
.pt-project-card--list .pt-project-card__actions .pt-card-action-btn--like.pt-card-action-btn--active, .pt-project-card--list:hover .pt-project-card__actions .pt-card-action-btn--like.pt-card-action-btn--active {
  color: #ee5b4e;
}
.pt-project-card--list .pt-project-card__actions .pt-card-action-btn--tag.pt-card-action-btn--active, .pt-project-card--list:hover .pt-project-card__actions .pt-card-action-btn--tag.pt-card-action-btn--active {
  color: #3196d1;
}
@container project (max-width: 930px) {
  .pt-project-shell--with-rail {
    flex-direction: column;
  }
  .pt-project-rail {
    position: relative;
    top: auto;
    align-self: stretch;
    height: auto;
    min-height: 0;
    margin: 0;
    width: 100%;
  }
  .pt-project-rail .pt-context-sidebar {
    width: 100%;
    min-width: 0;
    height: auto;
  }
  .pt-project-rail .pt-context-sidebar--collapsed {
    width: 100%;
    min-width: 0;
  }
  .pt-project-rail .pt-context-sidebar--collapsed .pt-context-sidebar__icons {
    display: none;
  }
  .pt-project-rail .pt-context-sidebar--collapsed .pt-context-sidebar__body {
    display: flex;
  }
  .pt-project-rail .pt-context-sidebar__toggle, .pt-project-rail .pt-context-sidebar__collapse {
    display: none;
  }
  .pt-phase-overview-grid {
    grid-template-columns: 1fr;
  }
}
.pt-project-anon {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  gap: 2rem;
  align-items: start;
}
@container project (max-width: 900px) {
  .pt-project-anon {
    grid-template-columns: 1fr;
    gap: 1.5rem;
  }
}
.pt-project-anon__media {
  position: sticky;
  top: 1.25rem;
  min-width: 0;
  align-self: center;
}
@container project (max-width: 900px) {
  .pt-project-anon__media {
    position: static;
    top: auto;
  }
}
.pt-public-app .pt-project-anon__media {
  top: 5.75rem;
}
.pt-project-anon__content {
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 1.25rem;
}
.pt-project-rail-gallery {
  display: grid;
  grid-template-columns: 84px minmax(0, 1fr);
  gap: 0.75rem;
  align-items: stretch;
}
.pt-project-rail-gallery:not(:has(.pt-project-rail-gallery__thumbs)) {
  grid-template-columns: 1fr;
}
.pt-project-rail-gallery__thumbs {
  display: flex;
  flex-direction: column;
  justify-content: safe center;
  gap: 0.5rem;
  max-height: 540px;
  overflow-y: auto;
  scrollbar-width: thin;
  padding-right: 2px;
}
.pt-project-rail-gallery__thumb {
  flex: 0 0 auto;
  display: block;
  width: 100%;
  aspect-ratio: 4 / 3;
  padding: 0;
  border: 2px solid transparent;
  border-radius: 0.5rem;
  overflow: hidden;
  background: var(--color-surface-2);
  cursor: pointer;
  opacity: 0.65;
  transition: opacity 0.15s ease, border-color 0.15s ease;
}
.pt-project-rail-gallery__thumb:hover {
  opacity: 1;
}
.pt-project-rail-gallery__thumb--active {
  opacity: 1;
  border-color: var(--color-brand);
}
.pt-project-rail-gallery__thumb-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.pt-project-rail-gallery__main {
  position: relative;
  border-radius: 0.625rem;
  overflow: hidden;
  background: var(--color-surface-2);
  border: 1px solid var(--color-border);
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.08);
  aspect-ratio: 10 / 7;
}
.pt-project-rail-gallery__main-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.pt-project-rail-gallery__nav {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.25rem;
  height: 2.25rem;
  border: none;
  border-radius: var(--radius-full, 9999px);
  background: rgba(15, 23, 42, 0.55);
  color: #fff;
  cursor: pointer;
  backdrop-filter: blur(4px);
  transition: background 0.15s ease;
}
.pt-project-rail-gallery__nav:hover {
  background: rgba(15, 23, 42, 0.78);
}
.pt-project-rail-gallery__nav--prev {
  left: 0.625rem;
}
.pt-project-rail-gallery__nav--next {
  right: 0.625rem;
}
.pt-project-rail-gallery__nav-icon {
  width: 1.25rem;
  height: 1.25rem;
}
.pt-project-rail-gallery__counter {
  position: absolute;
  bottom: 0.625rem;
  right: 0.625rem;
  padding: 0.25rem 0.625rem;
  border-radius: 1rem;
  background: rgba(15, 23, 42, 0.7);
  color: #fff;
  font-size: 0.75rem;
  font-weight: 600;
  backdrop-filter: blur(4px);
}
.pt-project-rail-gallery__placeholder {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  width: 100%;
  height: 100%;
  color: var(--color-text-muted, var(--color-text-secondary));
}
.pt-project-rail-gallery__placeholder-icon {
  width: 3rem;
  height: 3rem;
  opacity: 0.35;
}
.pt-project-anon-header {
  display: flex;
  flex-direction: column;
  gap: 0.875rem;
}
.pt-project-anon-header__bar {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
}
.pt-project-anon-header__updated {
  display: inline-flex;
  align-items: center;
  gap: 0.375rem;
  font-size: 0.8125rem;
  color: var(--color-text-secondary);
}
.pt-project-anon-header__updated-icon {
  width: 0.9375rem;
  height: 0.9375rem;
  opacity: 0.6;
}
.pt-project-anon-header__actions {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.5rem;
}
.pt-project-anon-header__actions .pt-btn--secondary {
  background: oklch(90% 0 0);
  border: 1px solid oklch(84% 0 0);
}
.pt-project-anon-header__actions .pt-btn--secondary:hover {
  background: oklch(86% 0 0);
}
.pt-project-anon-header__title {
  margin: 0;
  font-size: 1.625rem;
  font-weight: 700;
  line-height: 1.25;
  color: var(--color-text-primary);
}
.pt-project-anon-header__meta {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  column-gap: 0.875rem;
  row-gap: 0.5rem;
}
.pt-project-anon-header__meta-item {
  display: inline-flex;
  align-items: center;
  gap: 0.3125rem;
  min-width: 0;
  font-size: 0.8125rem;
  color: var(--color-text-secondary);
}
.pt-project-anon-header__meta-icon {
  flex: 0 0 auto;
  width: 0.9375rem;
  height: 0.9375rem;
  opacity: 0.6;
}
.pt-project-anon-header__link {
  color: var(--color-brand);
  font-weight: 500;
  text-decoration: none;
}
.pt-project-anon-header__link:hover {
  text-decoration: underline;
  text-underline-offset: 0.16em;
}
.pt-gated-participants__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  width: 100%;
  padding-right: 1.25rem;
}
.pt-gated-participants__head .pt-phase-section-title {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
}
.pt-gated-participants__head-icon {
  width: 1.125rem;
  height: 1.125rem;
  color: var(--color-brand);
}
.pt-gated-participants__promo {
  display: flex;
  align-items: flex-start;
  gap: 0.75rem;
  padding: 1rem 1.25rem;
  border-radius: var(--radius-md, 0.5rem);
  background: var(--color-brand-subtle);
  border: 1px dashed var(--color-border);
}
.pt-gated-participants__promo-icon {
  flex: 0 0 auto;
  width: 1.25rem;
  height: 1.25rem;
  margin-top: 0.125rem;
  color: var(--color-brand);
}
.pt-gated-participants__promo-text {
  margin: 0;
  font-size: 0.9375rem;
  line-height: 1.5;
  color: var(--color-text-secondary);
}
.pt-gated-participants__promo-link {
  border: 0;
  padding: 0;
  background: transparent;
  font: inherit;
  font-weight: 600;
  color: var(--color-brand);
  cursor: pointer;
  text-decoration: underline;
  text-underline-offset: 0.14em;
}
.pt-insights-banner {
  background: oklch(56% 0.19 250);
  border-radius: var(--radius-lg);
  padding: 1.75rem;
  color: var(--color-text-inverse);
  text-align: center;
  box-shadow: 0 6px 18px rgba(15, 23, 42, 0.18);
}
.pt-insights-banner__title {
  margin: 0 0 1.25rem;
  font-size: 1.25rem;
  font-weight: 700;
  line-height: 1.3;
  color: #fff;
}
.pt-insights-banner__stats {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 0.75rem;
  margin-bottom: 1.25rem;
}
.pt-insights-banner__stat {
  flex: 0 0 auto;
  width: 6rem;
  aspect-ratio: 1 / 1;
  box-sizing: border-box;
  padding: 0.5rem;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 0.125rem;
  border-radius: 0.5rem;
  background: rgba(255, 255, 255, 0.12);
  border: 1px solid rgba(255, 255, 255, 0.16);
}
.pt-insights-banner__stat-number {
  font-size: 1.5rem;
  font-weight: 700;
  line-height: 1.1;
  color: #fff;
}
.pt-insights-banner__stat-label {
  margin-top: 0.25rem;
  font-size: 0.625rem;
  font-weight: 500;
  letter-spacing: 0.02em;
  white-space: nowrap;
  color: rgba(255, 255, 255, 0.82);
}
.pt-insights-banner__text {
  margin: 0 0 1.25rem;
  font-size: 0.9375rem;
  line-height: 1.55;
  color: rgba(255, 255, 255, 0.9);
}
.pt-insights-banner__cta {
  background: oklch(70% 0.16 150);
  border-color: oklch(70% 0.16 150);
  color: #fff;
}
.pt-insights-banner__cta:hover {
  background: oklch(64% 0.14 150);
  border-color: oklch(64% 0.14 150);
  color: #fff;
}
.pt-questionnaire-index {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-xl);
  margin-top: var(--spacing-lg);
}
.pt-questionnaire-index__filters {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-md);
}
.pt-questionnaire-index__filter-row {
  display: flex;
  align-items: center;
  gap: var(--spacing-sm);
  flex-wrap: wrap;
}
.pt-questionnaire-index__grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(20rem, 1fr));
  gap: var(--spacing-lg);
}
.pt-questionnaire-card__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--spacing-sm);
}
.pt-questionnaire-card__title {
  font-size: var(--text-lg);
  font-weight: 600;
  color: var(--color-text-primary);
  text-decoration: none;
}
.pt-questionnaire-card__title:hover {
  color: var(--color-brand);
}
.pt-questionnaire-card__meta {
  display: flex;
  align-items: center;
  gap: var(--spacing-lg);
  font-size: var(--text-sm);
  color: var(--color-text-secondary);
  margin-top: var(--spacing-sm);
}
.pt-questionnaire-card__tags {
  display: flex;
  align-items: center;
  gap: var(--spacing-xs);
  flex-wrap: wrap;
  margin-top: var(--spacing-md);
}
.pt-questionnaire-card__actions {
  display: flex;
  align-items: center;
  gap: var(--spacing-sm);
  flex-wrap: wrap;
}
.pt-form-narrow {
  max-width: 40rem;
  margin-top: var(--spacing-lg);
}
.pt-form-actions {
  display: flex;
  align-items: center;
  gap: var(--spacing-sm);
  margin-top: var(--spacing-lg);
}
.pt-reg-types-wrap {
  border: 1px solid var(--color-border);
  border-radius: 0.5rem;
  overflow: hidden;
  background: var(--color-surface, #fff);
}
.pt-reg-types {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.875rem;
  color: var(--color-text-primary);
}
.pt-reg-types th, .pt-reg-types td {
  padding: 0.75rem 1rem;
  text-align: left;
  vertical-align: middle;
  border-bottom: 1px solid var(--color-border);
}
.pt-reg-types thead th {
  font-weight: 600;
  font-size: 0.6875rem;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--color-text-muted);
  background: var(--color-surface-subtle, oklch(98% 0 0));
}
.pt-reg-types tbody tr:last-child td {
  border-bottom: none;
}
.pt-reg-types tbody tr:hover {
  background: var(--color-surface-subtle, oklch(98% 0 0));
}
.pt-reg-types__name {
  font-weight: 600;
  color: var(--color-text-primary);
}
.pt-reg-types__muted {
  color: var(--color-text-muted);
}
.pt-reg-types__actions {
  display: flex;
  gap: 0.5rem;
  align-items: center;
  justify-content: flex-end;
}
.pt-reg-type-form {
  display: flex;
  flex-direction: column;
  gap: 1.25rem;
  max-width: 34rem;
}
.pt-reg-type-form__actions {
  display: flex;
  gap: 0.5rem;
  margin-top: 0.25rem;
}
.pt-vendor-registrations-new__grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(18rem, 24rem));
  gap: 1rem;
  margin-top: 1.5rem;
}
.pt-vendor-registrations-new__card-header {
  padding: 1.25rem 1.25rem 0;
}
.pt-vendor-registrations-new__type-name {
  margin: 0;
  color: var(--color-text);
  font-size: 1rem;
  font-weight: 700;
  line-height: 1.35;
}
.pt-vendor-registrations-new__card-footer {
  display: flex;
  justify-content: flex-end;
  padding: 1rem 1.25rem 1.25rem;
}
.pt-team-page {
  display: flex;
  flex-direction: column;
  gap: 2rem;
  min-width: 0;
}
.pt-team-section {
  min-width: 0;
}
.pt-team-section-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding-block-end: 0.75rem;
  border-bottom: 1px solid var(--color-border);
}
.pt-team-section-header__title {
  display: inline-flex;
  align-items: center;
  gap: 0.625rem;
  min-width: 0;
}
.pt-team-section-header__heading {
  margin: 0;
  color: var(--color-text-primary);
  font-size: 1rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}
.pt-team-section-header__icon {
  width: 1.25rem;
  height: 1.25rem;
  color: var(--color-brand);
  flex-shrink: 0;
}
.pt-team-section-header__actions {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 0.75rem;
  flex-wrap: wrap;
}
.pt-team-view-switcher {
  gap: 0.375rem;
  padding: 0;
  border: 0;
  background: transparent;
  box-shadow: none;
  overflow: visible;
}
.pt-team-view-switcher__button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.375rem;
  min-height: 2.375rem;
  padding: 0.4375rem 0.875rem;
  border: 1px solid var(--color-border);
  border-radius: 0.625rem;
  color: var(--color-text-secondary);
  background: var(--color-surface);
  box-shadow: 0 1px 2px oklch(20% 0 0 / 4%);
  font-size: 0.8125rem;
  font-weight: 600;
  text-decoration: none;
  transition: color 120ms ease, border-color 120ms ease, background-color 120ms ease, box-shadow 120ms ease, transform 120ms ease;
}
.pt-team-view-switcher__button:hover, .pt-team-view-switcher__button:focus-visible {
  color: var(--color-brand);
  border-color: color-mix( in oklab, oklch(45% 0.18 250) 55%, oklch(88% 0 0) );
  @supports (color: color-mix(in lab, red, red)) {
    border-color: color-mix( in oklab, var(--color-brand) 55%, var(--color-border) );
  }
  background: color-mix( in oklab, oklch(45% 0.18 250) 4%, oklch(99% 0 0) );
  @supports (color: color-mix(in lab, red, red)) {
    background: color-mix( in oklab, var(--color-brand) 4%, var(--color-surface) );
  }
  box-shadow: 0 0.25rem 0.625rem oklch(20% 0 0 / 7%);
  outline: none;
}
.pt-team-view-switcher__button:hover {
  transform: translateY(-1px);
}
.pt-team-view-switcher__button:focus-visible, .pt-team-chart-card__menu-button:focus-visible, .pt-team-chart-card__menu-item:focus-visible, .pt-team-card__link:focus-visible, .pt-team-table__link:focus-visible, .pt-team-pagination__button:focus-visible {
  outline: 3px solid color-mix( in oklab, oklch(45% 0.18 250) 35%, transparent );
  @supports (color: color-mix(in lab, red, red)) {
    outline: 3px solid color-mix( in oklab, var(--color-brand) 35%, transparent );
  }
  outline-offset: 2px;
}
.pt-team-view-switcher__button--active {
  color: var(--color-surface);
  border-color: var(--color-brand);
  background: var(--color-brand);
  box-shadow: 0 0.25rem 0.625rem color-mix( in oklab, oklch(45% 0.18 250) 22%, transparent );
  @supports (color: color-mix(in lab, red, red)) {
    box-shadow: 0 0.25rem 0.625rem color-mix( in oklab, var(--color-brand) 22%, transparent );
  }
}
.pt-team-view-switcher__button--active:hover, .pt-team-view-switcher__button--active:focus-visible {
  color: var(--color-surface);
  border-color: var(--color-brand);
  background: var(--color-brand);
}
.pt-team-view-switcher__icon {
  width: 1rem;
  height: 1rem;
  flex-shrink: 0;
}
.pt-team-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(14rem, 1fr));
  gap: 0.875rem;
  padding-block-start: 0.75rem;
}
.pt-team-grid__item {
  min-width: 0;
}
.pt-team-grid__item[hidden] {
  display: none;
}
.pt-team-grid__item > .pt-team-card {
  height: 100%;
}
.pt-team-card {
  display: flex;
  flex-direction: column;
  align-items: center;
  min-height: 100%;
  padding: 1rem;
  border: 1px solid var(--color-border);
  border-radius: 1rem;
  background: var(--color-surface);
  box-shadow: 0 0.25rem 0.75rem oklch(20% 0 0 / 5%);
  text-align: center;
  transform: translateY(0);
  transition: transform 160ms ease, box-shadow 160ms ease, border-color 160ms ease;
}
.pt-team-card:hover {
  border-color: color-mix( in oklab, oklch(45% 0.18 250) 28%, oklch(88% 0 0) );
  @supports (color: color-mix(in lab, red, red)) {
    border-color: color-mix( in oklab, var(--color-brand) 28%, var(--color-border) );
  }
  box-shadow: 0 0.75rem 1.5rem oklch(20% 0 0 / 10%);
  transform: translateY(-0.25rem);
}
.pt-team-card:focus-within {
  border-color: color-mix( in oklab, oklch(45% 0.18 250) 40%, oklch(88% 0 0) );
  @supports (color: color-mix(in lab, red, red)) {
    border-color: color-mix( in oklab, var(--color-brand) 40%, var(--color-border) );
  }
  box-shadow: 0 0.75rem 1.5rem oklch(20% 0 0 / 10%);
  transform: translateY(-0.25rem);
}
.pt-team-card__avatar {
  margin-block-end: 0.625rem;
}
.pt-team-card__avatar .pt-avatar {
  width: 5.75rem;
  height: 5.75rem;
  border: 1px solid var(--color-border);
  background: var(--color-surface-alt, oklch(96% 0 0));
  color: var(--color-text-secondary);
  font-size: 1.125rem;
}
.pt-team-card__body {
  display: flex;
  flex: 1;
  flex-direction: column;
  align-items: center;
  gap: 0.375rem;
  width: 100%;
  min-width: 0;
}
.pt-team-card__identity {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.25rem;
  width: 100%;
  min-width: 0;
  min-height: 4.5rem;
}
.pt-team-card__name {
  margin: 0;
  color: var(--color-text-primary);
  font-size: 0.96875rem;
  font-weight: 700;
}
.pt-team-card__role {
  margin: 0;
  color: var(--color-brand);
  font-size: 0.875rem;
  font-weight: 600;
}
.pt-team-card__meta {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.375rem;
  margin: 0;
  color: var(--color-text-secondary);
  font-size: 0.78125rem;
}
.pt-team-card__metadata {
  display: flex;
  align-items: flex-start;
  justify-content: center;
  width: 100%;
  min-height: 1.625rem;
}
.pt-team-card__meta-icon, .pt-team-card__badge-icon, .pt-team-card__contact-icon {
  width: 0.875rem;
  height: 0.875rem;
  flex-shrink: 0;
}
.pt-team-card__badges {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 0.25rem;
  margin-block-start: 0.125rem;
}
.pt-team-card__badge {
  display: inline-flex;
  align-items: center;
  gap: 0.25rem;
  max-width: 100%;
  padding: 0.1875rem 0.4375rem;
  border-radius: 999px;
  color: var(--color-text-secondary);
  background: var(--color-surface-alt, oklch(96% 0 0));
  font-size: 0.75rem;
  font-weight: 600;
}
.pt-team-card__contacts {
  display: grid;
  gap: 0.25rem;
  width: 100%;
  margin: 0.25rem 0 0;
  padding-block-start: 0.5rem;
  border-top: 1px solid var(--color-border);
}
.pt-team-card__contacts--empty {
  min-height: 0.5rem;
  padding-block-start: 0.375rem;
}
.pt-team-card__contact {
  display: grid;
  grid-template-columns: 1rem minmax(0, 1fr);
  align-items: center;
  gap: 0.3125rem;
  min-width: 0;
  color: var(--color-text-secondary);
  font-size: 0.78125rem;
  text-align: left;
}
.pt-team-card__contact-icon--linkedin {
  color: #0a66c2;
}
.pt-team-card__contact-label, .pt-team-card__contact-value {
  min-width: 0;
  margin: 0;
}
.pt-team-card__contact-value, .pt-team-card__link, .pt-team-table__link {
  overflow-wrap: anywhere;
}
.pt-team-card__link, .pt-team-table__link {
  color: var(--color-brand);
  text-decoration: none;
}
.pt-team-card__link:hover, .pt-team-table__link:hover {
  text-decoration: underline;
}
.pt-team-pagination {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.375rem;
  width: 100%;
  margin-block: 1.25rem 0;
}
.pt-team-pagination[hidden] {
  display: none;
}
.pt-team-pagination__button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 2.25rem;
  height: 2.25rem;
  padding: 0 0.625rem;
  border: 1px solid color-mix( in oklab, oklch(45% 0.18 250) 45%, oklch(88% 0 0) );
  @supports (color: color-mix(in lab, red, red)) {
    border: 1px solid color-mix( in oklab, var(--color-brand) 45%, var(--color-border) );
  }
  border-radius: 999px;
  color: var(--color-brand);
  background: var(--color-surface);
  font: inherit;
  font-size: 0.8125rem;
  font-weight: 700;
  line-height: 1;
  cursor: pointer;
  transition: color 120ms ease, border-color 120ms ease, background-color 120ms ease, transform 120ms ease;
}
.pt-team-pagination__button:hover:not(:disabled) {
  color: var(--color-surface);
  border-color: var(--color-brand);
  background: var(--color-brand);
  transform: translateY(-1px);
}
.pt-team-pagination__button--active, .pt-team-pagination__button--active:hover {
  color: var(--color-surface);
  border-color: var(--color-brand);
  background: var(--color-brand);
}
.pt-team-pagination__button--navigation {
  font-size: 1.25rem;
}
.pt-team-pagination__button:disabled {
  color: var(--color-text-disabled, var(--color-text-secondary));
  border-color: var(--color-border);
  background: var(--color-surface-alt, oklch(97% 0 0));
  cursor: not-allowed;
  opacity: 0.5;
}
.pt-team-pagination__ellipsis {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 1.5rem;
  height: 2.25rem;
  color: var(--color-text-secondary);
  font-weight: 700;
}
.pt-team-table__toolbar {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 0.625rem;
  flex-wrap: wrap;
  margin-block: 1rem 0.625rem;
}
.pt-team-table__toolbar .pt-button {
  min-height: 2.375rem;
  border-radius: 0.625rem;
}
.pt-team-table__export-action {
  display: flex;
  align-items: center;
}
.pt-team-table__export-action .pt-button {
  border-color: transparent;
  background: transparent;
  box-shadow: none;
}
.pt-team-table__export-action .pt-button:hover, .pt-team-table__export-action .pt-button:focus-visible {
  border-color: color-mix( in oklab, oklch(45% 0.18 250) 25%, transparent );
  @supports (color: color-mix(in lab, red, red)) {
    border-color: color-mix( in oklab, var(--color-brand) 25%, transparent );
  }
  background: color-mix( in oklab, oklch(45% 0.18 250) 6%, transparent );
  @supports (color: color-mix(in lab, red, red)) {
    background: color-mix( in oklab, var(--color-brand) 6%, transparent );
  }
}
.pt-team-table__export-action .pt-button:disabled {
  border-color: transparent;
  background: transparent;
  box-shadow: none;
}
.pt-team-table__grid-wrap {
  min-width: 0;
  max-width: 100%;
  overflow-x: auto;
  overflow-y: visible;
  border-radius: 0.875rem;
  background: var(--color-surface);
  box-shadow: 0 0.25rem 1rem oklch(20% 0 0 / 6%);
}
.pt-team-table__grid-wrap .pt-ag-grid-container {
  --ag-background-color: var(--color-surface);
  --ag-foreground-color: var(--color-text-primary);
  --ag-border-color: var(--color-border);
  --ag-secondary-border-color: var(--color-border);
  --ag-header-background-color: var(
            --color-surface-alt,
            oklch(97% 0 0)
    );
  --ag-header-foreground-color: var(--color-text-primary);
  --ag-odd-row-background-color: color-mix(
            in oklab,
            oklch(96% 0 0) 45%,
            oklch(99% 0 0)
    );
  @supports (color: color-mix(in lab, red, red)) {
    --ag-odd-row-background-color: color-mix(
            in oklab,
            var(--color-surface-alt, oklch(97% 0 0)) 45%,
            var(--color-surface)
    );
  }
  --ag-row-hover-color: color-mix(
            in oklab,
            oklch(45% 0.18 250) 8%,
            oklch(99% 0 0)
    );
  @supports (color: color-mix(in lab, red, red)) {
    --ag-row-hover-color: color-mix(
            in oklab,
            var(--color-brand) 8%,
            var(--color-surface)
    );
  }
  --ag-selected-row-background-color: color-mix(
            in oklab,
            oklch(45% 0.18 250) 12%,
            oklch(99% 0 0)
    );
  @supports (color: color-mix(in lab, red, red)) {
    --ag-selected-row-background-color: color-mix(
            in oklab,
            var(--color-brand) 12%,
            var(--color-surface)
    );
  }
  --ag-header-column-separator-display: block;
  --ag-header-column-separator-color: var(--color-border);
  --ag-header-column-separator-height: 55%;
  --ag-wrapper-border-radius: 0.875rem;
  --ag-font-size: 0.8125rem;
  --ag-grid-size: 0.375rem;
  --ag-cell-horizontal-padding: 0.75rem;
  min-width: 58rem;
  height: auto;
  min-height: 0;
  overflow: visible;
  border: 0;
  border-radius: 0.875rem;
}
.pt-team-table__grid-wrap .pt-ag-grid-container[data-ag-grid-dom-layout-value="autoHeight"] {
  height: auto !important;
  min-height: 0 !important;
}
.pt-team-table__grid-wrap .ag-layout-auto-height, .pt-team-table__grid-wrap .ag-layout-auto-height .ag-center-cols-viewport, .pt-team-table__grid-wrap .ag-layout-auto-height .ag-center-cols-container {
  min-height: 0;
}
.pt-team-table__grid-wrap .pt-team-table__grid--empty .ag-center-cols-viewport, .pt-team-table__grid-wrap .pt-team-table__grid--empty .ag-center-cols-container, .pt-team-table__grid-wrap .pt-team-table__grid--empty .ag-body-viewport, .pt-team-table__grid-wrap .pt-team-table__grid--empty .ag-body {
  min-height: 9rem !important;
}
.pt-team-table__grid-wrap .pt-team-table__grid--empty .ag-overlay-wrapper {
  min-height: 9rem;
}
.pt-team-table__grid-wrap .pt-team-table__grid--empty .ag-overlay-no-rows-wrapper {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 9rem;
  padding: 1.5rem;
}
.pt-team-table__grid-wrap .pt-team-table__grid--empty .ag-overlay-no-rows-center {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 3rem;
  margin: 0;
  padding: 0.75rem 1.25rem;
  border: 1px solid color-mix( in oklab, oklch(88% 0 0) 80%, oklch(45% 0.18 250) );
  @supports (color: color-mix(in lab, red, red)) {
    border: 1px solid color-mix( in oklab, var(--color-border) 80%, var(--color-brand) );
  }
  border-radius: 0.75rem;
  color: var(--color-text-secondary);
  background: var(--color-surface-alt, oklch(98% 0 0));
  box-shadow: 0 0.25rem 0.75rem oklch(20% 0 0 / 5%);
  font-size: 0.875rem;
  font-weight: 600;
  text-align: center;
}
.pt-team-table__grid-wrap .ag-root-wrapper {
  overflow: hidden;
  border: 1px solid var(--color-border);
  border-radius: 0.875rem;
}
.pt-team-table__grid-wrap .ag-header {
  border-bottom: 1px solid var(--color-border);
}
.pt-team-table__grid-wrap .ag-header-cell {
  border-inline-end: 1px solid var(--color-border);
  font-size: 0.75rem;
  font-weight: 700;
  letter-spacing: 0.025em;
}
.pt-team-table__grid-wrap .ag-header-cell-label {
  gap: 0.375rem;
}
.pt-team-table__grid-wrap .ag-header-cell:hover {
  background: color-mix( in oklab, oklch(45% 0.18 250) 5%, oklch(96% 0 0) );
  @supports (color: color-mix(in lab, red, red)) {
    background: color-mix( in oklab, var(--color-brand) 5%, var(--color-surface-alt, oklch(97% 0 0)) );
  }
}
.pt-team-table__grid-wrap .ag-row {
  border-color: color-mix( in oklab, oklch(88% 0 0) 75%, transparent );
  @supports (color: color-mix(in lab, red, red)) {
    border-color: color-mix( in oklab, var(--color-border) 75%, transparent );
  }
  transition: background-color 120ms ease;
}
.pt-team-table__grid-wrap .ag-cell {
  display: flex;
  align-items: center;
  line-height: 1.35;
}
.pt-team-table__grid-wrap .ag-cell-value {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.pt-team-table__grid-wrap .pt-ag-grid__cell {
  display: flex;
  align-items: center;
  min-width: 0;
  height: 100%;
}
.pt-team-table__grid-wrap .pt-team-table__link {
  display: block;
  min-width: 0;
  overflow: hidden;
  color: var(--color-brand);
  text-overflow: ellipsis;
  white-space: nowrap;
}
.pt-team-table__grid-wrap .ag-menu, .pt-team-table__grid-wrap .ag-tabs-header {
  border-radius: 0.75rem;
}
.pt-team-table__grid-wrap .ag-menu-option {
  border-radius: 0.375rem;
}
.pt-team-filter-popup {
  min-width: 24rem;
  overflow: hidden;
  border: 1px solid color-mix( in oklab, oklch(88% 0 0) 88%, oklch(45% 0.18 250) );
  @supports (color: color-mix(in lab, red, red)) {
    border: 1px solid color-mix( in oklab, var(--color-border) 88%, var(--color-brand) );
  }
  border-radius: 0.875rem;
  background: var(--color-surface);
  box-shadow: 0 1rem 2.5rem oklch(20% 0 0 / 18%);
}
.pt-team-filter-popup .ag-filter {
  min-width: 24rem;
}
.pt-team-filter-popup .ag-filter-body-wrapper {
  gap: 0.875rem;
  padding: 1.25rem;
}
.pt-team-filter-popup .ag-filter-select, .pt-team-filter-popup .ag-picker-field, .pt-team-filter-popup .ag-input-field {
  width: 100%;
}
.pt-team-filter-popup .ag-picker-field-wrapper, .pt-team-filter-popup .ag-input-field-input {
  width: 100%;
  min-height: 2.75rem;
  border-color: var(--color-border);
  border-radius: 0.625rem;
  background: var(--color-surface);
  font-size: 0.875rem;
}
.pt-team-filter-popup .ag-input-field-input {
  padding-inline: 0.875rem;
}
.pt-team-filter-popup .ag-picker-field-wrapper:hover, .pt-team-filter-popup .ag-input-field-input:hover {
  border-color: color-mix( in oklab, oklch(45% 0.18 250) 45%, oklch(45% 0.18 250) 45%, oklch(88% 0 0) );
  @supports (color: color-mix(in lab, red, red)) {
    border-color: color-mix( in oklab, var(--color-brand) 45%, var(--color-brand) 45%, var(--color-border) );
  }
}
.pt-team-filter-popup .ag-picker-field-wrapper:focus-within, .pt-team-filter-popup .ag-input-field-input:focus {
  border-color: var(--color-brand);
  box-shadow: 0 0 0 3px color-mix( in oklab, oklch(45% 0.18 250) 15%, transparent );
  @supports (color: color-mix(in lab, red, red)) {
    box-shadow: 0 0 0 3px color-mix( in oklab, var(--color-brand) 15%, transparent );
  }
  outline: none;
}
.pt-team-filter-popup .ag-filter-condition {
  gap: 0.875rem;
}
.pt-team-filter-popup .ag-filter-apply-panel {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  min-height: 4rem;
  padding: 0.75rem 1rem;
  border-top: 1px solid var(--color-border);
  background: var(--color-surface-alt, oklch(98% 0 0));
}
.pt-team-filter-popup .ag-filter-apply-panel-button.pt-team-ag-filter-button--apply, .pt-team-filter-popup .ag-filter-apply-panel-button.pt-team-ag-filter-button--reset {
  min-height: 2.25rem;
  padding: 0.4375rem 1rem;
  border: 1px solid transparent;
  border-radius: 0.625rem;
  box-shadow: none;
  font-size: 0.75rem;
  font-weight: 700;
  line-height: 1;
  transition: color 120ms ease, background-color 120ms ease, border-color 120ms ease, box-shadow 120ms ease, transform 120ms ease;
}
.pt-team-filter-popup .ag-filter-apply-panel-button.pt-team-ag-filter-button--reset {
  order: 1;
  margin-inline-end: auto;
  border-color: var(--color-danger);
  color: var(--color-on-danger, #fff);
  background: var(--color-danger);
}
.pt-team-filter-popup .ag-filter-apply-panel-button.pt-team-ag-filter-button--apply {
  order: 2;
  margin-inline-start: auto;
  border-color: var(--color-success);
  color: var(--color-on-success, #fff);
  background: var(--color-success);
}
.pt-team-filter-popup .ag-filter-apply-panel-button.pt-team-ag-filter-button--reset:hover, .pt-team-filter-popup .ag-filter-apply-panel-button.pt-team-ag-filter-button--reset:focus-visible {
  border-color: var(--color-danger-hover, var(--color-danger));
  color: var(--color-on-danger, #fff);
  background: var(--color-danger-hover, var(--color-danger));
}
.pt-team-filter-popup .ag-filter-apply-panel-button.pt-team-ag-filter-button--apply:hover, .pt-team-filter-popup .ag-filter-apply-panel-button.pt-team-ag-filter-button--apply:focus-visible {
  border-color: var(--color-success-hover, var(--color-success));
  color: var(--color-on-success, #fff);
  background: var(--color-success-hover, var(--color-success));
}
.pt-team-filter-popup .ag-filter-apply-panel-button.pt-team-ag-filter-button--apply:hover, .pt-team-filter-popup .ag-filter-apply-panel-button.pt-team-ag-filter-button--reset:hover {
  transform: translateY(-1px);
}
.pt-team-filter-popup .ag-filter-apply-panel-button.pt-team-ag-filter-button--apply:focus-visible, .pt-team-filter-popup .ag-filter-apply-panel-button.pt-team-ag-filter-button--reset:focus-visible {
  outline: 3px solid color-mix( in oklab, oklch(45% 0.18 250) 30%, transparent );
  @supports (color: color-mix(in lab, red, red)) {
    outline: 3px solid color-mix( in oklab, var(--color-brand) 30%, transparent );
  }
  outline-offset: 2px;
}
.pt-team-table__grid-wrap .ag-paging-panel {
  display: flex;
  align-items: center;
  justify-content: center !important;
  gap: 0.5rem;
  min-height: 3rem;
  padding: 0.5rem 0.75rem;
  border-top: 1px solid var(--color-border);
  background: var(--color-surface);
  color: var(--color-text-secondary);
  font-size: 0.75rem;
}
.pt-team-table__grid-wrap .ag-paging-page-summary-panel {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.25rem;
}
.pt-team-table__grid-wrap .ag-paging-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2rem;
  height: 2rem;
  border-radius: 999px;
  color: var(--color-text-secondary);
  transition: color 120ms ease, background-color 120ms ease, opacity 120ms ease;
}
.pt-team-table__grid-wrap .ag-paging-button:hover:not(.ag-disabled) {
  color: var(--color-brand);
  background: color-mix( in oklab, oklch(45% 0.18 250) 8%, oklch(99% 0 0) );
  @supports (color: color-mix(in lab, red, red)) {
    background: color-mix( in oklab, var(--color-brand) 8%, var(--color-surface) );
  }
}
.pt-team-table__grid-wrap .ag-paging-button:focus-visible {
  outline: 3px solid color-mix( in oklab, oklch(45% 0.18 250) 30%, transparent );
  @supports (color: color-mix(in lab, red, red)) {
    outline: 3px solid color-mix( in oklab, var(--color-brand) 30%, transparent );
  }
  outline-offset: 1px;
}
.pt-team-table__grid-wrap .ag-paging-button.ag-disabled {
  opacity: 0.4;
}
.pt-team-staff-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1rem;
  padding-block-start: 1.25rem;
}
.pt-team-chart-card {
  position: relative;
  display: flex;
  flex-direction: column;
  min-width: 0;
  min-height: 26rem;
  border: 1px solid var(--color-border);
  border-radius: 1rem;
  background: var(--color-surface);
  box-shadow: 0 0.25rem 0.75rem oklch(20% 0 0 / 5%);
}
.pt-team-chart-card__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: 1rem 1rem 0;
}
.pt-team-chart-card__title {
  margin: 0;
  color: var(--color-text-primary);
  font-size: 1rem;
  font-weight: 700;
}
.pt-team-chart-card__body {
  flex: 1;
  min-width: 0;
  padding: 0.75rem 1rem 1rem;
}
.pt-team-chart-card__body .pt-ag-donut-chart {
  width: 100%;
}
.pt-team-chart-card__menu {
  position: relative;
  flex-shrink: 0;
}
.pt-team-chart-card__menu-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2rem;
  height: 2rem;
  border: 1px solid transparent;
  border-radius: 999px;
  color: var(--color-text-secondary);
  background: transparent;
  cursor: pointer;
}
.pt-team-chart-card__menu-button:hover {
  color: var(--color-brand);
  background: var(--color-surface-alt, oklch(96% 0 0));
}
.pt-team-chart-card__menu-icon {
  width: 1.125rem;
  height: 1.125rem;
}
.pt-team-chart-card__menu-panel {
  position: absolute;
  inset-inline-end: 0;
  z-index: 20;
  min-width: 13rem;
  margin-block-start: 0.375rem;
  padding: 0.375rem;
  border: 1px solid var(--color-border);
  border-radius: 0.75rem;
  background: var(--color-surface);
  box-shadow: 0 0.75rem 1.5rem oklch(20% 0 0 / 12%);
}
.pt-team-chart-card__menu-panel[hidden] {
  display: none;
}
.pt-team-chart-card__menu-item {
  display: block;
  width: 100%;
  padding: 0.5rem 0.625rem;
  border: 0;
  border-radius: 0.5rem;
  color: var(--color-text-primary);
  background: transparent;
  font: inherit;
  font-size: 0.8125rem;
  text-align: left;
  cursor: pointer;
}
.pt-team-chart-card__menu-item:hover {
  background: var(--color-surface-alt, oklch(96% 0 0));
}
.pt-team-pie-wrap {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  min-height: 19.5rem;
}
.pt-team-pie {
  width: 100%;
  max-width: 29rem;
  height: auto;
  overflow: visible;
}
.pt-team-pie__slice {
  cursor: pointer;
  outline: none;
  transform-box: fill-box;
  transform-origin: center;
  transition: transform 0.18s ease, opacity 0.18s ease, filter 0.18s ease;
}
.pt-team-pie--has-hover .pt-team-pie__slice, .pt-team-pie:focus-within .pt-team-pie__slice {
  opacity: 0.18;
}
.pt-team-pie--has-hover .pt-team-pie__slice:hover, .pt-team-pie:focus-within .pt-team-pie__slice:focus-visible, .pt-team-pie .pt-team-pie__slice--active {
  opacity: 1;
}
.pt-team-pie__slice:hover, .pt-team-pie__slice:focus-visible, .pt-team-pie__slice--active {
  transform: translate( var(--pt-pie-explode-x), var(--pt-pie-explode-y) );
  filter: drop-shadow(0 5px 8px rgba(15, 23, 42, 0.22));
}
.pt-team-pie__sector {
  stroke: #fff;
  stroke-width: 1.35;
  transition: stroke-width 0.18s ease, opacity 0.18s ease;
}
.pt-team-pie__slice:hover .pt-team-pie__sector, .pt-team-pie__slice:focus-visible .pt-team-pie__sector, .pt-team-pie__slice--active .pt-team-pie__sector {
  stroke-width: 2.5;
}
.pt-team-pie__label {
  fill: var(--color-text-primary);
  cursor: pointer;
  font-size: 0.66rem;
  font-weight: 600;
  letter-spacing: 0.005em;
  line-height: 1.2;
  pointer-events: visiblePainted;
}
.pt-team-pie__callout {
  fill: none;
  stroke: #b8c0ca;
  stroke-width: 1;
  cursor: pointer;
  pointer-events: stroke;
}
.pt-team-pie__slice:hover .pt-team-pie__callout, .pt-team-pie__slice:focus-visible .pt-team-pie__callout, .pt-team-pie__slice--active .pt-team-pie__callout {
  stroke: color-mix( in srgb, oklch(45% 0.18 250) 70%, #7b8794 );
  @supports (color: color-mix(in lab, red, red)) {
    stroke: color-mix( in srgb, var(--color-brand) 70%, #7b8794 );
  }
  stroke-width: 1.25;
}
.pt-team-pie__slice:hover .pt-team-pie__label, .pt-team-pie__slice:focus-visible .pt-team-pie__label, .pt-team-pie__slice--active .pt-team-pie__label {
  fill: var(--color-text-primary);
  font-weight: 700;
}
.pt-team-pie-tooltip {
  position: absolute;
  z-index: 10;
  display: grid;
  gap: 0.1rem;
  min-width: 7.5rem;
  padding: 0.5rem 0.625rem;
  border: 1px solid color-mix(in srgb, oklch(45% 0.18 250) 55%, oklch(88% 0 0));
  @supports (color: color-mix(in lab, red, red)) {
    border: 1px solid color-mix(in srgb, var(--color-brand) 55%, var(--color-border));
  }
  border-radius: 0.25rem;
  background: var(--color-surface);
  color: var(--color-text-primary);
  box-shadow: 0 8px 22px rgba(15, 23, 42, 0.2);
  font-size: 0.75rem;
  line-height: 1.25;
  pointer-events: none;
}
.pt-team-pie-tooltip[hidden] {
  display: none;
}
.pt-team-pie-tooltip strong {
  font-weight: 700;
}
.pt-team-pie-tooltip span {
  color: var(--color-text-secondary);
}
.pt-team-pie-legend {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem 0.75rem;
  justify-content: center;
  margin: 0.75rem 0 0;
  padding: 0;
  list-style: none;
}
.pt-team-pie-legend__item {
  display: inline-flex;
  align-items: center;
  gap: 0.375rem;
  color: var(--color-text-secondary);
  font-size: 0.75rem;
  line-height: 1.2;
}
.pt-team-pie-legend__swatch {
  width: 0.625rem;
  height: 0.625rem;
  border-radius: 999px;
  flex-shrink: 0;
}
.pt-team-pie-legend__label {
  color: var(--color-text-primary);
  font-weight: 600;
}
.pt-team-pie-legend__value {
  font-variant-numeric: tabular-nums;
}
@media (max-width: 900px) {
  .pt-team-section-header {
    align-items: flex-start;
    flex-direction: column;
  }
  .pt-team-section-header__actions {
    justify-content: flex-start;
    width: 100%;
  }
  .pt-team-staff-grid {
    grid-template-columns: 1fr;
  }
}
@media (max-width: 560px) {
  .pt-team-view-switcher {
    width: 100%;
  }
  .pt-team-view-switcher__button {
    flex: 1;
  }
  .pt-team-pagination {
    flex-wrap: wrap;
  }
  .pt-team-table__toolbar {
    justify-content: stretch;
  }
  .pt-team-table__toolbar > * {
    flex: 1;
  }
  .pt-team-table__export-action .pt-button {
    width: 100%;
    justify-content: center;
  }
  .pt-team-table__grid-wrap .pt-ag-grid-container {
    min-width: 48rem;
    height: auto;
    min-height: 0;
  }
  .pt-team-table__grid-wrap .ag-paging-panel {
    justify-content: center !important;
    gap: 0.25rem;
    padding-inline: 0.5rem;
  }
  .pt-team-filter-popup, .pt-team-filter-popup .ag-filter {
    min-width: min(24rem, calc(100vw - 2rem));
    max-width: calc(100vw - 2rem);
  }
}
@media (prefers-reduced-motion: reduce) {
  .pt-team-card, .pt-team-view-switcher__button, .pt-team-pagination__button, .pt-team-pie__slice, .pt-team-pie__sector, .pt-team-filter-popup .ag-filter-apply-panel-button {
    transition: none;
  }
  .pt-team-card:hover, .pt-team-card:focus-within, .pt-team-view-switcher__button:hover, .pt-team-pagination__button:hover:not(:disabled), .pt-team-filter-popup .ag-filter-apply-panel-button:hover {
    transform: none;
  }
}
@media print {
  body.pt-team-chart-printing * {
    visibility: hidden !important;
  }
  body.pt-team-chart-printing .pt-team-chart-card--printing, body.pt-team-chart-printing .pt-team-chart-card--printing * {
    visibility: visible !important;
  }
  body.pt-team-chart-printing .pt-team-chart-card--printing {
    position: fixed !important;
    inset: 1rem !important;
    width: auto !important;
    height: auto !important;
    box-shadow: none !important;
  }
  body.pt-team-chart-printing .pt-team-chart-card--printing .pt-team-chart-card__menu {
    display: none !important;
  }
}
.pt-vendor-registration-show {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}
.pt-vendor-registration-actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 0.5rem;
}
.pt-vendor-registration-actions__back {
  min-height: 2.5rem;
  padding-inline: 1rem;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  background: var(--color-surface);
  box-shadow: var(--shadow-xs);
  font-weight: 700;
}
.pt-vendor-registration-show__meta-strip {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.75rem;
  padding: 0.875rem 1rem;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  background: var(--color-surface);
}
.pt-vendor-registration-show__meta-item {
  display: inline-flex;
  align-items: baseline;
  gap: 0.35rem;
  min-width: 0;
  color: var(--color-text-secondary);
  font-size: 0.8125rem;
}
.pt-vendor-registration-show__meta-label {
  color: var(--color-muted);
  font-weight: 600;
}
.pt-vendor-registration-show__meta-value {
  min-width: 0;
  color: var(--color-text);
  font-weight: 600;
}
.pt-vendor-registration-show__layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(19rem, 24rem);
  align-items: start;
  gap: 1rem;
}
.pt-vendor-registration-show__main, .pt-vendor-registration-show__aside {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  min-width: 0;
}
.pt-vendor-registration-show__aside {
  position: sticky;
  top: 1rem;
}
.pt-vendor-registration-documents__header, .pt-vendor-registration-status-panel__header, .pt-vendor-registration-history__header, .pt-vendor-registration-review__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  width: 100%;
}
.pt-vendor-registration-documents__header {
  min-height: 5.25rem;
  padding: 0.875rem 1.25rem;
}
.pt-vendor-registration-documents__heading, .pt-vendor-registration-history__heading, .pt-vendor-registration-review__heading {
  display: inline-flex;
  align-items: center;
  gap: 0.875rem;
  min-width: 0;
}
.pt-vendor-registration-documents__header-icon-wrap, .pt-vendor-registration-history__header-icon-wrap {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.25rem;
  height: 2.25rem;
  flex-shrink: 0;
  border-radius: var(--radius-md);
  background: var(--color-brand-subtle);
  color: var(--color-brand);
}
.pt-vendor-registration-documents__header-icon, .pt-vendor-registration-history__header-icon, .pt-vendor-registration-review__header-icon {
  width: 1.125rem;
  height: 1.125rem;
  flex-shrink: 0;
  color: var(--color-brand);
}
.pt-vendor-registration-documents__heading-text {
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 0.25rem;
  min-width: 0;
}
.pt-vendor-registration-documents__title, .pt-vendor-registration-status-panel__title, .pt-vendor-registration-history__title, .pt-vendor-registration-review__title {
  margin: 0;
  color: var(--color-text);
  font-size: 0.95rem;
  font-weight: 700;
  line-height: 1.3;
}
.pt-vendor-registration-documents__subtitle {
  max-width: 40rem;
  margin: 0;
  color: var(--color-text-secondary);
  font-size: 0.8125rem;
  font-weight: 500;
  line-height: 1.45;
}
.pt-vendor-registration-documents__count {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 1.75rem;
  flex-shrink: 0;
  padding: 0.25rem 0.75rem;
  border-radius: 999px;
  background: var(--color-surface-alt);
  color: var(--color-muted);
  font-size: 0.75rem;
  font-weight: 700;
  white-space: nowrap;
}
.pt-vendor-registration-documents {
  min-width: 0;
}
.pt-vendor-registration-documents__layout {
  display: grid;
  grid-template-columns: minmax(14rem, 18rem) minmax(0, 1fr);
  min-height: 39rem;
  border-top: 1px solid var(--color-border);
}
.pt-vendor-registration-documents__list {
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
  padding: 0.75rem;
  border-right: 1px solid var(--color-border);
  background: var(--color-surface-alt);
}
.pt-vendor-registration-documents__item {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  gap: 0.35rem;
  border: 1px solid transparent;
  border-radius: var(--radius-md);
}
.pt-vendor-registration-documents__item--active {
  border-color: var(--color-brand);
  background: var(--color-brand-subtle);
}
.pt-vendor-registration-documents__link {
  display: inline-flex;
  align-items: center;
  min-width: 0;
  gap: 0.5rem;
  padding: 0.625rem 0.5rem;
  color: var(--color-text);
  text-decoration: none;
}
.pt-vendor-registration-documents__item-name {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  font-size: 0.8125rem;
  font-weight: 600;
}
.pt-vendor-registration-documents__item-icon {
  width: 1rem;
  height: 1rem;
  flex-shrink: 0;
  color: var(--color-muted);
}
.pt-vendor-registration-documents__download {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2rem;
  height: 2rem;
  margin-right: 0.25rem;
  border-radius: var(--radius-sm);
  color: var(--color-muted);
  text-decoration: none;
}
.pt-vendor-registration-documents__download:hover {
  background: var(--color-surface);
  color: var(--color-brand);
}
.pt-vendor-registration-documents__download-icon {
  width: 1rem;
  height: 1rem;
}
.pt-vendor-registration-documents__preview {
  min-width: 0;
  padding: 0.75rem;
  background: var(--color-surface);
}
.pt-vendor-registration-documents__preview-surface {
  height: 100%;
  min-height: 37rem;
  padding: 0.75rem;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  background: var(--color-surface-alt);
}
.pt-vendor-registration-documents__preview-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  margin-bottom: 0.75rem;
}
.pt-vendor-registration-documents__preview-title {
  min-width: 0;
  margin: 0;
  overflow: hidden;
  color: var(--color-text);
  font-size: 0.875rem;
  font-weight: 700;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.pt-vendor-registration-documents__empty {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 26rem;
  padding: 2rem;
  border-top: 1px solid var(--color-border);
  background: var(--color-surface);
}
.pt-vendor-registration-documents__empty-card {
  display: flex;
  flex-direction: column;
  align-items: center;
  max-width: 28rem;
  padding: 2.25rem 2rem;
  text-align: center;
}
.pt-vendor-registration-documents__empty-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 3.25rem;
  height: 3.25rem;
  margin-bottom: 1rem;
  border: 1px solid var(--color-border);
  border-radius: 999px;
  background: var(--color-surface-alt);
  color: var(--color-brand);
  box-shadow: var(--shadow-sm);
}
.pt-vendor-registration-documents__empty-svg {
  width: 1.5rem;
  height: 1.5rem;
}
.pt-vendor-registration-documents__empty-title {
  margin: 0;
  color: var(--color-text);
  font-size: 1rem;
  font-weight: 800;
  line-height: 1.35;
}
.pt-vendor-registration-documents__empty-copy {
  max-width: 22rem;
  margin: 0.5rem 0 0;
  color: var(--color-text-secondary);
  font-size: 0.875rem;
  line-height: 1.5;
}
.pt-vendor-registration-status-panel__list {
  display: flex;
  flex-direction: column;
  gap: 0;
  margin: 0;
}
.pt-vendor-registration-status-panel__row {
  display: grid;
  grid-template-columns: minmax(7.5rem, 42%) minmax(0, 1fr);
  gap: 0.75rem;
  padding: 0.625rem 0;
  border-bottom: 1px solid var(--color-border);
}
.pt-vendor-registration-status-panel__row:last-child {
  border-bottom: 0;
}
.pt-vendor-registration-status-panel__label {
  margin: 0;
  color: var(--color-muted);
  font-size: 0.75rem;
  font-weight: 700;
  text-transform: uppercase;
}
.pt-vendor-registration-status-panel__value {
  min-width: 0;
  margin: 0;
  overflow-wrap: anywhere;
  color: var(--color-text);
  font-size: 0.875rem;
  font-weight: 600;
}
.pt-vendor-registration-status-panel__note {
  margin-top: 1rem;
  padding: 0.875rem;
  border-radius: var(--radius-md);
  background: var(--color-surface-alt);
}
.pt-vendor-registration-status-panel__note-body {
  margin-top: 0.35rem;
  color: var(--color-text);
  font-size: 0.875rem;
  line-height: 1.5;
  white-space: pre-wrap;
}
.pt-vendor-registration-form {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}
.pt-vendor-registration-modal {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}
.pt-vendor-registration-modal__copy {
  margin: 0;
  color: var(--color-text-secondary);
  font-size: 0.875rem;
  line-height: 1.5;
}
.pt-vendor-registration-form__grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.75rem;
}
.pt-vendor-registration-form__field {
  display: flex;
  flex-direction: column;
  gap: 0.35rem;
  min-width: 0;
}
.pt-vendor-registration-form__actions {
  display: flex;
  justify-content: flex-end;
  gap: 0.5rem;
  padding-top: 0.25rem;
}
.pt-vendor-registration-history {
  max-height: min(34rem, 70vh);
  overflow: auto;
}
.pt-vendor-registration-history__table-wrap {
  width: 100%;
  overflow: auto;
}
.pt-vendor-registration-history__table {
  width: 100%;
  border-collapse: separate;
  border-spacing: 0;
  table-layout: fixed;
}
.pt-vendor-registration-history__thead {
  background: var(--color-surface-alt);
}
.pt-vendor-registration-history__th {
  padding: 0.875rem 1rem;
  border-bottom: 1px solid var(--color-border);
  color: var(--color-muted);
  font-size: 0.72rem;
  font-weight: 800;
  letter-spacing: 0.06em;
  text-align: left;
  text-transform: uppercase;
  white-space: nowrap;
}
.pt-vendor-registration-history__th:first-child {
  width: 46%;
}
.pt-vendor-registration-history__th:nth-child(2) {
  width: 30%;
}
.pt-vendor-registration-history__th--date {
  width: 24%;
}
.pt-vendor-registration-history__row {
  background: var(--color-surface);
}
.pt-vendor-registration-history__row + .pt-vendor-registration-history__row .pt-vendor-registration-history__td {
  border-top: 1px solid var(--color-border);
}
.pt-vendor-registration-history__td {
  padding: 1rem;
  vertical-align: middle;
}
.pt-vendor-registration-history__td--event {
  min-width: 18rem;
}
.pt-vendor-registration-history__td--actor {
  color: var(--color-text);
  font-size: 0.8125rem;
  font-weight: 700;
}
.pt-vendor-registration-history__td--date {
  color: var(--color-text-secondary);
  font-size: 0.8125rem;
  white-space: nowrap;
}
.pt-vendor-registration-history__event {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  align-items: center;
  gap: 0.75rem;
  min-width: 0;
}
.pt-vendor-registration-history__icon-wrap {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2rem;
  height: 2rem;
  flex-shrink: 0;
  border-radius: var(--radius-md);
  background: var(--color-brand-subtle);
  color: var(--color-brand);
}
.pt-vendor-registration-history__icon {
  width: 1rem;
  height: 1rem;
}
.pt-vendor-registration-history__event-text, .pt-vendor-registration-history__event-content {
  min-width: 0;
}
.pt-vendor-registration-history__item-title {
  color: var(--color-text);
  font-size: 0.875rem;
  font-weight: 800;
  line-height: 1.35;
}
.pt-vendor-registration-history__item-body {
  margin-top: 0.125rem;
  color: var(--color-text-secondary);
  font-size: 0.8125rem;
  line-height: 1.4;
}
.pt-vendor-registration-history__time {
  display: block;
  color: var(--color-text-secondary);
  font-size: 0.8125rem;
  white-space: nowrap;
}
.pt-vendor-registration-history__empty {
  padding: 1rem 0;
  color: var(--color-text-secondary);
  font-size: 0.8125rem;
}
.pt-vendor-registration-history__sort-button {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  padding: 0;
  border: 0;
  background: transparent;
  color: inherit;
  cursor: pointer;
  font: inherit;
  text-transform: inherit;
}
.pt-vendor-registration-history__sort-icon {
  width: 0.875rem;
  height: 0.875rem;
  transition: transform 0.15s ease;
}
.pt-vendor-registration-history__sort-button--asc .pt-vendor-registration-history__sort-icon {
  transform: rotate(180deg);
}
.pt-vendor-registration-history__list {
  display: flex;
  flex-direction: column;
  gap: 0.875rem;
  margin: 0;
  padding: 0;
  list-style: none;
}
.pt-vendor-registration-history__item {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: 0.75rem;
}
.pt-vendor-registration-review {
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
}
@media (max-width: 1180px) {
  .pt-vendor-registration-show__layout {
    grid-template-columns: 1fr;
  }
  .pt-vendor-registration-show__aside {
    position: static;
  }
}
@media (max-width: 860px) {
  .pt-vendor-registration-documents__layout {
    grid-template-columns: 1fr;
  }
  .pt-vendor-registration-documents__list {
    border-right: 0;
    border-bottom: 1px solid var(--color-border);
  }
  .pt-vendor-registration-form__grid {
    grid-template-columns: 1fr;
  }
  .pt-vendor-registration-history {
    overflow-x: auto;
  }
  .pt-vendor-registration-history__table {
    min-width: 42rem;
  }
}
@media (max-width: 680px) {
  .pt-vendor-registration-actions, .pt-page-header__actions {
    justify-content: flex-start;
    width: 100%;
  }
  .pt-vendor-registration-show__meta-strip {
    align-items: flex-start;
    flex-direction: column;
  }
  .pt-vendor-registration-status-panel__row {
    grid-template-columns: 1fr;
    gap: 0.2rem;
  }
  .pt-vendor-registration-documents__header {
    align-items: flex-start;
    flex-direction: column;
    padding: 1rem;
  }
  .pt-vendor-registration-documents__count {
    align-self: flex-start;
  }
  .pt-vendor-registration-history__header {
    align-items: flex-start;
    flex-direction: column;
  }
}
.pt-workplace-projects-new {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  padding: 1rem 1.25rem 2rem;
}
.pt-back-link {
  display: inline-flex;
  align-items: center;
  gap: 0.375rem;
  align-self: flex-start;
  color: var(--color-text-secondary);
  font-size: var(--text-sm);
  text-decoration: none;
  transition: color 120ms ease;
}
.pt-back-link:hover {
  color: var(--color-brand);
}
.pt-back-link__icon {
  flex-shrink: 0;
}
.pt-wp-project-directory .pt-card, .pt-wp-project-directory .pt-filter-section, .pt-wp-project-directory .pt-wp-card {
  border-radius: 0.25rem;
}
.pt-wp-hits {
  min-height: 200px;
  position: relative;
}
.pt-wp-hits--list .pt-wp-grid {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  list-style: none;
  padding: 0;
  margin: 0;
}
.pt-wp-grid__item {
  list-style: none;
  min-width: 0;
  display: flex;
  width: 100%;
}
.pt-wp-grid__item > * {
  flex: 1 1 auto;
  width: 100%;
}
.pt-wp-hits--empty {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 300px;
}
.pt-wp-card {
  position: relative;
  display: flex;
  flex-direction: row;
  align-items: stretch;
  width: 100%;
  background: var(--color-surface);
  border: 1px solid oklch(91% 0 0);
  border-radius: 0.25rem;
  overflow: hidden;
  box-shadow: 0 0.15rem 0.5rem oklch(20% 0 0 / 4%);
  transition: box-shadow 150ms ease, border-color 150ms ease, transform 120ms ease;
}
.pt-wp-card:hover {
  border-color: oklch(82% 0 0);
  box-shadow: 0 0.35rem 0.85rem oklch(20% 0 0 / 8%);
  transform: translateY(-1px);
}
.pt-wp-card__media-link {
  flex: 0 0 8rem;
  max-width: 8rem;
  display: block;
  color: inherit;
  text-decoration: none;
  background: oklch(96% 0 0);
}
.pt-wp-card__media {
  width: 100%;
  height: 100%;
  min-height: 5rem;
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
}
.pt-wp-card__photo {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 250ms ease;
}
.pt-wp-card:hover .pt-wp-card__photo {
  transform: scale(1.02);
}
.pt-wp-card__photo-placeholder {
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  color: oklch(70% 0 0);
}
.pt-wp-card__photo-placeholder svg {
  width: 2.5rem;
  height: 2.5rem;
}
.pt-wp-card__content {
  flex: 1 1 auto;
  min-width: 0;
  display: flex;
  flex-direction: column;
  padding: 0.7rem 1rem;
  gap: 0.55rem;
}
.pt-wp-card__title {
  font-size: 1rem;
  font-weight: 600;
  line-height: 1.3;
  margin: 0;
}
.pt-wp-card__title-link {
  color: oklch(15% 0 0);
  text-decoration: none;
  transition: color 120ms ease;
}
.pt-wp-card__title-link:hover {
  color: var(--color-brand);
}
.pt-wp-card__title-link mark, .pt-wp-card__title-link .ais-Highlight-highlighted {
  background: oklch(94% 0.13 90);
  color: inherit;
  padding: 0 0.1em;
  border-radius: 0.15em;
}
.pt-wp-card__location {
  display: inline-flex;
  align-items: center;
  gap: 0.3rem;
  margin: 0;
  font-size: 0.8125rem;
  color: oklch(45% 0 0);
}
.pt-wp-card__location svg {
  width: 0.875rem;
  height: 0.875rem;
  flex-shrink: 0;
}
.pt-wp-card__meta {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  gap: 1rem;
  margin-top: auto;
}
.pt-wp-card__meta-col {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 0.35rem;
  min-width: 0;
}
.pt-wp-card__meta-col--right {
  flex-direction: row;
  flex-wrap: wrap;
  justify-content: flex-end;
  align-items: center;
  text-align: right;
  flex-shrink: 0;
  gap: 0.5rem;
}
.pt-wp-card__date {
  display: inline-flex;
  align-items: center;
  gap: 0.25rem;
  font-size: 0.75rem;
  color: oklch(50% 0 0);
}
.pt-wp-card__date svg {
  width: 0.875rem;
  height: 0.875rem;
}
.pt-wp-card__stats-link {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  padding: 0.3rem 0.65rem;
  border-radius: var(--radius-full);
  border: 1px solid oklch(90% 0 0);
  background: oklch(98.5% 0 0);
  font-size: 0.75rem;
  color: oklch(35% 0 0);
  text-decoration: none;
  line-height: 1;
  transition: border-color 120ms ease, background-color 120ms ease, color 120ms ease;
}
.pt-wp-card__stats-link:hover, .pt-wp-card__stats-link:focus-visible {
  border-color: var(--color-brand);
  background: oklch(97% 0.04 250);
  color: var(--color-brand);
}
.pt-wp-card__stats-link:hover .pt-wp-card__stats-label, .pt-wp-card__stats-link:focus-visible .pt-wp-card__stats-label {
  color: var(--color-brand);
}
.pt-wp-card__stats-link svg {
  width: 0.875rem;
  height: 0.875rem;
  color: var(--color-brand);
  flex-shrink: 0;
  transition: color 120ms ease;
}
.pt-wp-card__stats-link--issues svg {
  color: oklch(55% 0.15 25);
}
.pt-wp-card__stats-link--issues:hover, .pt-wp-card__stats-link--issues:focus-visible {
  border-color: oklch(60% 0.15 25);
  background: oklch(97% 0.04 25);
  color: oklch(40% 0.16 25);
}
.pt-wp-card__stats-link--issues:hover .pt-wp-card__stats-label, .pt-wp-card__stats-link--issues:focus-visible .pt-wp-card__stats-label {
  color: oklch(40% 0.16 25);
}
.pt-wp-card__stats-link--issues:hover svg, .pt-wp-card__stats-link--issues:focus-visible svg {
  color: oklch(45% 0.16 25);
}
.pt-wp-card__stats-label {
  font-weight: 600;
  color: oklch(35% 0 0);
  transition: color 120ms ease;
}
.pt-wp-card__stats-label::after {
  content: ":";
  margin-right: 0.15rem;
}
.pt-wp-card__stats-counts {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  flex-wrap: wrap;
}
.pt-wp-card__stat-count {
  display: inline-flex;
  align-items: baseline;
  gap: 0.2rem;
  font-size: 0.75rem;
  color: oklch(35% 0 0);
  line-height: 1.1;
}
.pt-wp-card__stat-count__value {
  font-weight: 700;
}
.pt-wp-card__stat-count__label {
  color: oklch(50% 0 0);
}
.pt-wp-card__stat-count--success .pt-wp-card__stat-count__value {
  color: var(--color-success);
}
.pt-wp-card__stat-count--warning .pt-wp-card__stat-count__value {
  color: var(--color-warning-hover);
}
.pt-wp-card__stat-count--error .pt-wp-card__stat-count__value {
  color: var(--color-danger);
}
.pt-wp-card__stat-count--info .pt-wp-card__stat-count__value {
  color: var(--color-info);
}
.pt-wp-card__stat-count--neutral .pt-wp-card__stat-count__value {
  color: oklch(45% 0 0);
}
.pt-wp-card__stat-count--purple .pt-wp-card__stat-count__value {
  color: oklch(48% 0.18 305);
}
.pt-status-badge {
  display: inline-flex;
  align-items: center;
  padding: 0.25em 0.7em;
  border-radius: var(--radius-full);
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  line-height: 1.3;
  color: var(--color-on-success, oklch(98% 0 0));
}
.pt-status-badge--success {
  background: var(--color-success);
}
.pt-status-badge--warning {
  background: var(--color-warning);
}
.pt-status-badge--error {
  background: var(--color-danger);
}
.pt-status-badge--info {
  background: var(--color-info);
}
.pt-status-badge--neutral {
  background: oklch(55% 0 0);
}
.pt-status-badge--purple {
  background: oklch(48% 0.18 305);
}
.pt-wp-card__location[data-tooltip], .pt-status-badge[data-tooltip], .pt-wp-card__date[data-tooltip], .pt-wp-card__stats-link[data-tooltip] {
  position: relative;
}
.pt-wp-card__location[data-tooltip]::after, .pt-status-badge[data-tooltip]::after, .pt-wp-card__date[data-tooltip]::after, .pt-wp-card__stats-link[data-tooltip]::after {
  content: attr(data-tooltip);
  position: absolute;
  bottom: calc(100% + 0.4rem);
  left: 50%;
  transform: translateX(-50%) translateY(4px);
  padding: 0.32rem 0.6rem;
  background-color: #181818;
  background-image: none;
  color: #ffffff;
  text-shadow: none;
  filter: none;
  font-size: 0.7rem;
  font-weight: 600;
  line-height: 1;
  letter-spacing: 0.01em;
  border-radius: 0.25rem;
  white-space: nowrap;
  opacity: 0;
  pointer-events: none;
  transition: opacity 140ms ease-out, transform 140ms ease-out;
  z-index: 10;
}
.pt-wp-card__location[data-tooltip]:hover::after, .pt-status-badge[data-tooltip]:hover::after, .pt-wp-card__date[data-tooltip]:hover::after, .pt-wp-card__stats-link[data-tooltip]:hover::after, .pt-wp-card__location[data-tooltip]:focus-visible::after, .pt-status-badge[data-tooltip]:focus-visible::after, .pt-wp-card__date[data-tooltip]:focus-visible::after, .pt-wp-card__stats-link[data-tooltip]:focus-visible::after {
  opacity: 1;
  transform: translateX(-50%) translateY(0);
}
.pt-wp-table__group-header .ag-header-group-cell-label {
  align-items: center;
  justify-content: center;
  color: oklch(27% 0 0);
  font-size: 0.72rem;
  font-weight: 750;
  letter-spacing: 0.08em;
  text-align: center;
  text-transform: uppercase;
}
.pt-wp-table__sub-header .ag-header-cell-label {
  justify-content: center;
  color: oklch(30% 0 0);
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  text-align: center;
}
.pt-wp-project-directory .ag-header-cell-label {
  justify-content: center;
  text-align: center;
}
.pt-wp-table__cell {
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  color: oklch(20% 0 0);
  font-size: 0.835rem;
  line-height: 1.35;
  white-space: normal;
  overflow-wrap: anywhere;
  padding-top: 0.5rem;
  padding-bottom: 0.5rem;
}
.pt-wp-table__cell--name {
  font-weight: 650;
}
.pt-wp-table__cell--status-update {
  padding-top: 0.6rem;
  padding-bottom: 0.6rem;
}
.pt-wp-table__status-update {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.05rem;
  line-height: 1.25;
}
.pt-wp-table__status-update-label {
  color: oklch(40% 0 0);
  font-size: 0.78rem;
}
.pt-wp-table__status-update-date {
  font-weight: 600;
  color: oklch(20% 0 0);
}
.pt-wp-table__cell--breakdown {
  padding-top: 0.6rem;
  padding-bottom: 0.6rem;
}
.pt-wp-table__logo {
  width: 32px;
  height: 32px;
  border-radius: 0.25rem;
  overflow: hidden;
  background: oklch(96% 0 0);
  display: flex;
  align-items: center;
  justify-content: center;
}
.pt-wp-table__logo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.pt-wp-table__logo--placeholder {
  font-weight: 700;
  color: oklch(55% 0 0);
}
.pt-wp-table__project {
  min-width: 0;
  white-space: normal;
  overflow-wrap: anywhere;
  line-height: 1.3;
}
.pt-wp-table__project-link {
  color: oklch(15% 0 0);
  text-decoration: none;
  font-weight: 600;
  transition: color 120ms ease;
}
.pt-wp-table__project-link:hover, .pt-wp-table__project-link:focus-visible {
  color: var(--color-brand);
}
.pt-wp-table__chip-more {
  color: oklch(55% 0 0);
  font-weight: 500;
  margin-left: 0.15rem;
}
.pt-wp-table__version-link {
  color: var(--color-brand);
  text-decoration: none;
  font-weight: 600;
}
.pt-wp-table__version-link:hover, .pt-wp-table__version-link:focus-visible {
  text-decoration: underline;
}
.pt-wp-table__breakdown {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.18rem;
  padding: 0.1rem 0;
  line-height: 1.3;
}
.pt-wp-table__breakdown-row {
  display: inline-flex;
  align-items: baseline;
  gap: 0.25rem;
  font-size: 0.8rem;
  color: oklch(25% 0 0);
}
.pt-wp-table__breakdown-row--link {
  color: inherit;
  text-decoration: none;
  transition: color 120ms ease;
}
.pt-wp-table__breakdown-row--link:hover, .pt-wp-table__breakdown-row--link:focus-visible {
  color: var(--color-brand);
}
.pt-wp-table__breakdown-value {
  font-weight: 700;
  font-variant-numeric: tabular-nums;
}
.pt-wp-table__breakdown-row--success .pt-wp-table__breakdown-value {
  color: var(--color-success);
}
.pt-wp-table__breakdown-row--warning .pt-wp-table__breakdown-value {
  color: var(--color-warning-hover);
}
.pt-wp-table__breakdown-row--error .pt-wp-table__breakdown-value {
  color: var(--color-danger);
}
.pt-wp-table__breakdown-row--info .pt-wp-table__breakdown-value {
  color: var(--color-info);
}
.pt-wp-table__breakdown-row--purple .pt-wp-table__breakdown-value {
  color: oklch(48% 0.18 305);
}
@media (max-width: 880px) {
  .pt-wp-card__meta {
    flex-direction: column;
    align-items: stretch;
    gap: 0.5rem;
  }
  .pt-wp-card__meta-col--right {
    justify-content: flex-start;
    align-items: center;
    text-align: left;
  }
}
@media (max-width: 640px) {
  .pt-wp-card {
    flex-direction: column;
  }
  .pt-wp-card__media-link {
    flex: 0 0 auto;
    max-width: 100%;
    aspect-ratio: 16 / 9;
  }
  .pt-wp-card__content {
    padding: 0.85rem 1rem;
  }
}
.pt-vendor-registrations-directory {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}
.pt-vendor-registrations-directory__cta {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  justify-content: center;
}
.pt-vendor-registrations-directory .pt-directory-controls {
  gap: 0.5rem;
}
.pt-vendor-registrations-directory.pt-directory-has-no-active-refinements .pt-directory-controls__filters {
  display: none;
}
.pt-vendor-registrations-directory.pt-directory-has-active-refinements .pt-directory-controls__filters {
  display: block;
}
.pt-vendor-registrations-directory .pt-directory-controls__top {
  margin-bottom: 0;
}
.pt-vendor-registrations-directory .pt-directory-refinements {
  margin-top: 0.5rem;
}
.pt-vendor-registrations-directory .pt-ag-grid-container {
  height: calc(100vh - 18rem);
  min-height: 34rem;
  width: 100%;
}
.pt-vendor-registrations-directory .ag-root-wrapper {
  border-radius: 0.75rem;
}
.pt-vendor-registrations-directory .ag-header-cell-label, .pt-vendor-registrations-directory .ag-header-group-cell-label {
  align-items: center;
}
.pt-vendor-registration-date-range .pt-date-range__inputs {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  gap: 0.5rem;
  align-items: center;
}
.pt-vendor-registration-date-range .pt-date-range__separator {
  display: none;
}
.pt-vendor-registration-date-range input {
  min-width: 0;
  width: 100%;
}
.pt-vendor-registration-status-filter__label {
  display: inline-flex;
  align-items: center;
  width: 100%;
  gap: 0.5rem;
}
.pt-vendor-registration-status-filter__badge {
  min-height: 1.5rem;
  padding: 0.2rem 0.55rem;
  font-size: 0.69rem;
  line-height: 1;
  pointer-events: none;
}
.pt-vendor-registration-status-filter__count {
  margin-left: auto;
}
.pt-vendor-registration-table__group-header {
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: oklch(35% 0.02 255);
}
.pt-vendor-registration-table__sub-header {
  font-size: 0.76rem;
  font-weight: 700;
  color: oklch(25% 0.02 255);
}
.pt-vendor-registration-table__cell {
  display: flex;
  align-items: center;
  min-width: 0;
  font-size: 0.82rem;
}
.pt-vendor-registration-table__cell--number {
  font-weight: 700;
}
.pt-vendor-registration-table__cell--company {
  font-weight: 700;
}
.pt-vendor-registration-table__cell--status {
  justify-content: flex-start;
}
.pt-vendor-registration-table__cell--date {
  white-space: nowrap;
}
.pt-vendor-registration-table-company, .pt-vendor-registration-table-number, .pt-vendor-registration-table-type {
  min-width: 0;
  max-width: 100%;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.pt-vendor-registration-table-company__name {
  display: block;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.pt-vendor-registrations-directory .ais-RefinementList-showMore {
  display: none;
}
@media (max-height: 820px) {
  .pt-vendor-registrations-directory .pt-ag-grid-container {
    height: calc(100vh - 15.5rem);
    min-height: 28rem;
  }
  .pt-vendor-registration-table__cell {
    font-size: 0.78rem;
  }
}
@media (max-width: 1280px) {
  .pt-vendor-registration-date-range .pt-date-range__inputs {
    grid-template-columns: 1fr;
  }
}
.pt-status-badge {
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  padding: 0.22rem 0.65em;
  color: #fff;
  border-radius: var(--radius-full, 999px);
  white-space: nowrap;
}
.pt-status-badge--success {
  background: #22b68e;
  color: #fff;
}
.pt-status-badge--warning {
  background: #fe9038;
  color: #fff;
}
.pt-status-badge--error {
  background: #ee5b4e;
  color: #fff;
}
.pt-status-badge--info {
  background: #3196d1;
  color: #fff;
}
.pt-status-badge--neutral {
  background: #647079;
  color: #fff;
}
.pt-status-badge--on-hold {
  background: #795f9c;
  color: #fff;
}
.pt-status-badge--posted {
  background: #305f82;
  color: #fff;
}
.pt-tender-list {
  display: flex;
  flex-direction: column;
  gap: 0.625rem;
  list-style: none;
  padding: 0;
  margin: 0;
}
.pt-tender-list__item {
  list-style: none;
  display: flex;
  width: 100%;
}
.pt-tender-list__item > .pt-tender-card {
  flex: 1 1 auto;
  width: 100%;
}
.pt-wp-hits--list {
  min-height: 200px;
}
.pt-wp-hits--list.pt-wp-hits--empty {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 300px;
}
[data-workplace-tender-search-target="state"] .ais-RefinementList-item {
  height: auto;
  min-height: 0;
  padding: 0.1rem 0;
}
.pt-state-filter-item .pt-refinement-list__count {
  margin-left: auto;
}
.pt-state-filter-item .pt-status-badge {
  font-size: 0.65rem;
  font-weight: 500;
  letter-spacing: 0.05em;
}
.pt-range-input__form {
  display: flex;
  align-items: center;
  gap: 0.375rem;
  width: 100%;
}
.pt-range-input__input {
  flex: 1 1 0;
  min-width: 0;
  padding: 0.25rem 0.5rem;
  border: 1px solid oklch(82% 0 0);
  border-radius: 0.375rem;
  font-size: 0.8125rem;
  color: oklch(20% 0 0);
  background: white;
  &:focus {
    outline: 2px solid var(--color-brand, oklch(45% 0.18 250));
    outline-offset: -1px;
    border-color: transparent;
  }
}
.pt-range-input__separator {
  font-size: 0.8125rem;
  color: oklch(60% 0 0);
  flex-shrink: 0;
}
.pt-range-input__submit {
  padding: 0.25rem 0.5rem;
  border: 1px solid oklch(82% 0 0);
  border-radius: 0.375rem;
  background: oklch(97% 0 0);
  cursor: pointer;
  flex-shrink: 0;
  font-size: 0;
  width: 1.75rem;
  height: 1.75rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke-width='1.8' stroke='%23647079'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' d='M21 21l-5.197-5.197m0 0A7.5 7.5 0 1 0 5.196 5.196a7.5 7.5 0 0 0 10.607 10.607z'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: center;
  background-size: 0.875rem;
  &:hover {
    background-color: oklch(94% 0 0);
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke-width='1.8' stroke='%23374151'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' d='M21 21l-5.197-5.197m0 0A7.5 7.5 0 1 0 5.196 5.196a7.5 7.5 0 0 0 10.607 10.607z'/%3E%3C/svg%3E");
  }
}
.pt-filter-date-range .pt-date-range:not(:has(.pt-date-range__subtitle)) .pt-date-range__separator {
  padding-top: 0;
  font-size: 0.5rem;
}
.pt-filter-date-range .pt-date-picker__icon {
  display: none;
}
.pt-filter-date-range .pt-date-picker--sm .pt-date-picker__input {
  padding-left: 0.375rem;
  padding-right: 1.375rem;
}
.pt-filter-date-range .pt-date-picker__placeholder {
  left: 0.375rem;
}
.pt-workplace-tenders .pt-ag-grid-container {
  --ag-cell-horizontal-padding: 0.4375rem;
  --ag-font-size: 0.78125rem;
}
.pt-workplace-tenders .pt-ag-grid-container .pt-status-badge {
  font-size: 0.5625rem;
  font-weight: 500;
  padding: 0.1rem 0.35em;
  letter-spacing: 0.04em;
  border-radius: 0.25rem;
}
.pt-tender-table__group-header .ag-header-group-cell-label {
  font-size: 0.6875rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: oklch(45% 0 0);
  padding-left: 0.25rem;
}
.pt-tender-table__sub-header .ag-header-cell-label {
  font-size: 0.6875rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: oklch(38% 0 0);
  justify-content: flex-start;
}
.pt-tender-table__cell {
  display: flex;
  align-items: center;
  font-size: 0.8125rem;
  color: oklch(20% 0 0);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.pt-tender-table__cell--name {
  font-weight: 500;
  overflow: visible;
}
.pt-tender-table__cell--numeric {
  justify-content: flex-end;
  font-variant-numeric: tabular-nums;
}
.pt-tender-table-name {
  display: flex;
  align-items: center;
  min-width: 0;
  overflow: hidden;
}
.pt-tender-table-name__link {
  color: oklch(25% 0 0);
  font-weight: 500;
  text-decoration: none;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  &:hover {
    color: oklch(45% 0.18 250);
    text-decoration: underline;
  }
}
.pt-tender-table-rfcs--open {
  color: #ee5b4e;
  font-weight: 600;
}
.pt-tender-table__bids-received--positive {
  color: #22b68e;
  font-weight: 600;
}
.pt-tender-table-bids-summary {
  font-variant-numeric: tabular-nums;
}
.pt-tender-table-bids-summary__count--complete {
  color: #22b68e;
  font-weight: 600;
}
.pt-tender-table-bids-summary__count--incomplete {
  color: #ee5b4e;
  font-weight: 600;
}
.pt-workplace-tenders.pt-directory-has-no-active-refinements .pt-directory-controls__filters {
  display: none;
}
.pt-create-tender {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}
.pt-create-tender__options {
  display: flex;
  flex-direction: column;
  gap: 0.625rem;
}
#ct-existing-fields {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}
.pt-field {
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
}
.pt-btn[aria-disabled="true"] {
  opacity: 0.45;
  pointer-events: none;
  cursor: not-allowed;
}
@layer base {
  input:where([type='text']),input:where(:not([type])),input:where([type='email']),input:where([type='url']),input:where([type='password']),input:where([type='number']),input:where([type='date']),input:where([type='datetime-local']),input:where([type='month']),input:where([type='search']),input:where([type='tel']),input:where([type='time']),input:where([type='week']),select:where([multiple]),textarea,select {
    appearance: none;
    background-color: #fff;
    border-color: oklch(55.1% 0.027 264.364);
    border-width: 1px;
    border-radius: 0px;
    padding-top: 0.5rem;
    padding-right: 0.75rem;
    padding-bottom: 0.5rem;
    padding-left: 0.75rem;
    font-size: 1rem;
    line-height: 1.5rem;
    --tw-shadow: 0 0 #0000;
    &:focus {
      outline: 2px solid transparent;
      outline-offset: 2px;
      --tw-ring-inset: var(--tw-empty,/*!*/ /*!*/);
      --tw-ring-offset-width: 0px;
      --tw-ring-offset-color: #fff;
      --tw-ring-color: oklch(54.6% 0.245 262.881);
      --tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);
      --tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(1px + var(--tw-ring-offset-width)) var(--tw-ring-color);
      box-shadow: var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
      border-color: oklch(54.6% 0.245 262.881);
    }
  }
  input::placeholder,textarea::placeholder {
    color: oklch(55.1% 0.027 264.364);
    opacity: 1;
  }
  ::-webkit-datetime-edit-fields-wrapper {
    padding: 0;
  }
  ::-webkit-date-and-time-value {
    min-height: 1.5em;
  }
  ::-webkit-date-and-time-value {
    text-align: inherit;
  }
  ::-webkit-datetime-edit {
    display: inline-flex;
  }
  ::-webkit-datetime-edit,::-webkit-datetime-edit-year-field,::-webkit-datetime-edit-month-field,::-webkit-datetime-edit-day-field,::-webkit-datetime-edit-hour-field,::-webkit-datetime-edit-minute-field,::-webkit-datetime-edit-second-field,::-webkit-datetime-edit-millisecond-field,::-webkit-datetime-edit-meridiem-field {
    padding-top: 0;
    padding-bottom: 0;
  }
  select {
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3e%3cpath stroke='oklch(55.1%25 0.027 264.364)' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M6 8l4 4 4-4'/%3e%3c/svg%3e");
    background-position: right 0.5rem center;
    background-repeat: no-repeat;
    background-size: 1.5em 1.5em;
    padding-right: 2.5rem;
    print-color-adjust: exact;
  }
  select:where([multiple]),select:where([size]:not([size="1"])) {
    background-image: initial;
    background-position: initial;
    background-repeat: unset;
    background-size: initial;
    padding-right: 0.75rem;
    print-color-adjust: unset;
  }
  input:where([type='checkbox']),input:where([type='radio']) {
    appearance: none;
    padding: 0;
    print-color-adjust: exact;
    display: inline-block;
    vertical-align: middle;
    background-origin: border-box;
    user-select: none;
    flex-shrink: 0;
    height: 1rem;
    width: 1rem;
    color: oklch(54.6% 0.245 262.881);
    background-color: #fff;
    border-color: oklch(55.1% 0.027 264.364);
    border-width: 1px;
    --tw-shadow: 0 0 #0000;
  }
  input:where([type='checkbox']) {
    border-radius: 0px;
  }
  input:where([type='radio']) {
    border-radius: 100%;
  }
  input:where([type='checkbox']):focus,input:where([type='radio']):focus {
    outline: 2px solid transparent;
    outline-offset: 2px;
    --tw-ring-inset: var(--tw-empty,/*!*/ /*!*/);
    --tw-ring-offset-width: 2px;
    --tw-ring-offset-color: #fff;
    --tw-ring-color: oklch(54.6% 0.245 262.881);
    --tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);
    --tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);
    box-shadow: var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
  }
  input:where([type='checkbox']):checked,input:where([type='radio']):checked {
    border-color: transparent;
    background-color: currentColor;
    background-size: 100% 100%;
    background-position: center;
    background-repeat: no-repeat;
  }
  input:where([type='checkbox']):checked {
    background-image: url("data:image/svg+xml,%3csvg viewBox='0 0 16 16' fill='white' xmlns='http://www.w3.org/2000/svg'%3e%3cpath d='M12.207 4.793a1 1 0 010 1.414l-5 5a1 1 0 01-1.414 0l-2-2a1 1 0 011.414-1.414L6.5 9.086l4.293-4.293a1 1 0 011.414 0z'/%3e%3c/svg%3e");
    @media (forced-colors: active) {
      appearance: auto;
    }
  }
  input:where([type='radio']):checked {
    background-image: url("data:image/svg+xml,%3csvg viewBox='0 0 16 16' fill='white' xmlns='http://www.w3.org/2000/svg'%3e%3ccircle cx='8' cy='8' r='3'/%3e%3c/svg%3e");
    @media (forced-colors: active) {
      appearance: auto;
    }
  }
  input:where([type='checkbox']):checked:hover,input:where([type='checkbox']):checked:focus,input:where([type='radio']):checked:hover,input:where([type='radio']):checked:focus {
    border-color: transparent;
    background-color: currentColor;
  }
  input:where([type='checkbox']):indeterminate {
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 16 16'%3e%3cpath stroke='white' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M4 8h8'/%3e%3c/svg%3e");
    border-color: transparent;
    background-color: currentColor;
    background-size: 100% 100%;
    background-position: center;
    background-repeat: no-repeat;
    @media (forced-colors: active) {
      appearance: auto;
    }
  }
  input:where([type='checkbox']):indeterminate:hover,input:where([type='checkbox']):indeterminate:focus {
    border-color: transparent;
    background-color: currentColor;
  }
  input:where([type='file']) {
    background: unset;
    border-color: inherit;
    border-width: 0;
    border-radius: 0;
    padding: 0;
    font-size: unset;
    line-height: inherit;
  }
  input:where([type='file']):focus {
    outline: 1px solid ButtonText;
    outline: 1px auto -webkit-focus-ring-color;
  }
}
@property --tw-rotate-x {
  syntax: "*";
  inherits: false;
}
@property --tw-rotate-y {
  syntax: "*";
  inherits: false;
}
@property --tw-rotate-z {
  syntax: "*";
  inherits: false;
}
@property --tw-skew-x {
  syntax: "*";
  inherits: false;
}
@property --tw-skew-y {
  syntax: "*";
  inherits: false;
}
@property --tw-space-y-reverse {
  syntax: "*";
  inherits: false;
  initial-value: 0;
}
@property --tw-divide-y-reverse {
  syntax: "*";
  inherits: false;
  initial-value: 0;
}
@property --tw-border-style {
  syntax: "*";
  inherits: false;
  initial-value: solid;
}
@property --tw-gradient-position {
  syntax: "*";
  inherits: false;
}
@property --tw-gradient-from {
  syntax: "<color>";
  inherits: false;
  initial-value: #0000;
}
@property --tw-gradient-via {
  syntax: "<color>";
  inherits: false;
  initial-value: #0000;
}
@property --tw-gradient-to {
  syntax: "<color>";
  inherits: false;
  initial-value: #0000;
}
@property --tw-gradient-stops {
  syntax: "*";
  inherits: false;
}
@property --tw-gradient-via-stops {
  syntax: "*";
  inherits: false;
}
@property --tw-gradient-from-position {
  syntax: "<length-percentage>";
  inherits: false;
  initial-value: 0%;
}
@property --tw-gradient-via-position {
  syntax: "<length-percentage>";
  inherits: false;
  initial-value: 50%;
}
@property --tw-gradient-to-position {
  syntax: "<length-percentage>";
  inherits: false;
  initial-value: 100%;
}
@property --tw-leading {
  syntax: "*";
  inherits: false;
}
@property --tw-font-weight {
  syntax: "*";
  inherits: false;
}
@property --tw-tracking {
  syntax: "*";
  inherits: false;
}
@property --tw-ordinal {
  syntax: "*";
  inherits: false;
}
@property --tw-slashed-zero {
  syntax: "*";
  inherits: false;
}
@property --tw-numeric-figure {
  syntax: "*";
  inherits: false;
}
@property --tw-numeric-spacing {
  syntax: "*";
  inherits: false;
}
@property --tw-numeric-fraction {
  syntax: "*";
  inherits: false;
}
@property --tw-shadow {
  syntax: "*";
  inherits: false;
  initial-value: 0 0 #0000;
}
@property --tw-shadow-color {
  syntax: "*";
  inherits: false;
}
@property --tw-shadow-alpha {
  syntax: "<percentage>";
  inherits: false;
  initial-value: 100%;
}
@property --tw-inset-shadow {
  syntax: "*";
  inherits: false;
  initial-value: 0 0 #0000;
}
@property --tw-inset-shadow-color {
  syntax: "*";
  inherits: false;
}
@property --tw-inset-shadow-alpha {
  syntax: "<percentage>";
  inherits: false;
  initial-value: 100%;
}
@property --tw-ring-color {
  syntax: "*";
  inherits: false;
}
@property --tw-ring-shadow {
  syntax: "*";
  inherits: false;
  initial-value: 0 0 #0000;
}
@property --tw-inset-ring-color {
  syntax: "*";
  inherits: false;
}
@property --tw-inset-ring-shadow {
  syntax: "*";
  inherits: false;
  initial-value: 0 0 #0000;
}
@property --tw-ring-inset {
  syntax: "*";
  inherits: false;
}
@property --tw-ring-offset-width {
  syntax: "<length>";
  inherits: false;
  initial-value: 0px;
}
@property --tw-ring-offset-color {
  syntax: "*";
  inherits: false;
  initial-value: #fff;
}
@property --tw-ring-offset-shadow {
  syntax: "*";
  inherits: false;
  initial-value: 0 0 #0000;
}
@property --tw-outline-style {
  syntax: "*";
  inherits: false;
  initial-value: solid;
}
@property --tw-blur {
  syntax: "*";
  inherits: false;
}
@property --tw-brightness {
  syntax: "*";
  inherits: false;
}
@property --tw-contrast {
  syntax: "*";
  inherits: false;
}
@property --tw-grayscale {
  syntax: "*";
  inherits: false;
}
@property --tw-hue-rotate {
  syntax: "*";
  inherits: false;
}
@property --tw-invert {
  syntax: "*";
  inherits: false;
}
@property --tw-opacity {
  syntax: "*";
  inherits: false;
}
@property --tw-saturate {
  syntax: "*";
  inherits: false;
}
@property --tw-sepia {
  syntax: "*";
  inherits: false;
}
@property --tw-drop-shadow {
  syntax: "*";
  inherits: false;
}
@property --tw-drop-shadow-color {
  syntax: "*";
  inherits: false;
}
@property --tw-drop-shadow-alpha {
  syntax: "<percentage>";
  inherits: false;
  initial-value: 100%;
}
@property --tw-drop-shadow-size {
  syntax: "*";
  inherits: false;
}
@property --tw-backdrop-blur {
  syntax: "*";
  inherits: false;
}
@property --tw-backdrop-brightness {
  syntax: "*";
  inherits: false;
}
@property --tw-backdrop-contrast {
  syntax: "*";
  inherits: false;
}
@property --tw-backdrop-grayscale {
  syntax: "*";
  inherits: false;
}
@property --tw-backdrop-hue-rotate {
  syntax: "*";
  inherits: false;
}
@property --tw-backdrop-invert {
  syntax: "*";
  inherits: false;
}
@property --tw-backdrop-opacity {
  syntax: "*";
  inherits: false;
}
@property --tw-backdrop-saturate {
  syntax: "*";
  inherits: false;
}
@property --tw-backdrop-sepia {
  syntax: "*";
  inherits: false;
}
@property --tw-duration {
  syntax: "*";
  inherits: false;
}
@property --tw-ease {
  syntax: "*";
  inherits: false;
}
@property --tw-translate-x {
  syntax: "*";
  inherits: false;
  initial-value: 0;
}
@property --tw-translate-y {
  syntax: "*";
  inherits: false;
  initial-value: 0;
}
@property --tw-translate-z {
  syntax: "*";
  inherits: false;
  initial-value: 0;
}
@property --tw-scale-x {
  syntax: "*";
  inherits: false;
  initial-value: 1;
}
@property --tw-scale-y {
  syntax: "*";
  inherits: false;
  initial-value: 1;
}
@property --tw-scale-z {
  syntax: "*";
  inherits: false;
  initial-value: 1;
}
@keyframes spin {
  to {
    transform: rotate(360deg);
  }
}
@keyframes ping {
  75%, 100% {
    transform: scale(2);
    opacity: 0;
  }
}
@keyframes pulse {
  50% {
    opacity: 0.5;
  }
}
@keyframes bounce {
  0%, 100% {
    transform: translateY(-25%);
    animation-timing-function: cubic-bezier(0.8, 0, 1, 1);
  }
  50% {
    transform: none;
    animation-timing-function: cubic-bezier(0, 0, 0.2, 1);
  }
}
@layer properties {
  @supports ((-webkit-hyphens: none) and (not (margin-trim: inline))) or ((-moz-orient: inline) and (not (color:rgb(from red r g b)))) {
    *, ::before, ::after, ::backdrop {
      --tw-rotate-x: initial;
      --tw-rotate-y: initial;
      --tw-rotate-z: initial;
      --tw-skew-x: initial;
      --tw-skew-y: initial;
      --tw-space-y-reverse: 0;
      --tw-divide-y-reverse: 0;
      --tw-border-style: solid;
      --tw-gradient-position: initial;
      --tw-gradient-from: #0000;
      --tw-gradient-via: #0000;
      --tw-gradient-to: #0000;
      --tw-gradient-stops: initial;
      --tw-gradient-via-stops: initial;
      --tw-gradient-from-position: 0%;
      --tw-gradient-via-position: 50%;
      --tw-gradient-to-position: 100%;
      --tw-leading: initial;
      --tw-font-weight: initial;
      --tw-tracking: initial;
      --tw-ordinal: initial;
      --tw-slashed-zero: initial;
      --tw-numeric-figure: initial;
      --tw-numeric-spacing: initial;
      --tw-numeric-fraction: initial;
      --tw-shadow: 0 0 #0000;
      --tw-shadow-color: initial;
      --tw-shadow-alpha: 100%;
      --tw-inset-shadow: 0 0 #0000;
      --tw-inset-shadow-color: initial;
      --tw-inset-shadow-alpha: 100%;
      --tw-ring-color: initial;
      --tw-ring-shadow: 0 0 #0000;
      --tw-inset-ring-color: initial;
      --tw-inset-ring-shadow: 0 0 #0000;
      --tw-ring-inset: initial;
      --tw-ring-offset-width: 0px;
      --tw-ring-offset-color: #fff;
      --tw-ring-offset-shadow: 0 0 #0000;
      --tw-outline-style: solid;
      --tw-blur: initial;
      --tw-brightness: initial;
      --tw-contrast: initial;
      --tw-grayscale: initial;
      --tw-hue-rotate: initial;
      --tw-invert: initial;
      --tw-opacity: initial;
      --tw-saturate: initial;
      --tw-sepia: initial;
      --tw-drop-shadow: initial;
      --tw-drop-shadow-color: initial;
      --tw-drop-shadow-alpha: 100%;
      --tw-drop-shadow-size: initial;
      --tw-backdrop-blur: initial;
      --tw-backdrop-brightness: initial;
      --tw-backdrop-contrast: initial;
      --tw-backdrop-grayscale: initial;
      --tw-backdrop-hue-rotate: initial;
      --tw-backdrop-invert: initial;
      --tw-backdrop-opacity: initial;
      --tw-backdrop-saturate: initial;
      --tw-backdrop-sepia: initial;
      --tw-duration: initial;
      --tw-ease: initial;
      --tw-translate-x: 0;
      --tw-translate-y: 0;
      --tw-translate-z: 0;
      --tw-scale-x: 1;
      --tw-scale-y: 1;
      --tw-scale-z: 1;
    }
  }
}
