/* [project]/apps/web/src/app/globals.css [app-client] (css) */
@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-translate-x: 0;
      --tw-translate-y: 0;
      --tw-translate-z: 0;
      --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-space-x-reverse: 0;
      --tw-divide-y-reverse: 0;
      --tw-border-style: solid;
      --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-ease: initial;
    }
  }
}

@layer theme {
  :root, :host {
    --font-sans: "Inter", system-ui, -apple-system, sans-serif;
    --font-mono: "JetBrains Mono", ui-monospace, monospace;
    --color-red-50: #fef2f2;
    --color-red-100: #ffe2e2;
    --color-red-200: #ffcaca;
    --color-red-300: #ffa3a3;
    --color-red-500: #fb2c36;
    --color-red-600: #e40014;
    --color-red-700: #bf000f;
    --color-red-800: #9f0712;
    --color-red-900: #82181a;
    --color-amber-50: #fffbeb;
    --color-amber-200: #fee685;
    --color-amber-300: #ffd236;
    --color-amber-800: #953d00;
    --color-amber-900: #7b3306;
    --color-green-50: #f0fdf4;
    --color-green-100: #dcfce7;
    --color-green-200: #b9f8cf;
    --color-green-300: #7bf1a8;
    --color-green-500: #00c758;
    --color-green-600: #00a544;
    --color-green-700: #008138;
    --color-green-800: #016630;
    --color-green-900: #0d542b;
    --color-emerald-100: #d0fae5;
    --color-emerald-600: #009767;
    --color-emerald-800: #005f46;
    --color-blue-50: #eff6ff;
    --color-blue-100: #dbeafe;
    --color-blue-200: #bedbff;
    --color-blue-500: #3080ff;
    --color-blue-600: #155dfc;
    --color-blue-700: #1447e6;
    --color-gray-50: #f9fafb;
    --color-gray-100: #f3f4f6;
    --color-gray-300: #d1d5dc;
    --color-gray-400: #99a1af;
    --color-gray-500: #6a7282;
    --color-gray-600: #4a5565;
    --color-gray-700: #364153;
    --color-zinc-100: #f4f4f5;
    --color-zinc-500: #71717b;
    --color-zinc-950: #09090b;
    --color-black: #000;
    --color-white: #fff;
    --spacing: .25rem;
    --container-xs: 20rem;
    --container-md: 28rem;
    --container-lg: 32rem;
    --container-xl: 36rem;
    --container-2xl: 42rem;
    --container-3xl: 48rem;
    --container-4xl: 56rem;
    --container-5xl: 64rem;
    --container-6xl: 72rem;
    --text-xs: .75rem;
    --text-xs--line-height: calc(1 / .75);
    --text-sm: .875rem;
    --text-sm--line-height: calc(1.25 / .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);
    --font-weight-normal: 400;
    --font-weight-medium: 500;
    --font-weight-semibold: 600;
    --font-weight-bold: 700;
    --tracking-wide: .025em;
    --tracking-wider: .05em;
    --tracking-widest: .1em;
    --leading-tight: 1.25;
    --leading-snug: 1.375;
    --leading-relaxed: 1.625;
    --radius-md: .375rem;
    --radius-lg: .5rem;
    --radius-xl: .75rem;
    --ease-in: cubic-bezier(.4, 0, 1, 1);
    --ease-out: cubic-bezier(0, 0, .2, 1);
    --ease-in-out: cubic-bezier(.4, 0, .2, 1);
    --animate-spin: spin 1s linear infinite;
    --animate-pulse: pulse 2s cubic-bezier(.4, 0, .6, 1) infinite;
    --default-transition-duration: .15s;
    --default-transition-timing-function: cubic-bezier(.4, 0, .2, 1);
    --default-font-family: var(--font-sans);
    --default-mono-font-family: var(--font-mono);
    --color-horn-blue: #2a6fdb;
    --color-horn-blue-deep: #1f5bb5;
    --color-horn-blue-soft: #e7effa;
    --color-ai: #7c5cff;
    --color-ai-deep: #5a3fd6;
    --color-ai-soft: #f0ecff;
    --color-ink: #1c1a17;
    --color-ink-2: #3a3631;
    --color-ink-3: #6a645b;
    --color-ink-4: #9a9388;
    --color-paper: #f6f4ef;
    --color-paper-2: #efece5;
    --color-page-bg: #f0eee9;
    --canvas: #ebe9e3;
    --status-ok: #2f8a4d;
    --status-ok-soft: #e3f5ea;
    --status-warn: #c9a85c;
    --status-warn-soft: #fef3dd;
    --status-risk: #c45a3e;
    --status-risk-soft: #fee8e6;
    --status-info: #1e5cb0;
    --status-info-soft: #e6effa;
    --status-warn-deep: #8a5700;
    --status-risk-deep: #8a2a22;
    --brand-primary: #0080c8;
    --brand-primary-deep: #00618f;
    --brand-primary-soft: #e2f0f8;
    --ai: #6d5ae0;
    --ai-deep: #4b3bbf;
    --ai-soft: #efeafc;
    --ai-bright: #9a82ff;
    --ai-tint: #fbfaff;
    --ai-grad: linear-gradient(180deg, var(--ai-tint), var(--white));
    --r-lg: 12px;
    --r-md: 8px;
    --shadow-card: 0 2px 24px #0000001a;
    --shadow-pop: 0 8px 28px #00000029;
    --mono: "JetBrains Mono", monospace;
    --ink: var(--color-ink);
    --ink-2: var(--color-ink-2);
    --ink-3: var(--color-ink-3);
    --ink-4: var(--color-ink-4);
    --rule: var(--color-rule);
    --rule-soft: var(--color-rule-2);
    --paper: var(--color-paper);
    --paper-2: var(--color-paper-2);
    --white: var(--color-white);
    --r-sm: 6px;
    --status-muted: #5f6670;
    --status-muted-soft: #ececee;
    --label-slate: #5e7491;
    --label-slate-soft: #eaedf2;
    --label-violet: #6b50a0;
    --label-violet-soft: #ece8f5;
    --label-teal: #2d8a8f;
    --label-teal-soft: #e0eff0;
    --label-azure: #357fbf;
    --label-azure-soft: #e3eef8;
    --label-magenta: #b0517f;
    --label-magenta-soft: #f6e7ef;
    --label-bronze: #94703a;
    --label-bronze-soft: #f0ead9;
    --label-green: #3f8c63;
    --label-green-soft: #e3f1ea;
    --label-plum: #8a4f9e;
    --label-plum-soft: #f1e8f5;
    --label-coral: #c4674f;
    --label-coral-soft: #f7e9e3;
    --label-gray: #7c8088;
    --label-gray-soft: #ededee;
    --label-indigo: #4a3fa6;
    --label-indigo-soft: #e9e7f5;
    --ci-grp-standorte: var(--label-slate);
    --ci-grp-compute: var(--label-violet);
    --ci-grp-virtualisierung: var(--label-teal);
    --ci-grp-netzwerk: var(--label-azure);
    --ci-grp-endgeraete: var(--label-magenta);
    --ci-grp-industrie: var(--label-bronze);
    --ci-grp-services: var(--label-green);
    --ci-grp-sonstiges: var(--label-gray);
    --ci-grp-messtechnik: var(--label-plum);
    --ci-grp-fahrzeuge: var(--label-coral);
    --ci-grp-entwicklung: var(--label-indigo);
    --ci-grp-werkzeug: var(--label-bronze);
    --ci-grp-gebaeudetechnik: var(--label-slate);
    --custody-stock: var(--status-info);
    --custody-issued: var(--status-ok);
    --custody-loan: var(--status-warn);
    --custody-repair: var(--status-warn);
    --custody-retired: var(--status-muted);
    --custody-disposed: var(--ink-4);
    --insp-locked: #7a1f18;
    --insp-locked-soft: var(--status-risk-soft);
    --color-rule: #ece8e0;
    --color-rule-2: #e2ddd3;
    --color-status-ja-bg: #eaf3de;
    --color-status-ja-fg: #27500a;
    --color-status-teilweise-bg: #faeeda;
    --color-status-teilweise-fg: #633806;
    --color-status-nein-bg: #fcebeb;
    --color-status-nein-fg: #791f1f;
    --color-status-entbehrlich-bg: #f1efe8;
    --color-status-entbehrlich-fg: #444441;
    --color-ok: #3f8a52;
    --color-ok-soft: #e7f0e7;
    --color-warn: #c08a2e;
    --color-warn-soft: #f6efe0;
    --color-stop: #b3403a;
    --color-stop-soft: #f6e6e4;
    --mod-heute: #1f1f1f;
    --mod-projekte: #2f8a4d;
    --mod-kommunikation: #6d5ae0;
    --mod-aktionen: #c45a3e;
    --mod-wissen: #1e5cb0;
    --mod-inhalte: #5a6472;
    --mod-wiki: #327cd9;
    --mod-dev: #0e7c86;
    --mod-cmdb: #4b5e9e;
    --mod-regulierte-stoffe: #1f7a8c;
    --mod-inventar: #7a8a3a;
    --mod-compliance: #a8323a;
    --mod-operations: #2f7d9e;
    --mod-mappen: #4756c4;
    --mod-modadmin: #6a6a6a;
    --mod-produktion: #8a5a2e;
    --radius-card: 14px;
    --radius-input: 9px;
    --radius-btn: 9px;
  }

  @supports (color: lab(0% 0 0)) {
    :root, :host {
      --color-red-50: lab(96.5005% 4.18508 1.52328);
      --color-red-100: lab(92.243% 10.2865 3.83865);
      --color-red-200: lab(86.017% 19.8815 7.75869);
      --color-red-300: lab(76.5514% 36.422 15.5335);
      --color-red-500: lab(55.4814% 75.0732 48.8528);
      --color-red-600: lab(48.4493% 77.4328 61.5452);
      --color-red-700: lab(40.4273% 67.2623 53.7441);
      --color-red-800: lab(33.7174% 55.8993 41.0293);
      --color-red-900: lab(28.5139% 44.5539 29.0463);
      --color-amber-50: lab(98.6252% -.635922 8.42309);
      --color-amber-200: lab(91.7203% -.505269 49.9084);
      --color-amber-300: lab(86.4156% 6.13147 78.3961);
      --color-amber-800: lab(37.8822% 37.1699 52.2718);
      --color-amber-900: lab(31.2288% 30.2627 40.0378);
      --color-green-50: lab(98.1563% -5.60117 2.75915);
      --color-green-100: lab(96.1861% -13.8464 6.52365);
      --color-green-200: lab(92.4222% -26.4702 12.9427);
      --color-green-300: lab(86.9953% -47.2691 25.0054);
      --color-green-500: lab(70.5521% -66.5147 45.8073);
      --color-green-600: lab(59.0978% -58.6621 41.2579);
      --color-green-700: lab(47.0329% -47.0239 31.4788);
      --color-green-800: lab(37.4616% -36.7971 22.9692);
      --color-green-900: lab(30.797% -29.6927 17.382);
      --color-emerald-100: lab(94.9004% -17.0769 5.63836);
      --color-emerald-600: lab(55.0481% -49.9246 15.93);
      --color-emerald-800: lab(35.3675% -33.1188 8.04002);
      --color-blue-50: lab(96.492% -1.14644 -5.11479);
      --color-blue-100: lab(92.0301% -2.24757 -11.6453);
      --color-blue-200: lab(86.15% -4.04379 -21.0797);
      --color-blue-500: lab(54.1736% 13.3369 -74.6839);
      --color-blue-600: lab(44.0605% 29.0279 -86.0352);
      --color-blue-700: lab(36.9089% 35.0961 -85.6872);
      --color-gray-50: lab(98.2596% -.247031 -.706708);
      --color-gray-100: lab(96.1596% -.0823438 -1.13575);
      --color-gray-300: lab(85.1236% -.612259 -3.7138);
      --color-gray-400: lab(65.9269% -.832707 -8.17473);
      --color-gray-500: lab(47.7841% -.393182 -10.0268);
      --color-gray-600: lab(35.6337% -1.58697 -10.8425);
      --color-gray-700: lab(27.1134% -.956401 -12.3224);
      --color-zinc-100: lab(96.1634% .0993311 -.364041);
      --color-zinc-500: lab(47.8878% 1.65477 -5.77283);
      --color-zinc-950: lab(2.51107% .242703 -.886115);
    }
  }
}

@layer base {
  *, :after, :before, ::backdrop {
    box-sizing: border-box;
    border: 0 solid;
    margin: 0;
    padding: 0;
  }

  ::file-selector-button {
    box-sizing: border-box;
    border: 0 solid;
    margin: 0;
    padding: 0;
  }

  html, :host {
    -webkit-text-size-adjust: 100%;
    tab-size: 4;
    line-height: 1.5;
    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;
    -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 {
    vertical-align: baseline;
    font-size: 75%;
    line-height: 0;
    position: relative;
  }

  sub {
    bottom: -.25em;
  }

  sup {
    top: -.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 {
    vertical-align: middle;
    display: block;
  }

  img, video {
    max-width: 100%;
    height: auto;
  }

  button, input, select, optgroup, textarea {
    font: inherit;
    font-feature-settings: inherit;
    font-variation-settings: inherit;
    letter-spacing: inherit;
    color: inherit;
    opacity: 1;
    background-color: #0000;
    border-radius: 0;
  }

  ::file-selector-button {
    font: inherit;
    font-feature-settings: inherit;
    font-variation-settings: inherit;
    letter-spacing: inherit;
    color: inherit;
    opacity: 1;
    background-color: #0000;
    border-radius: 0;
  }

  :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)) {
      ::placeholder {
        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 {
    padding-block: 0;
  }

  ::-webkit-datetime-edit-year-field {
    padding-block: 0;
  }

  ::-webkit-datetime-edit-month-field {
    padding-block: 0;
  }

  ::-webkit-datetime-edit-day-field {
    padding-block: 0;
  }

  ::-webkit-datetime-edit-hour-field {
    padding-block: 0;
  }

  ::-webkit-datetime-edit-minute-field {
    padding-block: 0;
  }

  ::-webkit-datetime-edit-second-field {
    padding-block: 0;
  }

  ::-webkit-datetime-edit-millisecond-field {
    padding-block: 0;
  }

  ::-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"]) {
    appearance: button;
  }

  ::file-selector-button {
    appearance: button;
  }

  ::-webkit-inner-spin-button {
    height: auto;
  }

  ::-webkit-outer-spin-button {
    height: auto;
  }

  [hidden]:where(:not([hidden="until-found"])) {
    display: none !important;
  }
}

@layer components;

@layer utilities {
  .pointer-events-none {
    pointer-events: none;
  }

  .collapse {
    visibility: collapse;
  }

  .visible {
    visibility: visible;
  }

  .absolute {
    position: absolute;
  }

  .fixed {
    position: fixed;
  }

  .relative {
    position: relative;
  }

  .static {
    position: static;
  }

  .sticky {
    position: sticky;
  }

  .inset-0 {
    inset: 0;
  }

  .top-0 {
    top: 0;
  }

  .top-1 {
    top: var(--spacing);
  }

  .top-1\.5 {
    top: calc(var(--spacing) * 1.5);
  }

  .top-1\/2 {
    top: 50%;
  }

  .top-2 {
    top: calc(var(--spacing) * 2);
  }

  .top-2\.5 {
    top: calc(var(--spacing) * 2.5);
  }

  .top-7 {
    top: calc(var(--spacing) * 7);
  }

  .top-9 {
    top: calc(var(--spacing) * 9);
  }

  .top-10 {
    top: calc(var(--spacing) * 10);
  }

  .top-12 {
    top: calc(var(--spacing) * 12);
  }

  .top-14 {
    top: calc(var(--spacing) * 14);
  }

  .top-16 {
    top: calc(var(--spacing) * 16);
  }

  .top-full {
    top: 100%;
  }

  .right-0 {
    right: 0;
  }

  .right-1 {
    right: var(--spacing);
  }

  .right-1\.5 {
    right: calc(var(--spacing) * 1.5);
  }

  .right-2 {
    right: calc(var(--spacing) * 2);
  }

  .right-6 {
    right: calc(var(--spacing) * 6);
  }

  .bottom-0 {
    bottom: 0;
  }

  .left-0 {
    left: 0;
  }

  .left-2 {
    left: calc(var(--spacing) * 2);
  }

  .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;
  }

  .z-\[5\] {
    z-index: 5;
  }

  .z-\[60\] {
    z-index: 60;
  }

  .z-\[100\] {
    z-index: 100;
  }

  .col-span-1 {
    grid-column: span 1 / span 1;
  }

  .col-span-2 {
    grid-column: span 2 / span 2;
  }

  .col-span-3 {
    grid-column: span 3 / span 3;
  }

  .col-span-12 {
    grid-column: span 12 / span 12;
  }

  .col-span-full {
    grid-column: 1 / -1;
  }

  .row-1 {
    grid-row: 1;
  }

  .row-2 {
    grid-row: 2;
  }

  .row-3 {
    grid-row: 3;
  }

  .row-4 {
    grid-row: 4;
  }

  .container {
    width: 100%;
  }

  @media (min-width: 40rem) {
    .container {
      max-width: 40rem;
    }
  }

  @media (min-width: 48rem) {
    .container {
      max-width: 48rem;
    }
  }

  @media (min-width: 64rem) {
    .container {
      max-width: 64rem;
    }
  }

  @media (min-width: 80rem) {
    .container {
      max-width: 80rem;
    }
  }

  @media (min-width: 96rem) {
    .container {
      max-width: 96rem;
    }
  }

  .m-4 {
    margin: calc(var(--spacing) * 4);
  }

  .-mx-8 {
    margin-inline: calc(var(--spacing) * -8);
  }

  .mx-0\.5 {
    margin-inline: calc(var(--spacing) * .5);
  }

  .mx-2 {
    margin-inline: calc(var(--spacing) * 2);
  }

  .mx-auto {
    margin-inline: auto;
  }

  .-my-8 {
    margin-block: calc(var(--spacing) * -8);
  }

  .my-1 {
    margin-block: var(--spacing);
  }

  .my-2 {
    margin-block: calc(var(--spacing) * 2);
  }

  .my-3 {
    margin-block: calc(var(--spacing) * 3);
  }

  .my-4 {
    margin-block: calc(var(--spacing) * 4);
  }

  .my-6 {
    margin-block: calc(var(--spacing) * 6);
  }

  .my-8 {
    margin-block: calc(var(--spacing) * 8);
  }

  .ms-1 {
    margin-inline-start: var(--spacing);
  }

  .ms-2 {
    margin-inline-start: calc(var(--spacing) * 2);
  }

  .mt-0\.5 {
    margin-top: calc(var(--spacing) * .5);
  }

  .mt-1 {
    margin-top: var(--spacing);
  }

  .mt-1\.5 {
    margin-top: calc(var(--spacing) * 1.5);
  }

  .mt-2 {
    margin-top: calc(var(--spacing) * 2);
  }

  .mt-2\.5 {
    margin-top: calc(var(--spacing) * 2.5);
  }

  .mt-3 {
    margin-top: calc(var(--spacing) * 3);
  }

  .mt-4 {
    margin-top: calc(var(--spacing) * 4);
  }

  .mt-5 {
    margin-top: calc(var(--spacing) * 5);
  }

  .mt-6 {
    margin-top: calc(var(--spacing) * 6);
  }

  .mt-7 {
    margin-top: calc(var(--spacing) * 7);
  }

  .mt-8 {
    margin-top: calc(var(--spacing) * 8);
  }

  .mt-10 {
    margin-top: calc(var(--spacing) * 10);
  }

  .mr-1 {
    margin-right: var(--spacing);
  }

  .mr-1\.5 {
    margin-right: calc(var(--spacing) * 1.5);
  }

  .mr-2 {
    margin-right: calc(var(--spacing) * 2);
  }

  .mr-3 {
    margin-right: calc(var(--spacing) * 3);
  }

  .mb-0\.5 {
    margin-bottom: calc(var(--spacing) * .5);
  }

  .mb-1 {
    margin-bottom: var(--spacing);
  }

  .mb-1\.5 {
    margin-bottom: calc(var(--spacing) * 1.5);
  }

  .mb-2 {
    margin-bottom: calc(var(--spacing) * 2);
  }

  .mb-2\.5 {
    margin-bottom: calc(var(--spacing) * 2.5);
  }

  .mb-3 {
    margin-bottom: calc(var(--spacing) * 3);
  }

  .mb-4 {
    margin-bottom: calc(var(--spacing) * 4);
  }

  .mb-5 {
    margin-bottom: calc(var(--spacing) * 5);
  }

  .mb-6 {
    margin-bottom: calc(var(--spacing) * 6);
  }

  .mb-7 {
    margin-bottom: calc(var(--spacing) * 7);
  }

  .mb-8 {
    margin-bottom: calc(var(--spacing) * 8);
  }

  .mb-10 {
    margin-bottom: calc(var(--spacing) * 10);
  }

  .ml-1 {
    margin-left: var(--spacing);
  }

  .ml-1\.5 {
    margin-left: calc(var(--spacing) * 1.5);
  }

  .ml-2 {
    margin-left: calc(var(--spacing) * 2);
  }

  .ml-3 {
    margin-left: calc(var(--spacing) * 3);
  }

  .ml-4 {
    margin-left: calc(var(--spacing) * 4);
  }

  .ml-5 {
    margin-left: calc(var(--spacing) * 5);
  }

  .ml-9 {
    margin-left: calc(var(--spacing) * 9);
  }

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

  .line-clamp-2 {
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    display: -webkit-box;
    overflow: hidden;
  }

  .block {
    display: block;
  }

  .contents {
    display: contents;
  }

  .flex {
    display: flex;
  }

  .grid {
    display: grid;
  }

  .hidden {
    display: none;
  }

  .inline {
    display: inline;
  }

  .inline-block {
    display: inline-block;
  }

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

  .table {
    display: table;
  }

  .h-1\.5 {
    height: calc(var(--spacing) * 1.5);
  }

  .h-2 {
    height: calc(var(--spacing) * 2);
  }

  .h-3 {
    height: calc(var(--spacing) * 3);
  }

  .h-4 {
    height: calc(var(--spacing) * 4);
  }

  .h-5 {
    height: calc(var(--spacing) * 5);
  }

  .h-7 {
    height: calc(var(--spacing) * 7);
  }

  .h-8 {
    height: calc(var(--spacing) * 8);
  }

  .h-9 {
    height: calc(var(--spacing) * 9);
  }

  .h-14 {
    height: calc(var(--spacing) * 14);
  }

  .h-24 {
    height: calc(var(--spacing) * 24);
  }

  .h-32 {
    height: calc(var(--spacing) * 32);
  }

  .h-\[34px\] {
    height: 34px;
  }

  .h-\[calc\(100vh-64px\)\] {
    height: calc(100vh - 64px);
  }

  .h-\[calc\(100vh-220px\)\] {
    height: calc(100vh - 220px);
  }

  .h-full {
    height: 100%;
  }

  .h-px {
    height: 1px;
  }

  .h-screen {
    height: 100vh;
  }

  .max-h-32 {
    max-height: calc(var(--spacing) * 32);
  }

  .max-h-48 {
    max-height: calc(var(--spacing) * 48);
  }

  .max-h-64 {
    max-height: calc(var(--spacing) * 64);
  }

  .max-h-72 {
    max-height: calc(var(--spacing) * 72);
  }

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

  .max-h-\[260px\] {
    max-height: 260px;
  }

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

  .max-h-\[480px\] {
    max-height: 480px;
  }

  .min-h-0 {
    min-height: 0;
  }

  .min-h-\[calc\(100vh-200px\)\] {
    min-height: calc(100vh - 200px);
  }

  .min-h-screen {
    min-height: 100vh;
  }

  .w-2 {
    width: calc(var(--spacing) * 2);
  }

  .w-4 {
    width: calc(var(--spacing) * 4);
  }

  .w-5 {
    width: calc(var(--spacing) * 5);
  }

  .w-6 {
    width: calc(var(--spacing) * 6);
  }

  .w-7 {
    width: calc(var(--spacing) * 7);
  }

  .w-8 {
    width: calc(var(--spacing) * 8);
  }

  .w-12 {
    width: calc(var(--spacing) * 12);
  }

  .w-16 {
    width: calc(var(--spacing) * 16);
  }

  .w-20 {
    width: calc(var(--spacing) * 20);
  }

  .w-32 {
    width: calc(var(--spacing) * 32);
  }

  .w-48 {
    width: calc(var(--spacing) * 48);
  }

  .w-56 {
    width: calc(var(--spacing) * 56);
  }

  .w-60 {
    width: calc(var(--spacing) * 60);
  }

  .w-64 {
    width: calc(var(--spacing) * 64);
  }

  .w-72 {
    width: calc(var(--spacing) * 72);
  }

  .w-80 {
    width: calc(var(--spacing) * 80);
  }

  .w-\[28px\] {
    width: 28px;
  }

  .w-\[244px\] {
    width: 244px;
  }

  .w-\[280px\] {
    width: 280px;
  }

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

  .w-\[440px\] {
    width: 440px;
  }

  .w-\[480px\] {
    width: 480px;
  }

  .w-full {
    width: 100%;
  }

  .max-w-2xl {
    max-width: var(--container-2xl);
  }

  .max-w-3xl {
    max-width: var(--container-3xl);
  }

  .max-w-4xl {
    max-width: var(--container-4xl);
  }

  .max-w-5xl {
    max-width: var(--container-5xl);
  }

  .max-w-6xl {
    max-width: var(--container-6xl);
  }

  .max-w-\[75\%\] {
    max-width: 75%;
  }

  .max-w-\[80\%\] {
    max-width: 80%;
  }

  .max-w-\[85\%\] {
    max-width: 85%;
  }

  .max-w-\[90vw\] {
    max-width: 90vw;
  }

  .max-w-\[140px\] {
    max-width: 140px;
  }

  .max-w-\[260px\] {
    max-width: 260px;
  }

  .max-w-\[1080px\] {
    max-width: 1080px;
  }

  .max-w-\[1100px\] {
    max-width: 1100px;
  }

  .max-w-\[1400px\] {
    max-width: 1400px;
  }

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

  .max-w-lg {
    max-width: var(--container-lg);
  }

  .max-w-md {
    max-width: var(--container-md);
  }

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

  .max-w-xl {
    max-width: var(--container-xl);
  }

  .max-w-xs {
    max-width: var(--container-xs);
  }

  .min-w-0 {
    min-width: 0;
  }

  .min-w-\[1rem\] {
    min-width: 1rem;
  }

  .min-w-\[140px\] {
    min-width: 140px;
  }

  .min-w-\[200px\] {
    min-width: 200px;
  }

  .min-w-\[280px\] {
    min-width: 280px;
  }

  .flex-1 {
    flex: 1;
  }

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

  .flex-shrink-0, .shrink-0 {
    flex-shrink: 0;
  }

  .grow {
    flex-grow: 1;
  }

  .border-collapse {
    border-collapse: collapse;
  }

  .-translate-y-1\/2 {
    --tw-translate-y: calc(calc(1 / 2 * 100%) * -1);
    translate: var(--tw-translate-x) var(--tw-translate-y);
  }

  .transform {
    transform: var(--tw-rotate-x, ) var(--tw-rotate-y, ) var(--tw-rotate-z, ) var(--tw-skew-x, ) var(--tw-skew-y, );
  }

  .animate-pulse {
    animation: var(--animate-pulse);
  }

  .animate-spin {
    animation: var(--animate-spin);
  }

  .cursor-grab {
    cursor: grab;
  }

  .cursor-pointer {
    cursor: pointer;
  }

  .resize {
    resize: both;
  }

  .resize-none {
    resize: none;
  }

  .resize-y {
    resize: vertical;
  }

  .scroll-mt-20 {
    scroll-margin-top: calc(var(--spacing) * 20);
  }

  .list-inside {
    list-style-position: inside;
  }

  .list-decimal {
    list-style-type: decimal;
  }

  .list-disc {
    list-style-type: disc;
  }

  .list-none {
    list-style-type: none;
  }

  .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-12 {
    grid-template-columns: repeat(12, minmax(0, 1fr));
  }

  .grid-cols-\[1fr_1fr_80px_28px\] {
    grid-template-columns: 1fr 1fr 80px 28px;
  }

  .grid-cols-\[2fr_1fr\] {
    grid-template-columns: 2fr 1fr;
  }

  .grid-cols-\[100px_1fr\] {
    grid-template-columns: 100px 1fr;
  }

  .grid-cols-\[120px_1fr\] {
    grid-template-columns: 120px 1fr;
  }

  .grid-cols-\[140px\,1fr\] {
    grid-template-columns: 140px,1fr;
  }

  .grid-cols-\[140px_1fr\] {
    grid-template-columns: 140px 1fr;
  }

  .grid-cols-\[200px_1fr\] {
    grid-template-columns: 200px 1fr;
  }

  .grid-cols-\[auto_1fr\] {
    grid-template-columns: auto 1fr;
  }

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

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

  .flex-row-reverse {
    flex-direction: row-reverse;
  }

  .flex-wrap {
    flex-wrap: wrap;
  }

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

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

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

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

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

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

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

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

  .justify-start {
    justify-content: flex-start;
  }

  .gap-0 {
    gap: 0;
  }

  .gap-0\.5 {
    gap: calc(var(--spacing) * .5);
  }

  .gap-1 {
    gap: var(--spacing);
  }

  .gap-1\.5 {
    gap: calc(var(--spacing) * 1.5);
  }

  .gap-2 {
    gap: calc(var(--spacing) * 2);
  }

  .gap-2\.5 {
    gap: calc(var(--spacing) * 2.5);
  }

  .gap-3 {
    gap: calc(var(--spacing) * 3);
  }

  .gap-3\.5 {
    gap: calc(var(--spacing) * 3.5);
  }

  .gap-4 {
    gap: calc(var(--spacing) * 4);
  }

  .gap-5 {
    gap: calc(var(--spacing) * 5);
  }

  .gap-6 {
    gap: calc(var(--spacing) * 6);
  }

  :where(.space-y-0\.5 > :not(:last-child)) {
    --tw-space-y-reverse: 0;
    margin-block-start: calc(calc(var(--spacing) * .5) * var(--tw-space-y-reverse));
    margin-block-end: calc(calc(var(--spacing) * .5) * calc(1 - var(--tw-space-y-reverse)));
  }

  :where(.space-y-1 > :not(:last-child)) {
    --tw-space-y-reverse: 0;
    margin-block-start: calc(var(--spacing) * var(--tw-space-y-reverse));
    margin-block-end: calc(var(--spacing) * calc(1 - var(--tw-space-y-reverse)));
  }

  :where(.space-y-1\.5 > :not(:last-child)) {
    --tw-space-y-reverse: 0;
    margin-block-start: calc(calc(var(--spacing) * 1.5) * var(--tw-space-y-reverse));
    margin-block-end: calc(calc(var(--spacing) * 1.5) * calc(1 - var(--tw-space-y-reverse)));
  }

  :where(.space-y-2 > :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)));
  }

  :where(.space-y-2\.5 > :not(:last-child)) {
    --tw-space-y-reverse: 0;
    margin-block-start: calc(calc(var(--spacing) * 2.5) * var(--tw-space-y-reverse));
    margin-block-end: calc(calc(var(--spacing) * 2.5) * calc(1 - var(--tw-space-y-reverse)));
  }

  :where(.space-y-3 > :not(:last-child)) {
    --tw-space-y-reverse: 0;
    margin-block-start: calc(calc(var(--spacing) * 3) * var(--tw-space-y-reverse));
    margin-block-end: calc(calc(var(--spacing) * 3) * calc(1 - var(--tw-space-y-reverse)));
  }

  :where(.space-y-4 > :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)));
  }

  :where(.space-y-5 > :not(:last-child)) {
    --tw-space-y-reverse: 0;
    margin-block-start: calc(calc(var(--spacing) * 5) * var(--tw-space-y-reverse));
    margin-block-end: calc(calc(var(--spacing) * 5) * calc(1 - var(--tw-space-y-reverse)));
  }

  :where(.space-y-6 > :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)));
  }

  .gap-x-3 {
    column-gap: calc(var(--spacing) * 3);
  }

  .gap-x-4 {
    column-gap: calc(var(--spacing) * 4);
  }

  .gap-x-8 {
    column-gap: calc(var(--spacing) * 8);
  }

  :where(.space-x-2 > :not(:last-child)) {
    --tw-space-x-reverse: 0;
    margin-inline-start: calc(calc(var(--spacing) * 2) * var(--tw-space-x-reverse));
    margin-inline-end: calc(calc(var(--spacing) * 2) * calc(1 - var(--tw-space-x-reverse)));
  }

  .gap-y-1 {
    row-gap: var(--spacing);
  }

  .gap-y-1\.5 {
    row-gap: calc(var(--spacing) * 1.5);
  }

  .gap-y-2 {
    row-gap: calc(var(--spacing) * 2);
  }

  :where(.divide-y > :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)));
  }

  .self-center {
    align-self: center;
  }

  .self-start {
    align-self: flex-start;
  }

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

  .overflow-auto {
    overflow: auto;
  }

  .overflow-hidden {
    overflow: hidden;
  }

  .overflow-x-auto {
    overflow-x: auto;
  }

  .overflow-x-hidden {
    overflow-x: hidden;
  }

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

  .rounded {
    border-radius: .25rem;
  }

  .rounded-full {
    border-radius: 3.40282e38px;
  }

  .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-0 {
    border-style: var(--tw-border-style);
    border-width: 0;
  }

  .border-2 {
    border-style: var(--tw-border-style);
    border-width: 2px;
  }

  .border-t {
    border-top-style: var(--tw-border-style);
    border-top-width: 1px;
  }

  .border-b {
    border-bottom-style: var(--tw-border-style);
    border-bottom-width: 1px;
  }

  .border-l-4 {
    border-left-style: var(--tw-border-style);
    border-left-width: 4px;
  }

  .border-dashed {
    --tw-border-style: dashed;
    border-style: dashed;
  }

  .border-none {
    --tw-border-style: none;
    border-style: none;
  }

  .border-amber-200 {
    border-color: var(--color-amber-200);
  }

  .border-green-200 {
    border-color: var(--color-green-200);
  }

  .border-green-300 {
    border-color: var(--color-green-300);
  }

  .border-red-200 {
    border-color: var(--color-red-200);
  }

  .border-red-300 {
    border-color: var(--color-red-300);
  }

  .border-red-500 {
    border-color: var(--color-red-500);
  }

  .bg-\[var\(--color-paper-2\)\] {
    background-color: var(--color-paper-2);
  }

  .bg-amber-50 {
    background-color: var(--color-amber-50);
  }

  .bg-black\/30 {
    background-color: #0000004d;
  }

  @supports (color: color-mix(in lab, red, red)) {
    .bg-black\/30 {
      background-color: color-mix(in oklab, var(--color-black) 30%, transparent);
    }
  }

  .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-emerald-100 {
    background-color: var(--color-emerald-100);
  }

  .bg-gray-50 {
    background-color: var(--color-gray-50);
  }

  .bg-gray-100 {
    background-color: var(--color-gray-100);
  }

  .bg-gray-300 {
    background-color: var(--color-gray-300);
  }

  .bg-green-50 {
    background-color: var(--color-green-50);
  }

  .bg-green-50\/50 {
    background-color: #f0fdf480;
  }

  @supports (color: color-mix(in lab, red, red)) {
    .bg-green-50\/50 {
      background-color: color-mix(in oklab, var(--color-green-50) 50%, transparent);
    }
  }

  .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-600 {
    background-color: var(--color-red-600);
  }

  .bg-transparent {
    background-color: #0000;
  }

  .bg-white {
    background-color: var(--color-white);
  }

  .bg-zinc-950 {
    background-color: var(--color-zinc-950);
  }

  .p-0 {
    padding: 0;
  }

  .p-0\.5 {
    padding: calc(var(--spacing) * .5);
  }

  .p-1 {
    padding: var(--spacing);
  }

  .p-1\.5 {
    padding: calc(var(--spacing) * 1.5);
  }

  .p-2 {
    padding: calc(var(--spacing) * 2);
  }

  .p-2\.5 {
    padding: calc(var(--spacing) * 2.5);
  }

  .p-3 {
    padding: calc(var(--spacing) * 3);
  }

  .p-4 {
    padding: calc(var(--spacing) * 4);
  }

  .p-5 {
    padding: calc(var(--spacing) * 5);
  }

  .p-6 {
    padding: calc(var(--spacing) * 6);
  }

  .p-7 {
    padding: calc(var(--spacing) * 7);
  }

  .p-8 {
    padding: calc(var(--spacing) * 8);
  }

  .p-10 {
    padding: calc(var(--spacing) * 10);
  }

  .p-12 {
    padding: calc(var(--spacing) * 12);
  }

  .px-0\.5 {
    padding-inline: calc(var(--spacing) * .5);
  }

  .px-1 {
    padding-inline: var(--spacing);
  }

  .px-1\.5 {
    padding-inline: calc(var(--spacing) * 1.5);
  }

  .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-3\.5 {
    padding-inline: calc(var(--spacing) * 3.5);
  }

  .px-4 {
    padding-inline: calc(var(--spacing) * 4);
  }

  .px-5 {
    padding-inline: calc(var(--spacing) * 5);
  }

  .px-6 {
    padding-inline: calc(var(--spacing) * 6);
  }

  .px-8 {
    padding-inline: calc(var(--spacing) * 8);
  }

  .py-0 {
    padding-block: 0;
  }

  .py-0\.5 {
    padding-block: calc(var(--spacing) * .5);
  }

  .py-1 {
    padding-block: var(--spacing);
  }

  .py-1\.5 {
    padding-block: calc(var(--spacing) * 1.5);
  }

  .py-2 {
    padding-block: calc(var(--spacing) * 2);
  }

  .py-2\.5 {
    padding-block: calc(var(--spacing) * 2.5);
  }

  .py-3 {
    padding-block: calc(var(--spacing) * 3);
  }

  .py-3\.5 {
    padding-block: calc(var(--spacing) * 3.5);
  }

  .py-4 {
    padding-block: calc(var(--spacing) * 4);
  }

  .py-6 {
    padding-block: calc(var(--spacing) * 6);
  }

  .py-8 {
    padding-block: calc(var(--spacing) * 8);
  }

  .py-10 {
    padding-block: calc(var(--spacing) * 10);
  }

  .py-12 {
    padding-block: calc(var(--spacing) * 12);
  }

  .pt-0 {
    padding-top: 0;
  }

  .pt-1 {
    padding-top: var(--spacing);
  }

  .pt-1\.5 {
    padding-top: calc(var(--spacing) * 1.5);
  }

  .pt-2 {
    padding-top: calc(var(--spacing) * 2);
  }

  .pt-3 {
    padding-top: calc(var(--spacing) * 3);
  }

  .pt-4 {
    padding-top: calc(var(--spacing) * 4);
  }

  .pr-1 {
    padding-right: var(--spacing);
  }

  .pr-2 {
    padding-right: calc(var(--spacing) * 2);
  }

  .pr-3 {
    padding-right: calc(var(--spacing) * 3);
  }

  .pr-4 {
    padding-right: calc(var(--spacing) * 4);
  }

  .pr-7 {
    padding-right: calc(var(--spacing) * 7);
  }

  .pr-8 {
    padding-right: calc(var(--spacing) * 8);
  }

  .pr-16 {
    padding-right: calc(var(--spacing) * 16);
  }

  .pb-0\.5 {
    padding-bottom: calc(var(--spacing) * .5);
  }

  .pb-1 {
    padding-bottom: var(--spacing);
  }

  .pb-2 {
    padding-bottom: calc(var(--spacing) * 2);
  }

  .pb-3 {
    padding-bottom: calc(var(--spacing) * 3);
  }

  .pb-5 {
    padding-bottom: calc(var(--spacing) * 5);
  }

  .pl-3 {
    padding-left: calc(var(--spacing) * 3);
  }

  .pl-4 {
    padding-left: calc(var(--spacing) * 4);
  }

  .pl-5 {
    padding-left: calc(var(--spacing) * 5);
  }

  .pl-6 {
    padding-left: calc(var(--spacing) * 6);
  }

  .pl-7 {
    padding-left: calc(var(--spacing) * 7);
  }

  .pl-8 {
    padding-left: calc(var(--spacing) * 8);
  }

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

  .text-end {
    text-align: end;
  }

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

  .text-right {
    text-align: right;
  }

  .text-start {
    text-align: start;
  }

  .align-baseline {
    vertical-align: baseline;
  }

  .align-top {
    vertical-align: top;
  }

  .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-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));
  }

  .text-\[8px\] {
    font-size: 8px;
  }

  .text-\[9\.5px\] {
    font-size: 9.5px;
  }

  .text-\[9px\] {
    font-size: 9px;
  }

  .text-\[10px\] {
    font-size: 10px;
  }

  .text-\[11\.5px\] {
    font-size: 11.5px;
  }

  .text-\[11px\] {
    font-size: 11px;
  }

  .text-\[12\.5px\] {
    font-size: 12.5px;
  }

  .text-\[12px\] {
    font-size: 12px;
  }

  .leading-none {
    --tw-leading: 1;
    line-height: 1;
  }

  .leading-relaxed {
    --tw-leading: var(--leading-relaxed);
    line-height: var(--leading-relaxed);
  }

  .leading-snug {
    --tw-leading: var(--leading-snug);
    line-height: var(--leading-snug);
  }

  .leading-tight {
    --tw-leading: var(--leading-tight);
    line-height: var(--leading-tight);
  }

  .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-normal {
    --tw-font-weight: var(--font-weight-normal);
    font-weight: var(--font-weight-normal);
  }

  .font-semibold {
    --tw-font-weight: var(--font-weight-semibold);
    font-weight: var(--font-weight-semibold);
  }

  .tracking-\[0\.1em\] {
    --tw-tracking: .1em;
    letter-spacing: .1em;
  }

  .tracking-\[0\.04em\] {
    --tw-tracking: .04em;
    letter-spacing: .04em;
  }

  .tracking-\[0\.05em\] {
    --tw-tracking: .05em;
    letter-spacing: .05em;
  }

  .tracking-\[0\.06em\] {
    --tw-tracking: .06em;
    letter-spacing: .06em;
  }

  .tracking-\[0\.08em\] {
    --tw-tracking: .08em;
    letter-spacing: .08em;
  }

  .tracking-\[0\.12em\] {
    --tw-tracking: .12em;
    letter-spacing: .12em;
  }

  .tracking-wide {
    --tw-tracking: var(--tracking-wide);
    letter-spacing: var(--tracking-wide);
  }

  .tracking-wider {
    --tw-tracking: var(--tracking-wider);
    letter-spacing: var(--tracking-wider);
  }

  .tracking-widest {
    --tw-tracking: var(--tracking-widest);
    letter-spacing: var(--tracking-widest);
  }

  .break-words {
    overflow-wrap: break-word;
  }

  .break-all {
    word-break: break-all;
  }

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

  .whitespace-pre-wrap {
    white-space: pre-wrap;
  }

  .text-amber-300 {
    color: var(--color-amber-300);
  }

  .text-amber-800 {
    color: var(--color-amber-800);
  }

  .text-amber-900 {
    color: var(--color-amber-900);
  }

  .text-blue-700 {
    color: var(--color-blue-700);
  }

  .text-emerald-600 {
    color: var(--color-emerald-600);
  }

  .text-emerald-800 {
    color: var(--color-emerald-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-green-600 {
    color: var(--color-green-600);
  }

  .text-green-700 {
    color: var(--color-green-700);
  }

  .text-green-800 {
    color: var(--color-green-800);
  }

  .text-green-900 {
    color: var(--color-green-900);
  }

  .text-red-300 {
    color: var(--color-red-300);
  }

  .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-red-900 {
    color: var(--color-red-900);
  }

  .text-white {
    color: var(--color-white);
  }

  .text-zinc-100 {
    color: var(--color-zinc-100);
  }

  .text-zinc-500 {
    color: var(--color-zinc-500);
  }

  .capitalize {
    text-transform: capitalize;
  }

  .lowercase {
    text-transform: lowercase;
  }

  .uppercase {
    text-transform: uppercase;
  }

  .italic {
    font-style: italic;
  }

  .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;
  }

  .no-underline {
    text-decoration-line: none;
  }

  .underline {
    text-decoration-line: underline;
  }

  .opacity-0 {
    opacity: 0;
  }

  .opacity-30 {
    opacity: .3;
  }

  .opacity-40 {
    opacity: .4;
  }

  .opacity-50 {
    opacity: .5;
  }

  .opacity-60 {
    opacity: .6;
  }

  .opacity-70 {
    opacity: .7;
  }

  .opacity-80 {
    opacity: .8;
  }

  .opacity-90 {
    opacity: .9;
  }

  .opacity-100 {
    opacity: 1;
  }

  .shadow {
    --tw-shadow: 0 1px 3px 0 var(--tw-shadow-color, #0000001a), 0 1px 2px -1px var(--tw-shadow-color, #0000001a);
    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, #0000001a), 0 4px 6px -4px var(--tw-shadow-color, #0000001a);
    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, #0000001a), 0 2px 4px -2px var(--tw-shadow-color, #0000001a);
    box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
  }

  .shadow-xl {
    --tw-shadow: 0 20px 25px -5px var(--tw-shadow-color, #0000001a), 0 8px 10px -6px var(--tw-shadow-color, #0000001a);
    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);
  }

  .ring-2 {
    --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);
  }

  .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, );
  }

  .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, );
  }

  .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-opacity {
    transition-property: opacity;
    transition-timing-function: var(--tw-ease, var(--default-transition-timing-function));
    transition-duration: var(--tw-duration, var(--default-transition-duration));
  }

  .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;
  }

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

  @media (hover: hover) {
    .group-hover\:opacity-60:is(:where(.group):hover *) {
      opacity: .6;
    }
  }

  @media (hover: hover) {
    .group-hover\:opacity-100:is(:where(.group):hover *) {
      opacity: 1;
    }
  }

  @media (hover: hover) {
    .group-hover\/code\:opacity-100:is(:where(.group\/code):hover *) {
      opacity: 1;
    }
  }

  @media (hover: hover) {
    .group-hover\/msg\:opacity-100:is(:where(.group\/msg):hover *) {
      opacity: 1;
    }
  }

  .focus-within\:opacity-100:focus-within {
    opacity: 1;
  }

  @media (hover: hover) {
    .hover\:bg-\[var\(--color-paper-2\)\]:hover {
      background-color: var(--color-paper-2);
    }
  }

  @media (hover: hover) {
    .hover\:bg-blue-50:hover {
      background-color: var(--color-blue-50);
    }
  }

  @media (hover: hover) {
    .hover\:bg-blue-200:hover {
      background-color: var(--color-blue-200);
    }
  }

  @media (hover: hover) {
    .hover\:bg-blue-700:hover {
      background-color: var(--color-blue-700);
    }
  }

  @media (hover: hover) {
    .hover\:bg-gray-50:hover {
      background-color: var(--color-gray-50);
    }
  }

  @media (hover: hover) {
    .hover\:bg-gray-100:hover {
      background-color: var(--color-gray-100);
    }
  }

  @media (hover: hover) {
    .hover\:bg-red-700:hover {
      background-color: var(--color-red-700);
    }
  }

  @media (hover: hover) {
    .hover\:bg-white:hover {
      background-color: var(--color-white);
    }
  }

  @media (hover: hover) {
    .hover\:underline:hover {
      text-decoration-line: underline;
    }
  }

  @media (hover: hover) {
    .hover\:\!opacity-100:hover {
      opacity: 1 !important;
    }
  }

  @media (hover: hover) {
    .hover\:opacity-100:hover {
      opacity: 1;
    }
  }

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

  .disabled\:cursor-not-allowed:disabled {
    cursor: not-allowed;
  }

  .disabled\:opacity-50:disabled {
    opacity: .5;
  }

  @media (min-width: 40rem) {
    .sm\:block {
      display: block;
    }
  }

  @media (min-width: 40rem) {
    .sm\:grid-cols-2 {
      grid-template-columns: repeat(2, minmax(0, 1fr));
    }
  }

  @media (min-width: 40rem) {
    .sm\:grid-cols-3 {
      grid-template-columns: repeat(3, minmax(0, 1fr));
    }
  }

  @media (min-width: 40rem) {
    .sm\:grid-cols-4 {
      grid-template-columns: repeat(4, minmax(0, 1fr));
    }
  }

  @media (min-width: 40rem) {
    .sm\:pt-24 {
      padding-top: calc(var(--spacing) * 24);
    }
  }

  @media (min-width: 48rem) {
    .md\:col-span-2 {
      grid-column: span 2 / span 2;
    }
  }

  @media (min-width: 48rem) {
    .md\:col-span-6 {
      grid-column: span 6 / span 6;
    }
  }

  @media (min-width: 48rem) {
    .md\:block {
      display: block;
    }
  }

  @media (min-width: 48rem) {
    .md\:flex {
      display: flex;
    }
  }

  @media (min-width: 48rem) {
    .md\:hidden {
      display: none;
    }
  }

  @media (min-width: 48rem) {
    .md\:inline {
      display: inline;
    }
  }

  @media (min-width: 48rem) {
    .md\:inline-flex {
      display: inline-flex;
    }
  }

  @media (min-width: 48rem) {
    .md\:grid-cols-2 {
      grid-template-columns: repeat(2, minmax(0, 1fr));
    }
  }

  @media (min-width: 48rem) {
    .md\:grid-cols-3 {
      grid-template-columns: repeat(3, minmax(0, 1fr));
    }
  }

  @media (min-width: 48rem) {
    .md\:grid-cols-4 {
      grid-template-columns: repeat(4, minmax(0, 1fr));
    }
  }

  @media (min-width: 48rem) {
    .md\:grid-cols-5 {
      grid-template-columns: repeat(5, minmax(0, 1fr));
    }
  }

  @media (min-width: 48rem) {
    .md\:grid-cols-6 {
      grid-template-columns: repeat(6, minmax(0, 1fr));
    }
  }

  @media (min-width: 48rem) {
    .md\:grid-cols-\[1\.4fr_1fr\] {
      grid-template-columns: 1.4fr 1fr;
    }
  }

  @media (min-width: 48rem) {
    .md\:flex-row {
      flex-direction: row;
    }
  }

  @media (min-width: 48rem) {
    .md\:p-6 {
      padding: calc(var(--spacing) * 6);
    }
  }

  @media (min-width: 48rem) {
    .md\:px-8 {
      padding-inline: calc(var(--spacing) * 8);
    }
  }

  @media (min-width: 48rem) {
    .md\:py-8 {
      padding-block: calc(var(--spacing) * 8);
    }
  }

  @media (min-width: 64rem) {
    .lg\:grid-cols-2 {
      grid-template-columns: repeat(2, minmax(0, 1fr));
    }
  }

  @media (min-width: 64rem) {
    .lg\:grid-cols-3 {
      grid-template-columns: repeat(3, minmax(0, 1fr));
    }
  }

  @media (min-width: 64rem) {
    .lg\:grid-cols-4 {
      grid-template-columns: repeat(4, minmax(0, 1fr));
    }
  }
}

.shell {
  background: var(--white);
  max-width: 1280px;
  box-shadow: var(--shadow-card);
  min-height: 100vh;
  margin: 0 auto;
}

.eyebrow {
  font-family: var(--mono);
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--mod-deep);
  margin-bottom: 6px;
  font-size: 10px;
}

.page-title {
  align-items: center;
  gap: 10px;
  display: flex;
}

.page-title h1 {
  letter-spacing: -.02em;
  font-size: 24px;
  font-weight: 600;
}

.btn:hover {
  border-color: var(--ink-4);
}

.kpi-strip {
  grid-auto-columns: 1fr;
  grid-auto-flow: column;
  gap: 12px;
  display: grid;
}

.kpi-label {
  font-family: var(--mono);
  text-transform: uppercase;
  color: var(--ink-4);
  letter-spacing: .06em;
  margin-bottom: 6px;
  font-size: 9.5px;
}

.kpi-value.warn {
  color: var(--status-warn);
}

.kpi-value.risk {
  color: var(--status-risk);
}

.panel {
  background: var(--white);
  border: 1px solid var(--rule);
  border-radius: var(--r-md);
  overflow: hidden;
}

.panel-head .h {
  color: var(--ink);
  font-size: 13px;
  font-weight: 600;
}

.panel-head .s {
  color: var(--ink-4);
  font-size: 11px;
  font-family: var(--mono);
}

.chip {
  white-space: nowrap;
  font-size: 11px;
  font-weight: 500;
  font-family: var(--mono);
  border-radius: 99px;
  align-items: center;
  gap: 5px;
  padding: 3px 9px;
  display: inline-flex;
}

.chip .dot {
  border-radius: 50%;
  width: 6px;
  height: 6px;
}

.chip-ok {
  background: var(--status-ok-soft);
  color: var(--status-ok);
}

.chip-ok .dot {
  background: var(--status-ok);
}

.chip-warn {
  background: var(--status-warn-soft);
  color: var(--status-warn-deep);
}

.chip-warn .dot {
  background: var(--status-warn);
}

.chip-risk {
  background: var(--status-risk-soft);
  color: var(--status-risk-deep);
}

.chip-risk .dot {
  background: var(--status-risk);
}

.chip-info {
  background: var(--status-info-soft);
  color: var(--status-info);
}

.chip-info .dot {
  background: var(--status-info);
}

.chip-muted {
  background: var(--status-muted-soft);
  color: var(--status-muted);
}

.chip-muted .dot {
  background: var(--status-muted);
}

.chip-mod {
  background: var(--mod-soft);
  color: var(--mod-deep);
}

.chip-mod .dot {
  background: var(--mod);
}

.chip-gray {
  background: var(--paper-2);
  color: var(--ink-3);
}

.chip-gray .dot {
  background: var(--ink-4);
}

.chip-planned {
  background: var(--status-info-soft);
  color: var(--status-info);
}

.chip-planned .dot {
  background: var(--status-info);
}

.chip-active {
  background: var(--status-ok-soft);
  color: var(--status-ok);
}

.chip-active .dot {
  background: var(--status-ok);
}

.chip-maintenance {
  background: var(--status-warn-soft);
  color: var(--status-warn-deep);
}

.chip-maintenance .dot {
  background: var(--status-warn);
}

.chip-decommissioned {
  background: var(--status-muted-soft);
  color: var(--status-muted);
}

.chip-decommissioned .dot {
  background: var(--status-muted);
}

.chip-type {
  background: var(--paper-2);
  color: var(--ink-3);
}

.chip-type .dot {
  background: var(--ink-4);
}

.tag {
  --tag: var(--ink-3);
  --tag-soft: transparent;
  font: 500 11px/1 var(--mono);
  border-radius: var(--r-sm);
  border: 1.5px solid var(--tag);
  align-items: center;
  gap: 4px;
  padding: 3px 8px 3px 7px;
  display: inline-flex;
}

@supports (color: color-mix(in lab, red, red)) {
  .tag {
    border: 1.5px solid color-mix(in srgb, var(--tag) 42%, transparent);
  }
}

.tag {
  background: var(--tag-soft);
  color: var(--tag);
  white-space: nowrap;
}

.tag:before {
  content: "#";
  opacity: .65;
  font-weight: 700;
}

.tag.is-tint {
  background: var(--tag);
}

@supports (color: color-mix(in lab, red, red)) {
  .tag.is-tint {
    background: color-mix(in srgb, var(--tag) 10%, var(--white));
  }
}

.tag.is-locked {
  border-style: solid;
  border-color: var(--tag);
}

@supports (color: color-mix(in lab, red, red)) {
  .tag.is-locked {
    border-color: color-mix(in srgb, var(--tag) 55%, transparent);
  }
}

.tag.is-locked:before {
  content: "🔒";
  opacity: .8;
  font-weight: 400;
}

.tag.is-level:before {
  content: "⚑";
  opacity: .7;
  font-weight: 400;
}

.has-flag:before {
  content: "⚑";
  opacity: .7;
  margin-right: 4px;
  font-weight: 400;
}

.tag .x {
  opacity: .55;
  cursor: pointer;
  margin-left: 1px;
  font-weight: 700;
}

.tag .x:hover {
  opacity: 1;
}

.tag-slate {
  --tag: var(--label-slate);
  --tag-soft: var(--label-slate-soft);
}

.tag-violet {
  --tag: var(--label-violet);
  --tag-soft: var(--label-violet-soft);
}

.tag-teal {
  --tag: var(--label-teal);
  --tag-soft: var(--label-teal-soft);
}

.tag-azure {
  --tag: var(--label-azure);
  --tag-soft: var(--label-azure-soft);
}

.tag-magenta {
  --tag: var(--label-magenta);
  --tag-soft: var(--label-magenta-soft);
}

.tag-bronze {
  --tag: var(--label-bronze);
  --tag-soft: var(--label-bronze-soft);
}

.tag-green {
  --tag: var(--label-green);
  --tag-soft: var(--label-green-soft);
}

.tag-plum {
  --tag: var(--label-plum);
  --tag-soft: var(--label-plum-soft);
}

.tag-coral {
  --tag: var(--label-coral);
  --tag-soft: var(--label-coral-soft);
}

.tag-gray {
  --tag: var(--label-gray);
  --tag-soft: var(--label-gray-soft);
}

.crit {
  border-radius: var(--r-sm);
  width: 18px;
  height: 18px;
  font: 700 11px/1 var(--mono);
  border: 1px solid #0000;
  justify-content: center;
  align-items: center;
  display: inline-flex;
}

.crit:before {
  content: attr(data-level);
}

.crit-a {
  background: var(--status-risk-soft);
  color: var(--status-risk-deep);
  border-color: #c45a3e59;
}

@supports (color: color-mix(in lab, red, red)) {
  .crit-a {
    border-color: color-mix(in srgb, var(--status-risk) 35%, transparent);
  }
}

.crit-b {
  background: var(--status-warn-soft);
  color: var(--status-warn-deep);
  border-color: #c9a85c66;
}

@supports (color: color-mix(in lab, red, red)) {
  .crit-b {
    border-color: color-mix(in srgb, var(--status-warn) 40%, transparent);
  }
}

.crit-c {
  background: var(--status-muted-soft);
  color: var(--status-muted);
  border-color: #5f667059;
}

@supports (color: color-mix(in lab, red, red)) {
  .crit-c {
    border-color: color-mix(in srgb, var(--status-muted) 35%, transparent);
  }
}

.crit-pa {
  background: var(--label-plum);
  color: var(--white);
  border-color: #0000;
}

.crit-pb {
  background: #ece3ef;
}

@supports (color: color-mix(in lab, red, red)) {
  .crit-pb {
    background: color-mix(in srgb, var(--label-plum) 16%, var(--white));
  }
}

.crit-pb {
  color: var(--label-plum);
  border-color: #8a4f9e6b;
}

@supports (color: color-mix(in lab, red, red)) {
  .crit-pb {
    border-color: color-mix(in srgb, var(--label-plum) 42%, transparent);
  }
}

.crit-pc {
  background: var(--white);
  color: var(--ink-3);
  border-color: var(--rule);
}

.crit-wrap {
  color: var(--ink-3);
  font-size: 11px;
  font-family: var(--mono);
  align-items: center;
  gap: 6px;
  display: inline-flex;
}

.grp-dot {
  background: var(--grp, var(--ink-4));
  border-radius: 2px;
  width: 9px;
  height: 9px;
  display: inline-block;
}

.grp-standorte {
  --grp: var(--ci-grp-standorte);
}

.grp-compute {
  --grp: var(--ci-grp-compute);
}

.grp-virtualisierung {
  --grp: var(--ci-grp-virtualisierung);
}

.grp-netzwerk {
  --grp: var(--ci-grp-netzwerk);
}

.grp-endgeraete {
  --grp: var(--ci-grp-endgeraete);
}

.grp-industrie {
  --grp: var(--ci-grp-industrie);
}

.grp-services {
  --grp: var(--ci-grp-services);
}

.grp-sonstiges {
  --grp: var(--ci-grp-sonstiges);
}

.grp-messtechnik {
  --grp: var(--ci-grp-messtechnik);
}

.grp-fahrzeuge {
  --grp: var(--ci-grp-fahrzeuge);
}

.grp-entwicklung {
  --grp: var(--ci-grp-entwicklung);
}

.grp-werkzeug {
  --grp: var(--ci-grp-werkzeug);
}

.grp-gebaeudetechnik {
  --grp: var(--ci-grp-gebaeudetechnik);
}

.custody {
  --cu: var(--ink-3);
  font: 500 11px var(--mono);
  border-radius: var(--r-sm);
  border: 1.5px solid var(--cu);
  align-items: center;
  gap: 5px;
  padding: 3px 9px 3px 7px;
  display: inline-flex;
}

@supports (color: color-mix(in lab, red, red)) {
  .custody {
    border: 1.5px solid color-mix(in srgb, var(--cu) 45%, transparent);
  }
}

.custody {
  background: var(--cu);
}

@supports (color: color-mix(in lab, red, red)) {
  .custody {
    background: color-mix(in srgb, var(--cu) 8%, var(--white));
  }
}

.custody {
  color: var(--cu);
  white-space: nowrap;
}

.custody svg {
  flex: none;
  width: 12px;
  height: 12px;
}

.custody-stock {
  --cu: var(--custody-stock);
}

.custody-issued {
  --cu: var(--custody-issued);
}

.custody-loan {
  --cu: var(--custody-loan);
}

.custody-repair {
  --cu: var(--custody-repair);
}

.custody-retired {
  --cu: var(--custody-retired);
}

.custody-disposed {
  --cu: var(--custody-disposed);
}

.due {
  --d: var(--ink-4);
  font: 600 11px var(--mono);
  border-radius: var(--r-sm);
  white-space: nowrap;
  border: 1px solid var(--d);
  align-items: center;
  gap: 5px;
  padding: 3px 9px 3px 7px;
  display: inline-flex;
}

@supports (color: color-mix(in lab, red, red)) {
  .due {
    border: 1px solid color-mix(in srgb, var(--d) 32%, transparent);
  }
}

.due {
  background: var(--d);
}

@supports (color: color-mix(in lab, red, red)) {
  .due {
    background: color-mix(in srgb, var(--d) 10%, var(--white));
  }
}

.due {
  color: var(--d);
}

.due svg {
  flex: none;
  width: 12px;
  height: 12px;
}

.due-ok {
  --d: var(--status-ok);
}

.due-soon {
  --d: var(--status-warn-deep);
}

.due-over {
  --d: var(--status-risk-deep);
}

.due-none {
  --d: var(--ink-4);
}

.due-locked {
  background: var(--status-risk);
  color: var(--white);
  border-color: var(--status-risk);
  --d: var(--white);
  font-weight: 700;
}

.due-locked svg {
  stroke: var(--white);
}

.select {
  appearance: none;
  background-image: 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='%238a8580' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
  background-position: right 11px center;
  background-repeat: no-repeat;
  padding-right: 32px;
}

.req-star {
  color: var(--status-risk);
  margin-left: 2px;
  font-weight: 700;
}

.field-req {
  font-family: var(--mono);
  letter-spacing: .05em;
  text-transform: uppercase;
  color: var(--status-risk-deep);
  margin-left: 6px;
  font-size: 9px;
}

.is-invalid {
  background: #fdf8f7;
  border-color: var(--status-risk) !important;
}

@supports (color: color-mix(in lab, red, red)) {
  .is-invalid {
    background: color-mix(in srgb, var(--status-risk) 4%, var(--white));
  }
}

.is-invalid:focus {
  box-shadow: 0 0 0 3px var(--status-risk-soft) !important;
}

.field-error {
  color: var(--status-risk-deep);
  font-size: 11px;
  font-family: var(--mono);
  align-items: center;
  gap: 5px;
  margin-top: 6px;
  display: flex;
}

.field-error:before {
  content: "⚠";
}

.guard-note {
  --gc: var(--status-warn);
  border: 1px solid var(--gc);
  align-items: flex-start;
  gap: 9px;
  font-size: 12.5px;
  line-height: 1.45;
  display: flex;
}

@supports (color: color-mix(in lab, red, red)) {
  .guard-note {
    border: 1px solid color-mix(in srgb, var(--gc) 32%, var(--white));
  }
}

.guard-note {
  background: var(--gc);
}

@supports (color: color-mix(in lab, red, red)) {
  .guard-note {
    background: color-mix(in srgb, var(--gc) 8%, var(--white));
  }
}

.guard-note {
  color: var(--gc);
}

@supports (color: color-mix(in lab, red, red)) {
  .guard-note {
    color: color-mix(in srgb, var(--gc) 64%, var(--ink));
  }
}

.guard-note {
  border-radius: var(--r-md);
  padding: 10px 13px;
}

.guard-note .gi {
  flex-shrink: 0;
  font-weight: 700;
  line-height: 1.4;
}

.guard-info {
  --gc: var(--status-info);
}

.guard-warn {
  --gc: var(--status-warn);
}

.guard-risk {
  --gc: var(--status-risk);
}

.guard-mod {
  --gc: var(--mod);
}

.hx-backdrop {
  z-index: var(--z-backdrop);
  background: var(--overlay-backdrop);
  justify-content: center;
  align-items: center;
  padding: 24px;
  display: flex;
  position: fixed;
  inset: 0;
}

.hx-dialog {
  --dc: var(--status-warn);
  z-index: var(--z-overlay);
  background: var(--white);
  border-radius: var(--r-lg);
  width: 440px;
  max-width: 94vw;
  box-shadow: var(--shadow-pop);
  position: relative;
  overflow: hidden;
}

.hx-dialog-hd {
  align-items: flex-start;
  gap: 13px;
  padding: 18px 20px 6px;
  display: flex;
}

.hx-dialog-ic {
  border-radius: var(--r-md);
  background: var(--dc);
  flex-shrink: 0;
  justify-content: center;
  align-items: center;
  width: 36px;
  height: 36px;
  font-size: 18px;
  font-weight: 700;
  display: flex;
}

@supports (color: color-mix(in lab, red, red)) {
  .hx-dialog-ic {
    background: color-mix(in srgb, var(--dc) 15%, var(--white));
  }
}

.hx-dialog-ic {
  color: var(--dc);
}

.hx-dialog-hd .hx-t {
  color: var(--ink);
  padding-top: 7px;
  font-size: 15.5px;
  font-weight: 600;
}

.hx-dialog-bd {
  color: var(--ink-3);
  padding: 4px 20px 16px 69px;
  font-size: 13px;
  line-height: 1.5;
}

.hx-dialog-ft {
  border-top: 1px solid var(--rule-soft);
  background: var(--paper);
  justify-content: flex-end;
  gap: 10px;
  padding: 13px 20px;
  display: flex;
}

.hx-dialog.is-info {
  --dc: var(--status-info);
}

.hx-dialog.is-warn {
  --dc: var(--status-warn);
}

.hx-dialog.is-danger {
  --dc: var(--status-risk);
}

.btn-danger:hover {
  background: var(--status-risk-deep);
  border-color: var(--status-risk-deep);
}

.hx-toaster {
  z-index: var(--z-toast);
  pointer-events: none;
  flex-direction: column;
  align-items: center;
  gap: 9px;
  display: flex;
  position: fixed;
  bottom: 24px;
  left: 50%;
  transform: translateX(-50%);
}

.hx-toast {
  --tc: var(--ink-3);
  pointer-events: auto;
  background: var(--ink);
  color: var(--white);
  border-radius: var(--r-md);
  box-shadow: var(--shadow-pop);
  border-left: 3px solid var(--tc);
  align-items: center;
  gap: 12px;
  min-width: 300px;
  max-width: 460px;
  padding: 10px 12px 10px 14px;
  font-size: 13px;
  display: flex;
}

.hx-toast .t-msg {
  flex: 1;
}

.hx-toast .t-act {
  color: var(--white);
  cursor: pointer;
  font-weight: 600;
  font-family: var(--font);
  white-space: nowrap;
  background: none;
  border: none;
  font-size: 13px;
  text-decoration: underline;
}

.hx-toast .t-x:hover {
  opacity: 1;
}

.hx-toast.is-ok {
  --tc: var(--status-ok);
}

.hx-toast.is-warn {
  --tc: var(--status-warn);
}

.hx-toast.is-risk {
  --tc: var(--status-risk);
}

.hx-toast.is-undo {
  --tc: var(--mod);
}

.meter {
  margin-bottom: 10px;
}

.meter:last-child {
  margin-bottom: 0;
}

.meter-head {
  font-family: var(--mono);
  color: var(--ink-4);
  justify-content: space-between;
  gap: 10px;
  margin-bottom: 5px;
  font-size: 11px;
  display: flex;
}

.meter-track {
  background: var(--rule);
  border-radius: 99px;
  height: 6px;
  overflow: hidden;
}

.meter-fill {
  background: var(--mod);
  border-radius: 99px;
  height: 100%;
}

.meter.is-empty .meter-head {
  color: var(--ink-4);
}

.meter.is-empty .meter-track {
  background: var(--rule-soft);
  box-shadow: inset 0 0 0 1px var(--rule);
}

.meter.is-over .meter-fill {
  background: var(--status-risk);
}

.meter.is-over .meter-head {
  color: var(--status-risk-deep);
  font-weight: 600;
}

.bar-cell {
  align-items: center;
  gap: 10px;
  display: flex;
}

.bar-num {
  font-family: var(--mono);
  color: var(--ink-3);
  width: 38px;
  font-size: 11px;
}

.bar-mini {
  background: var(--rule);
  border-radius: 99px;
  flex-shrink: 0;
  width: 120px;
  height: 6px;
  overflow: hidden;
}

.bar-mini > i {
  background: var(--mod);
  border-radius: 99px;
  height: 100%;
  display: block;
}

.bar-mini.is-warn > i {
  background: var(--status-warn);
}

.bar-mini.is-risk > i {
  background: var(--status-risk);
}

.stackbar {
  border: 1px solid var(--rule);
  border-radius: var(--r-sm);
  background: var(--rule);
  height: 26px;
  display: flex;
  overflow: hidden;
}

.stackbar-seg {
  font-family: var(--mono);
  color: var(--white);
  justify-content: center;
  align-items: center;
  min-width: 0;
  font-size: 10px;
  font-weight: 600;
  transition: width .3s;
  display: flex;
}

.stackbar-seg.open {
  background: var(--rule);
  color: var(--ink-4);
}

.stackbar.is-mini {
  border: none;
  border-radius: 99px;
  width: 120px;
  height: 6px;
}

.stackbar.is-mini .stackbar-seg {
  font-size: 0;
}

.loadbar {
  background: var(--white);
  border: 1px solid var(--rule);
  border-radius: var(--r-md);
  flex-wrap: wrap;
  align-items: center;
  gap: 14px;
  padding: 10px 14px;
  display: flex;
}

.loadbar-title {
  font-family: var(--mono);
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--ink-4);
  font-size: 9px;
}

.load {
  color: var(--ink-2);
  align-items: center;
  gap: 7px;
  font-size: 12px;
  display: inline-flex;
}

.load-c {
  font-family: var(--mono);
  color: var(--ink-4);
  font-size: 11px;
}

.load-c.is-over {
  color: var(--status-risk-deep);
  font-weight: 600;
}

.loadbar.is-list {
  flex-direction: column;
  align-items: stretch;
  gap: 0;
  padding: 4px 14px;
}

.loadbar.is-list .load {
  border-top: 1px solid var(--rule-soft);
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 10px;
  width: 100%;
  padding: 9px 0;
  display: grid;
}

.loadbar.is-list .load:first-of-type {
  border-top: none;
}

.loadbar.is-list .load .nm {
  text-overflow: ellipsis;
  white-space: nowrap;
  min-width: 0;
  overflow: hidden;
}

.loadbar.is-list .load .meter {
  min-width: 90px;
  margin: 0;
}

.hx-drawer-backdrop {
  z-index: var(--z-backdrop);
  background: var(--overlay-backdrop-light);
  opacity: 0;
  pointer-events: none;
  transition: opacity var(--transition-backdrop);
  position: fixed;
  inset: 0;
}

.hx-drawer-backdrop.is-open {
  opacity: 1;
  pointer-events: auto;
}

.hx-drawer {
  z-index: var(--z-overlay);
  width: min(var(--drawer-width), 100%);
  background: var(--overlay-bg);
  box-shadow: var(--overlay-shadow);
  transition: transform var(--transition-drawer-in);
  flex-direction: column;
  display: flex;
  position: fixed;
  top: 0;
  bottom: 0;
  right: 0;
  transform: translateX(100%);
}

.hx-drawer.is-open {
  transform: none;
}

.hx-drawer.is-wide {
  width: min(var(--drawer-width-wide), 100%);
}

.hx-drawer.is-detail {
  width: min(var(--drawer-width-detail), 100%);
}

.hx-drawer-hd {
  border-bottom: 1px solid var(--overlay-hairline);
  flex: none;
  align-items: center;
  gap: 11px;
  padding: 16px 20px;
  display: flex;
}

.hx-drawer-ic {
  border-radius: var(--r-sm);
  background: var(--mod-soft);
  width: 30px;
  height: 30px;
  color: var(--mod-deep);
  flex: none;
  justify-content: center;
  align-items: center;
  display: flex;
}

.hx-drawer-hd .hx-t {
  color: var(--ink);
  font-size: 15px;
  font-weight: 600;
}

.hx-drawer-hd .hx-s {
  font-family: var(--mono);
  color: var(--ink-4);
  margin-top: 1px;
  font-size: 11px;
}

.hx-drawer-x {
  border: 1px solid var(--rule);
  border-radius: var(--r-sm);
  background: var(--white);
  width: 30px;
  height: 30px;
  color: var(--ink-3);
  cursor: pointer;
  justify-content: center;
  align-items: center;
  margin-left: auto;
  font-size: 14px;
  display: flex;
}

.hx-drawer-x:hover {
  border-color: var(--ink-4);
  color: var(--ink);
}

.hx-drawer-bd {
  flex-direction: column;
  flex: auto;
  gap: 15px;
  padding: 18px 20px;
  display: flex;
  overflow-y: auto;
}

.hx-drawer-ft {
  border-top: 1px solid var(--overlay-hairline);
  flex: none;
  align-items: center;
  gap: 10px;
  padding: 13px 20px;
  display: flex;
}

.field {
  flex-direction: column;
  gap: 6px;
  display: flex;
}

.field-label {
  color: var(--ink-2);
  align-items: center;
  font-size: 12px;
  font-weight: 500;
  display: flex;
}

.field-label .opt {
  color: var(--ink-4);
  font-weight: 400;
  font-family: var(--mono);
  margin-left: 5px;
  font-size: 10px;
}

.hx-detail {
  grid-template-columns: 1fr 200px;
  align-items: start;
  gap: 20px;
  display: grid;
}

.hx-detail-main {
  flex-direction: column;
  gap: 20px;
  min-width: 0;
  display: flex;
}

.hx-detail-meta {
  background: var(--white);
  border: 1px solid var(--rule);
  border-radius: var(--r-lg);
  flex-direction: column;
  align-self: start;
  gap: 0;
  padding: 2px 15px;
  display: flex;
}

.hx-detail-meta > div {
  border-top: 1px solid var(--rule-soft);
  padding: 14px 0;
}

.hx-detail-meta > div:first-child {
  border-top: none;
}

.sec-h {
  font-family: var(--mono);
  letter-spacing: .11em;
  text-transform: uppercase;
  color: var(--ink-3);
  margin-bottom: 9px;
  font-size: 9.5px;
  font-weight: 600;
}

.sec-row {
  align-items: center;
  gap: 8px;
  display: flex;
}

.sec-mk {
  font-family: var(--mono);
  color: var(--ink-4);
  font-size: 10px;
}

.sec-sep {
  background: var(--rule);
  height: 1px;
  margin: 15px 0;
}

.fold-head {
  cursor: pointer;
  text-align: left;
  background: none;
  border: none;
  align-items: center;
  gap: 8px;
  width: 100%;
  padding: 4px 0;
  font-family: inherit;
  display: flex;
}

.fold-head:hover .sec-h {
  color: var(--ink-3);
}

.fold-body {
  flex-direction: column;
  gap: 10px;
  display: flex;
}

.ai-callout {
  background: #f5f3fd;
}

@supports (color: color-mix(in lab, red, red)) {
  .ai-callout {
    background: color-mix(in srgb, var(--ai) 7%, var(--white));
  }
}

.ai-callout {
  border: 1px solid #dfdbf8;
}

@supports (color: color-mix(in lab, red, red)) {
  .ai-callout {
    border: 1px solid color-mix(in srgb, var(--ai) 22%, var(--white));
  }
}

.ai-callout {
  border-left: 3px solid var(--ai);
  border-radius: var(--r-md);
  padding: 13px 15px;
}

.ai-panel {
  border: 1px solid #dcd7f8;
}

@supports (color: color-mix(in lab, red, red)) {
  .ai-panel {
    border: 1px solid color-mix(in srgb, var(--ai) 24%, var(--white));
  }
}

.ai-panel {
  background: var(--ai-tint);
  border-radius: var(--r-md);
  padding: 12px 13px;
}

.ai-panel-h {
  color: var(--ai-deep);
  align-items: center;
  gap: 7px;
  margin-bottom: 5px;
  font-size: 12.5px;
  font-weight: 600;
  display: flex;
}

.ai-panel-d {
  color: var(--ink-2);
  font-size: 12px;
  line-height: 1.55;
}

.jump-link {
  color: var(--mod-deep);
  cursor: pointer;
  align-items: center;
  gap: 5px;
  font-size: 12px;
  text-decoration: none;
  display: inline-flex;
}

.jump-link:hover {
  text-decoration: underline;
}

.ident-preview {
  background: var(--paper-2);
  border: 1px dashed var(--rule);
  border-radius: var(--r-sm);
  align-items: center;
  gap: 9px;
  padding: 9px 11px;
  display: flex;
}

.ident-preview .iv {
  font-family: var(--mono);
  color: var(--ink-2);
  font-size: 13px;
  font-weight: 600;
}

.ident-preview .ih {
  color: var(--ink-4);
  margin-left: auto;
  font-size: 11px;
}

.segctl {
  gap: 6px;
  display: flex;
}

.segctl button {
  font-family: var(--font);
  color: var(--ink-2);
  background: var(--white);
  border: 1px solid var(--rule);
  border-radius: var(--r-sm);
  cursor: pointer;
  flex: 1;
  padding: 8px 6px;
  font-size: 12.5px;
}

.segctl button:hover {
  border-color: var(--ink-4);
}

.segctl button.is-on {
  background: var(--mod-soft);
  border-color: var(--mod);
  color: var(--mod-deep);
  font-weight: 600;
}

.filter-bar {
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
  display: flex;
}

.filter-chip {
  font-family: var(--mono);
  border: 1px solid var(--rule);
  background: var(--white);
  color: var(--ink-3);
  cursor: pointer;
  border-radius: 99px;
  align-items: center;
  gap: 6px;
  padding: 4px 11px;
  font-size: 11px;
  display: inline-flex;
}

.filter-chip:hover {
  border-color: var(--ink-4);
}

.filter-chip.is-on {
  background: var(--mod);
  color: var(--white);
  border-color: var(--mod);
}

.filter-chip .n {
  opacity: .75;
  font-size: 10px;
}

.switch {
  --sw: var(--mod);
  background: var(--ink-4);
  cursor: pointer;
  border: none;
  border-radius: 99px;
  flex-shrink: 0;
  width: 40px;
  height: 23px;
  padding: 0;
  transition: background .15s;
  position: relative;
}

.switch:after {
  content: "";
  background: var(--white);
  border-radius: 99px;
  width: 19px;
  height: 19px;
  transition: transform .15s;
  position: absolute;
  top: 2px;
  left: 2px;
}

.switch.is-on {
  background: var(--sw);
}

.switch.is-on:after {
  transform: translateX(17px);
}

.switch.is-ai {
  --sw: var(--ai-deep);
}

.combo {
  position: relative;
}

.combo-pop {
  z-index: var(--z-picker);
  background: var(--white);
  border: 1px solid var(--rule);
  border-radius: var(--r-sm);
  box-shadow: var(--shadow-pop);
  max-height: 196px;
  padding: 4px;
  display: none;
  position: absolute;
  top: calc(100% + 4px);
  left: 0;
  right: 0;
  overflow-y: auto;
}

.combo-pop.is-open {
  display: block;
}

.combo-opt {
  border-radius: var(--r-sm);
  cursor: pointer;
  align-items: center;
  gap: 9px;
  padding: 7px 9px;
  display: flex;
}

.combo-opt:hover, .combo-opt.is-active {
  background: var(--mod-soft);
}

.combo-opt .av {
  background: var(--mod);
  width: 24px;
  height: 24px;
  color: var(--white);
  border-radius: 99px;
  flex-shrink: 0;
  justify-content: center;
  align-items: center;
  font-size: 10px;
  font-weight: 600;
  display: flex;
}

.combo-opt .nm {
  color: var(--ink);
  font-size: 13px;
}

.combo-opt .rl {
  color: var(--ink-4);
  margin-left: auto;
  font-size: 11px;
}

.combo-empty {
  color: var(--ink-4);
  padding: 10px 9px;
  font-size: 12px;
  line-height: 1.5;
}

.combo-empty a {
  color: var(--mod-deep);
  cursor: pointer;
  font-weight: 500;
}

.combo-empty a:hover {
  text-decoration: underline;
}

.combo-sel {
  border: 1px solid var(--rule);
  border-radius: var(--r-sm);
  background: var(--paper);
  align-items: center;
  gap: 9px;
  min-width: 0;
  padding: 7px 10px;
  display: flex;
}

.combo-sel .rc-dot {
  background: var(--rc-tone, var(--mod));
  border-radius: 50%;
  flex-shrink: 0;
  width: 8px;
  height: 8px;
}

.combo-sel .rc-nm {
  color: var(--ink);
  white-space: nowrap;
  text-overflow: ellipsis;
  font-size: 13px;
  font-weight: 500;
  overflow: hidden;
}

.combo-sel .rc-id {
  font-family: var(--mono);
  color: var(--ink-4);
  flex-shrink: 0;
  font-size: 11px;
}

.combo-sel .rc-x {
  cursor: pointer;
  color: var(--ink-4);
  background: none;
  border: none;
  flex-shrink: 0;
  margin-left: auto;
  padding: 2px;
}

.combo-sel .rc-x:hover {
  color: var(--ink);
}

.combo-sel.is-freeform {
  background: var(--white);
  border-style: dashed;
}

.combo-sel.is-freeform .rc-dot {
  background: var(--ink-4);
}

.src-tag {
  font-family: var(--mono);
  letter-spacing: .04em;
  text-transform: uppercase;
  color: var(--white);
  background: var(--st-tone, var(--ink-4));
  border-radius: 4px;
  flex-shrink: 0;
  padding: 2px 6px;
  font-size: 8.5px;
  font-weight: 700;
}

.src-wiki {
  --st-tone: var(--label-azure);
}

.src-pol {
  --st-tone: var(--label-violet);
}

.src-cmdb {
  --st-tone: var(--label-slate);
}

.src-sa {
  --st-tone: var(--label-teal);
}

.src-doc {
  --st-tone: var(--label-bronze);
}

.src-url {
  --st-tone: var(--label-green);
}

.ref-manage {
  border-radius: var(--r-sm);
  border: 1px solid var(--rule);
  background: var(--white);
  cursor: pointer;
  font: inherit;
  color: var(--ink-2);
  align-items: center;
  gap: 8px;
  padding: 4px 9px 4px 7px;
  font-size: 12px;
  display: inline-flex;
}

.ref-manage:hover {
  border-color: var(--mod, var(--brand-primary));
}

.ref-strip {
  display: inline-flex;
}

.ref-strip .ref-dot {
  border: 1.5px solid var(--white);
  background: var(--st-tone, var(--ink-4));
  border-radius: 50%;
  width: 9px;
  height: 9px;
  margin-left: -3px;
}

.rm-count {
  color: var(--ink-3);
  font-size: 11.5px;
}

.rm-add {
  color: var(--ink-3);
  font-size: 12px;
}

.ref-manage:hover .rm-add {
  color: var(--mod-deep, var(--brand-primary-deep));
}

.ref-item {
  border: 1px solid var(--rule);
  border-radius: var(--r-sm);
  background: var(--white);
  align-items: center;
  gap: 9px;
  padding: 9px 11px;
  display: flex;
}

.ref-item .ri-main {
  flex: 1;
  min-width: 0;
}

.ref-item .ri-label {
  color: var(--ink);
  white-space: nowrap;
  text-overflow: ellipsis;
  font-size: 13px;
  font-weight: 500;
  overflow: hidden;
}

.ref-item .ri-meta {
  font-family: var(--mono);
  color: var(--ink-4);
  margin-top: 2px;
  font-size: 10px;
}

.ref-item .ri-x {
  cursor: pointer;
  color: var(--ink-4);
  background: none;
  border: none;
  flex-shrink: 0;
  margin-left: auto;
  padding: 3px;
}

.ref-item .ri-x:hover {
  color: var(--status-risk-deep);
}

.ai-orb {
  background: radial-gradient(circle at 32% 28%, var(--ai-bright), var(--ai));
  color: var(--white);
}

.chat {
  flex-direction: column;
  gap: 16px;
  display: flex;
}

.chat-msg {
  gap: 11px;
  max-width: 760px;
  display: flex;
}

.chat-msg.is-me {
  flex-direction: row-reverse;
  align-self: flex-end;
}

.chat-av {
  border-radius: 50%;
  flex-shrink: 0;
  justify-content: center;
  align-items: center;
  width: 30px;
  height: 30px;
  font-size: 14px;
  display: flex;
}

.chat-av.is-ai {
  background: radial-gradient(circle at 32% 28%, var(--ai-bright), var(--ai));
  color: var(--white);
}

.chat-av.is-me {
  background: var(--mod);
  color: var(--white);
  font-size: 11px;
  font-weight: 600;
}

.chat-who {
  font-family: var(--mono);
  letter-spacing: .06em;
  text-transform: uppercase;
  color: var(--ink-4);
  margin-bottom: 5px;
  font-size: 9px;
}

.chat-bubble {
  background: var(--white);
  border: 1px solid var(--rule);
  color: var(--ink-2);
  border-radius: 4px 12px 12px;
  padding: 12px 15px;
  font-size: 13.5px;
  line-height: 1.55;
}

.chat-bubble p + p {
  margin-top: 8px;
}

.chat-msg.is-me .chat-bubble {
  background: var(--mod-soft);
  border-color: var(--mod);
}

@supports (color: color-mix(in lab, red, red)) {
  .chat-msg.is-me .chat-bubble {
    border-color: color-mix(in srgb, var(--mod) 22%, var(--rule));
  }
}

.chat-msg.is-me .chat-bubble {
  color: var(--mod-deep);
  border-radius: 12px 4px 12px 12px;
}

.actcard {
  border: 1px solid #cbc3e0;
  margin-top: 11px;
}

@supports (color: color-mix(in lab, red, red)) {
  .actcard {
    border: 1px solid color-mix(in srgb, var(--ai) 26%, var(--rule));
  }
}

.actcard {
  border-radius: var(--r-md);
  overflow: hidden;
}

.actcard-hd {
  background: var(--ai-soft);
  font-size: 11px;
  font-family: var(--mono);
  letter-spacing: .04em;
  text-transform: uppercase;
  color: var(--ai-deep);
  align-items: center;
  gap: 6px;
  padding: 8px 12px;
  display: flex;
}

.actcard-bd {
  padding: 11px 13px;
}

.actcard-row {
  align-items: center;
  gap: 10px;
  padding: 6px 0;
  display: flex;
}

.actcard-row .nm {
  flex: 1;
  font-size: 13px;
  font-weight: 500;
}

.actcard-ft {
  border-top: 1px solid var(--rule-soft);
  background: var(--paper);
  align-items: center;
  gap: 8px;
  padding: 10px 13px;
  display: flex;
}

.actcard-ft .hint {
  color: var(--ink-4);
  align-items: center;
  gap: 6px;
  font-size: 11px;
  display: flex;
}

.prompt-chips {
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 10px;
  display: flex;
}

.prompt-chip {
  font: inherit;
  color: var(--ai-deep);
  background: var(--ai-soft);
  border: 1px solid #6d5ae038;
  font-size: 12px;
}

@supports (color: color-mix(in lab, red, red)) {
  .prompt-chip {
    border: 1px solid color-mix(in srgb, var(--ai) 22%, transparent);
  }
}

.prompt-chip {
  cursor: pointer;
  border-radius: 99px;
  padding: 5px 12px;
}

.prompt-chip:hover {
  background: #ebe8fb;
}

@supports (color: color-mix(in lab, red, red)) {
  .prompt-chip:hover {
    background: color-mix(in srgb, var(--ai) 14%, var(--white));
  }
}

.composer {
  align-items: flex-end;
  gap: 10px;
  display: flex;
}

.composer-input {
  resize: none;
  border: 1px solid var(--rule);
  border-radius: var(--r-md);
  font-family: var(--font);
  color: var(--ink);
  flex: 1;
  min-height: 44px;
  max-height: 160px;
  padding: 11px 13px;
  font-size: 13.5px;
}

.composer-input:focus {
  border-color: var(--ai);
  box-shadow: 0 0 0 3px var(--ai-soft);
  outline: none;
}

.composer-send {
  border-radius: var(--r-md);
  background: var(--ai);
  height: 44px;
  color: var(--white);
  cursor: pointer;
  border: none;
  flex-shrink: 0;
  align-items: center;
  gap: 7px;
  padding: 0 18px;
  font-size: 13.5px;
  font-weight: 500;
  display: flex;
}

.composer-send:hover {
  background: var(--ai-deep);
}

.threadrail {
  flex-direction: column;
  min-height: 0;
  display: flex;
}

.thread {
  border-radius: var(--r-sm);
  cursor: pointer;
  color: inherit;
  align-items: center;
  gap: 10px;
  padding: 9px 10px;
  text-decoration: none;
  display: flex;
}

.thread:hover {
  background: var(--paper);
}

.thread.is-on {
  background: var(--ai-soft);
}

.thread.is-on .nm {
  color: var(--ai-deep);
}

.thread .dot {
  border-radius: 50%;
  flex-shrink: 0;
  width: 9px;
  height: 9px;
}

.thread .nm {
  color: var(--ink);
  font-size: 13px;
  font-weight: 500;
  line-height: 1.2;
}

.thread .sb {
  font-family: var(--mono);
  color: var(--ink-4);
  margin-top: 2px;
  font-size: 10px;
}

.subtask {
  border-top: 1px solid var(--rule-soft);
  align-items: center;
  gap: 10px;
  padding: 8px 0;
  display: flex;
}

.subtask:first-of-type {
  border-top: none;
}

.subtask.is-done .subtask-title {
  color: var(--ink-4);
  text-decoration: line-through;
}

.subtask.is-overdue .subtask-due {
  color: var(--status-warn-deep);
  font-weight: 600;
}

.subtask-check {
  flex-shrink: 0;
  align-items: center;
  display: flex;
}

.subtask-box {
  border: 1.5px solid var(--rule);
  background: var(--white);
  color: #0000;
  cursor: pointer;
  border-radius: 5px;
  justify-content: center;
  align-items: center;
  width: 18px;
  height: 18px;
  display: flex;
}

.subtask-box.is-on {
  background: var(--mod);
  border-color: var(--mod);
  color: var(--white);
}

.subtask-slider {
  align-items: center;
  gap: 8px;
  display: inline-flex;
}

.subtask-slider input[type="range"] {
  width: 92px;
  height: 14px;
  accent-color: var(--mod);
  cursor: pointer;
  margin: 0;
}

.subtask-slider-v {
  font-family: var(--mono);
  color: var(--mod-deep);
  text-align: right;
  min-width: 36px;
  font-size: 10px;
}

.subtask-count {
  font-family: var(--mono);
  color: var(--mod-deep);
  font-size: 11px;
  font-weight: 600;
}

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

.subtask-title {
  color: var(--ink-2);
  font-size: 12.5px;
}

.subtask-meta {
  font-family: var(--mono);
  color: var(--ink-4);
  align-items: center;
  gap: 8px;
  margin-top: 2px;
  font-size: 10px;
  display: flex;
}

.subtask-due {
  font-family: var(--mono);
  color: var(--ink-4);
  font-size: 10px;
}

.subtask-due.is-over {
  color: var(--status-risk-deep);
  font-weight: 600;
}

.subtask-grip {
  color: var(--ink-4);
  cursor: grab;
  opacity: .4;
  flex-shrink: 0;
  align-items: center;
  transition: opacity .12s, color .12s;
  display: none;
}

.subtask-grip:active {
  cursor: grabbing;
}

.is-editing .subtask:hover .subtask-grip {
  opacity: 1;
  color: var(--ink-3);
}

.is-editing .subtask-grip, .is-editing .subtask-del {
  display: inline-flex;
}

.subtask-del {
  cursor: pointer;
  color: var(--ink-4);
  background: none;
  border: none;
  flex-shrink: 0;
  margin-left: auto;
  padding: 3px;
  display: none;
}

.subtask-del:hover {
  color: var(--status-risk-deep);
}

.subtask.dragging {
  opacity: .45;
}

.subtask-ring {
  font-family: var(--mono);
  color: var(--ink-3);
  align-items: center;
  gap: 8px;
  font-size: 11px;
  display: inline-flex;
}

.subtask-ring .ring {
  background: conic-gradient(var(--mod) calc(var(--p, 0)*1%), var(--rule) 0);
  border-radius: 50%;
  flex-shrink: 0;
  width: 20px;
  height: 20px;
}

.subtask.is-deleted {
  opacity: .55;
}

.subtask.is-deleted .subtask-title {
  color: var(--ink-4);
  text-decoration: line-through;
}

.subtask-deleted-tag {
  font-family: var(--mono);
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--ink-4);
  border: 1px solid var(--rule);
  border-radius: 99px;
  padding: 0 5px;
  font-size: 8.5px;
}

.subtask-restore {
  cursor: pointer;
  font-family: var(--mono);
  color: var(--mod-deep);
  background: none;
  border: none;
  padding: 0;
  font-size: 10px;
}

.subtask-restore:hover {
  text-decoration: underline;
}

.subtask-warn {
  border-radius: var(--r-md);
  background: var(--status-warn-soft);
  border: 1px solid #efe5ce;
  align-items: flex-start;
  gap: 8px;
  margin-top: 9px;
  padding: 9px 11px;
  display: flex;
}

@supports (color: color-mix(in lab, red, red)) {
  .subtask-warn {
    border: 1px solid color-mix(in srgb, var(--status-warn) 30%, var(--white));
  }
}

.subtask-warn {
  color: var(--status-warn-deep);
  font-size: 12px;
  line-height: 1.45;
}

.subtask-warn > .ico {
  flex-shrink: 0;
  margin-top: 1px;
  font-size: 14px;
}

.subtask-add {
  align-items: center;
  gap: 7px;
  margin-top: 9px;
  display: flex;
}

.subtask-add .flt {
  flex: 1;
}

.callout {
  --cc: var(--status-info);
  border: 1px solid var(--cc);
  align-items: flex-start;
  gap: 11px;
  display: flex;
}

@supports (color: color-mix(in lab, red, red)) {
  .callout {
    border: 1px solid color-mix(in srgb, var(--cc) 30%, var(--white));
  }
}

.callout {
  background: var(--cc);
}

@supports (color: color-mix(in lab, red, red)) {
  .callout {
    background: color-mix(in srgb, var(--cc) 9%, var(--white));
  }
}

.callout {
  border-radius: var(--r-md);
  padding: 12px 13px;
}

.callout.is-active {
  border-color: var(--cc);
  box-shadow: 0 0 0 3px var(--cc);
}

@supports (color: color-mix(in lab, red, red)) {
  .callout.is-active {
    box-shadow: 0 0 0 3px color-mix(in srgb, var(--cc) 16%, transparent);
  }
}

.callout .co-tx {
  flex: 1;
  min-width: 0;
}

.callout .co-h {
  color: var(--cc);
  font-size: 12.5px;
  font-weight: 600;
}

@supports (color: color-mix(in lab, red, red)) {
  .callout .co-h {
    color: color-mix(in srgb, var(--cc) 72%, black);
  }
}

.callout .co-h {
  align-items: center;
  gap: 6px;
  display: flex;
}

.callout .co-d {
  color: var(--cc);
  font-size: 11.5px;
}

@supports (color: color-mix(in lab, red, red)) {
  .callout .co-d {
    color: color-mix(in srgb, var(--cc) 80%, black);
  }
}

.callout .co-d {
  margin-top: 3px;
  line-height: 1.5;
}

.callout.is-ai {
  --cc: var(--ai);
}

.callout.is-ai .co-h, .callout.is-ai .co-d {
  color: var(--ai-deep);
}

.callout.is-warn {
  --cc: var(--status-warn);
}

.callout.is-risk {
  --cc: var(--status-risk);
}

.timeline {
  flex-direction: column;
  display: flex;
}

.stepper {
  align-items: center;
  gap: 0;
  display: flex;
}

.step {
  color: var(--step-todo);
  white-space: nowrap;
  align-items: center;
  gap: 9px;
  display: flex;
}

.step-num {
  border: 1.5px solid;
  border-radius: 99px;
  flex-shrink: 0;
  justify-content: center;
  align-items: center;
  width: 26px;
  height: 26px;
  font-size: 12px;
  font-weight: 600;
  display: flex;
}

.step-label {
  font-size: 13px;
  font-weight: 500;
}

.step-link {
  background: var(--step-rail);
  flex: 1;
  min-width: 24px;
  height: 1px;
  margin: 0 14px;
}

.step.is-current {
  color: var(--step-current);
}

.step.is-current .step-num {
  border-color: var(--step-current);
  box-shadow: 0 0 0 3px var(--mod);
}

@supports (color: color-mix(in lab, red, red)) {
  .step.is-current .step-num {
    box-shadow: 0 0 0 3px color-mix(in srgb, var(--mod) 18%, transparent);
  }
}

.step.is-done {
  color: var(--step-done);
}

.step.is-done .step-num {
  background: var(--step-done);
  border-color: var(--step-done);
  color: var(--white);
}

.step.is-done + .step-link {
  background: var(--step-rail-done);
}

.sidenav {
  background: var(--white);
  border: 1px solid var(--rule);
  border-radius: var(--r-md);
  flex-shrink: 0;
  width: 232px;
  overflow: hidden;
}

.sidenav.is-sticky {
  position: sticky;
  top: 14px;
}

.sidenav-title {
  font-family: var(--mono);
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--ink-4);
  padding: 11px 14px 6px;
  font-size: 9px;
}

.sidenav-group {
  padding: 0 6px 8px;
}

.sidenav-group-label {
  font-family: var(--mono);
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--ink-4);
  padding: 8px 8px 4px;
  font-size: 9px;
}

.sidenav-item {
  border-radius: var(--r-sm);
  color: var(--ink-2);
  cursor: pointer;
  text-align: left;
  width: 100%;
  font-size: 12.5px;
  font-family: var(--font);
  background: none;
  border: none;
  align-items: center;
  gap: 8px;
  padding: 7px 9px;
  text-decoration: none;
  display: flex;
}

.sidenav-item:hover {
  background: var(--paper);
  color: var(--ink);
}

.sidenav-item.is-active {
  background: var(--mod-soft);
  color: var(--mod-deep);
  font-weight: 500;
}

.sidenav-item .sn-ic {
  opacity: .7;
  flex-shrink: 0;
  width: 15px;
  height: 15px;
}

.sidenav-item.is-active .sn-ic {
  opacity: 1;
}

.sidenav-item .sn-dot {
  background: var(--ink-4);
  border-radius: 2px;
  flex-shrink: 0;
  width: 7px;
  height: 7px;
}

.sidenav-item.is-active .sn-dot {
  background: var(--mod);
}

.sidenav-badge {
  font-family: var(--mono);
  background: var(--paper-2);
  color: var(--ink-4);
  text-align: center;
  border-radius: 9px;
  min-width: 16px;
  margin-left: auto;
  padding: 1px 6px;
  font-size: 10px;
}

.sidenav-item.is-active .sidenav-badge {
  background: var(--mod);
  color: var(--white);
}

.sidenav-soon {
  font-family: var(--mono);
  letter-spacing: .03em;
  color: var(--ink-4);
  border: 1px solid var(--rule);
  border-radius: 99px;
  margin-left: auto;
  padding: 1px 6px;
  font-size: 8.5px;
}

.sidenav-item.is-disabled {
  color: var(--ink-4);
  cursor: default;
}

.sidenav-item.is-disabled:hover {
  background: none;
}

.sidenav-divider {
  background: var(--rule-soft);
  height: 1px;
  margin: 4px 8px;
}

.sidenav-note {
  color: var(--ink-4);
  border-top: 1px solid var(--rule-soft);
  padding: 10px 12px;
  font-size: 11px;
  line-height: 1.5;
}

.sidenav-note b {
  color: var(--ink-3);
}

.overview {
  grid-template-columns: 1fr 320px;
  align-items: start;
  gap: 20px;
  display: grid;
}

.overview-main {
  flex-direction: column;
  gap: 22px;
  min-width: 0;
  display: flex;
}

.overview-rail {
  flex-direction: column;
  gap: 16px;
  display: flex;
}

.overview-rail.is-sticky {
  position: sticky;
  top: 14px;
}

.ov-sec-head {
  align-items: center;
  gap: 10px;
  margin-bottom: 11px;
  display: flex;
}

.ov-sec-head .h {
  color: var(--ink);
  font-size: 14px;
  font-weight: 600;
}

.ov-sec-head .c {
  font-family: var(--mono);
  color: var(--ink-4);
  font-size: 10px;
}

.ov-sec-head .more {
  color: var(--mod-deep);
  margin-left: auto;
  font-size: 12px;
  font-weight: 500;
  text-decoration: none;
}

.ov-sec-head .more:hover {
  text-decoration: underline;
}

.ov-row {
  background: var(--white);
  border: 1px solid var(--rule);
  border-radius: var(--r-md);
  color: inherit;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 13px;
  padding: 11px 14px;
  text-decoration: none;
  display: grid;
}

.ov-row + .ov-row {
  margin-top: 7px;
}

.ov-row:hover {
  border-color: var(--ink-4);
}

.ov-row .pdot {
  border-radius: 50%;
  flex-shrink: 0;
  width: 9px;
  height: 9px;
}

.ov-row .nm {
  color: var(--ink);
  letter-spacing: -.005em;
  font-size: 13.5px;
  font-weight: 600;
}

.ov-row .rw {
  flex-wrap: wrap;
  align-items: center;
  gap: 9px;
  margin-top: 6px;
  display: flex;
}

.ov-row .m {
  font-family: var(--mono);
  color: var(--ink-4);
  align-items: center;
  gap: 4px;
  font-size: 10px;
  display: inline-flex;
}

.ov-row .m.is-due {
  color: var(--status-risk-deep);
}

.ov-row .rt {
  flex-shrink: 0;
  align-items: center;
  gap: 13px;
  display: flex;
}

.ov-links {
  flex-direction: column;
  gap: 2px;
  display: flex;
}

.ov-link {
  border-radius: var(--r-sm);
  color: var(--ink-2);
  align-items: center;
  gap: 11px;
  padding: 9px 10px;
  text-decoration: none;
  display: flex;
}

.ov-link:hover {
  background: var(--paper);
}

.ov-link .ic {
  border-radius: var(--r-sm);
  background: var(--mod-soft);
  width: 30px;
  height: 30px;
  color: var(--mod-deep);
  flex-shrink: 0;
  justify-content: center;
  align-items: center;
  display: flex;
}

.ov-link .ic svg {
  width: 15px;
  height: 15px;
}

.ov-link .tx {
  min-width: 0;
}

.ov-link .t {
  color: var(--ink);
  font-size: 13px;
  font-weight: 500;
}

.ov-link .d {
  color: var(--ink-4);
  font-size: 11px;
}

.ov-link .ct {
  font-family: var(--mono);
  color: var(--ink-4);
  margin-left: auto;
  font-size: 11px;
}

.avatar-sm {
  width: 24px;
  height: 24px;
  color: var(--white);
  background: var(--mod);
  border-radius: 50%;
  flex-shrink: 0;
  justify-content: center;
  align-items: center;
  font-size: 10px;
  font-weight: 600;
  display: flex;
}

.ai-gated {
  transition: opacity .15s;
  position: relative;
}

[data-ai="off"] .ai-gated {
  opacity: .5;
  filter: grayscale(.55);
  pointer-events: none;
}

[data-ai="off"] .ai-on-only {
  display: none !important;
}

.ai-off-note {
  color: var(--status-warn-deep);
  background: var(--status-warn-soft);
  border: 1px solid #efe5ce;
  align-items: flex-start;
  gap: 8px;
  font-size: 11.5px;
  line-height: 1.45;
  display: none;
}

@supports (color: color-mix(in lab, red, red)) {
  .ai-off-note {
    border: 1px solid color-mix(in srgb,var(--status-warn) 30%,var(--white));
  }
}

.ai-off-note {
  border-radius: var(--r-sm);
  margin-top: 8px;
  padding: 8px 10px;
}

[data-ai="off"] .ai-off-note {
  display: flex;
}

.ai-off-note b {
  font-weight: 600;
}

.ai-mark {
  font-family: var(--mono);
  letter-spacing: .04em;
  color: var(--ai-deep);
  background: var(--ai-soft);
  vertical-align: middle;
  border-radius: 99px;
  align-items: center;
  gap: 4px;
  padding: 2px 7px;
  font-size: 9px;
  font-weight: 600;
  display: none;
}

[data-markers="on"] .ai-mark {
  display: inline-flex;
}

.ai-mark:before {
  content: "✦";
  font-size: 9px;
}

.ai-pulse {
  background: var(--ai);
  border-radius: 50%;
  flex-shrink: 0;
  width: 9px;
  height: 9px;
  animation: 1.5s ease-in-out infinite ai-pulse-core;
  display: inline-block;
  position: relative;
}

.ai-pulse:after {
  content: "";
  background: var(--ai);
  border-radius: 50%;
  animation: 1.5s ease-out infinite ai-pulse;
  position: absolute;
  inset: 0;
}

.prov {
  font-family: var(--mono);
  letter-spacing: .04em;
  text-transform: uppercase;
  white-space: nowrap;
  border-radius: 99px;
  align-items: center;
  gap: 4px;
  padding: 2px 7px;
  font-size: 9px;
  display: inline-flex;
}

.prov-inherited {
  color: var(--ink-4);
  background: var(--paper-2);
}

.prov-inherited:before {
  content: "↳";
  opacity: .7;
}

.prov-override {
  color: var(--mod-deep);
  background: var(--mod-soft);
}

.prov-override:before {
  content: "◉";
}

.prov-own {
  color: var(--ink-3);
  background: var(--rule-soft);
}

.is-overridden {
  box-shadow: inset 3px 0 0 var(--mod);
}

.is-inherited {
  opacity: .82;
}

.prov-reset {
  font-family: var(--mono);
  color: var(--mod-deep);
  cursor: pointer;
  background: none;
  border: none;
  padding: 0 2px;
  font-size: 10px;
}

.prov-reset:before {
  content: "↺ ";
}

.prov-reset:hover {
  text-decoration: underline;
}

.ie-wrap {
  display: inline-flex;
  position: relative;
}

.ie-trigger {
  font: inherit;
  text-align: left;
  border-radius: var(--r-sm);
  cursor: pointer;
  color: inherit;
  background: none;
  border: 1px solid #0000;
  align-items: flex-start;
  gap: 6px;
  margin: -2px -6px;
  padding: 2px 6px;
  transition: background .12s, border-color .12s;
  display: inline-flex;
}

.ie-trigger:hover {
  background: var(--mod-soft);
  border-color: var(--rule);
}

.ie-trigger.is-open {
  background: var(--mod-soft);
  border-color: var(--mod);
}

.ie-pen {
  opacity: 0;
  color: var(--mod);
  flex-shrink: 0;
  margin-top: 1px;
  transition: opacity .12s;
}

.ie-trigger:hover .ie-pen, .ie-trigger.is-open .ie-pen {
  opacity: 1;
}

.ie-pen .ico {
  width: 13px;
  height: 13px;
}

.ie-asbtn {
  color: var(--mod-deep);
  font-size: 11.5px;
  font-weight: 500;
}

.ie-pop {
  background: var(--white);
  border: 1px solid var(--rule);
  border-radius: var(--r-md);
  min-width: 248px;
  box-shadow: var(--shadow-pop);
  z-index: var(--z-picker);
  position: absolute;
  top: calc(100% + 6px);
  left: 0;
  overflow: hidden;
}

.ie-pop.to-right {
  left: auto;
  right: 0;
}

.ie-pop.to-up {
  top: auto;
  bottom: calc(100% + 6px);
}

.ie-pop-h {
  font-family: var(--mono);
  letter-spacing: .06em;
  text-transform: uppercase;
  color: var(--ink-4);
  padding: 11px 13px 0;
  font-size: 9px;
}

.ie-pop-bd {
  flex-direction: column;
  gap: 9px;
  padding: 10px 13px;
  display: flex;
}

.ie-pop-ft {
  border-top: 1px solid var(--rule-soft);
  background: var(--paper);
  justify-content: flex-end;
  gap: 7px;
  padding: 9px 13px;
  display: flex;
}

.ie-opt {
  font: inherit;
  text-align: left;
  border: 1px solid var(--rule);
  border-radius: var(--r-sm);
  cursor: pointer;
  color: var(--ink);
  background: none;
  align-items: center;
  padding: 7px 9px;
  display: flex;
}

.ie-opt:hover {
  background: var(--paper);
}

.ie-opt.is-sel {
  border-color: var(--mod);
  background: var(--mod-soft);
}

.t-undo {
  font: inherit;
  color: inherit;
  opacity: .8;
  border-radius: var(--r-sm);
  cursor: pointer;
  background: none;
  border: 1px solid;
  margin-left: 8px;
  padding: 2px 9px;
  font-size: 12px;
  font-weight: 600;
}

.t-undo:hover {
  opacity: 1;
}

.rte {
  border: 1px solid var(--rule);
  border-radius: var(--r-sm);
  background: var(--white);
  overflow: hidden;
}

.rte-bar {
  border-bottom: 1px solid var(--rule);
  background: var(--paper);
  gap: 1px;
  padding: 5px;
  display: flex;
}

.rte-bar button {
  border-radius: var(--r-sm);
  cursor: pointer;
  width: 28px;
  height: 26px;
  color: var(--ink-3);
  background: none;
  border: none;
  justify-content: center;
  align-items: center;
  font-size: 13px;
  display: flex;
}

.rte-bar button:hover {
  background: var(--rule-soft);
  color: var(--ink-2);
}

.rte-bar .rte-sep {
  background: var(--rule);
  width: 1px;
  margin: 3px 2px;
}

.rte-ed {
  min-height: 84px;
  color: var(--ink);
  outline: none;
  padding: 10px 12px;
  font-size: 13px;
  line-height: 1.55;
}

.rte-ed:empty:before {
  content: attr(data-placeholder);
  color: var(--ink-4);
  pointer-events: none;
}

.zravail-label {
  font-family: var(--mono);
  letter-spacing: .06em;
  text-transform: uppercase;
  color: var(--ink-4);
  margin-bottom: 6px;
  font-size: 9px;
}

.zravail {
  background: var(--paper);
  border: 1px solid var(--rule);
  border-radius: var(--r-sm);
  height: 50px;
  position: relative;
  overflow: hidden;
}

.zravail-tick {
  border-left: 1px dashed var(--rule);
  position: absolute;
  top: 0;
  bottom: 0;
}

.zravail-tick-l {
  font-family: var(--mono);
  color: var(--ink-4);
  font-size: 8.5px;
  position: absolute;
  bottom: 2px;
  transform: translateX(3px);
}

.zravail-busy {
  background: repeating-linear-gradient(45deg,var(--rule-soft),var(--rule-soft) 4px,var(--white) 4px,var(--white) 8px);
  border: 1px solid var(--rule);
  height: 20px;
  color: var(--ink-3);
  white-space: nowrap;
  border-radius: 4px;
  align-items: center;
  padding: 0 5px;
  font-size: 9px;
  display: flex;
  position: absolute;
  top: 6px;
  overflow: hidden;
}

.zravail-sel {
  background: var(--mod-soft);
  border: 1.5px solid var(--mod);
  border-radius: 4px;
  height: 15px;
  position: absolute;
  top: 29px;
}

.zravail-sel.is-conflict {
  background: var(--status-risk-soft);
  border-color: var(--status-risk);
}

.zravail-legend {
  flex-wrap: wrap;
  gap: 6px;
  margin-top: 8px;
  display: flex;
}

.share-dlg {
  background: var(--white);
  border: 1px solid var(--rule);
  border-radius: var(--r-lg);
  width: 480px;
  max-width: 92vw;
  max-height: 86vh;
  box-shadow: var(--shadow-pop);
  padding: 20px 22px;
  overflow: auto;
}

.share-hd {
  align-items: center;
  gap: 9px;
  margin-bottom: 4px;
  display: flex;
}

.share-hd h3 {
  color: var(--ink);
  margin: 0;
  font-size: 15px;
  font-weight: 600;
}

.share-hd > .ico {
  color: var(--mod, var(--brand-primary));
}

.share-sub {
  color: var(--ink-3);
  margin-bottom: 14px;
  font-size: 12px;
}

.share-note {
  border-radius: var(--r-sm);
  align-items: flex-start;
  gap: 8px;
  margin-bottom: 16px;
  padding: 8px 11px;
  font-size: 12px;
  line-height: 1.45;
  display: flex;
}

.share-note .ico {
  flex-shrink: 0;
  margin-top: 1px;
}

.share-note.live {
  background: var(--paper-2);
  border: 1px solid var(--rule);
  color: var(--ink-2);
}

.share-note.live .ico {
  color: var(--ink-4);
}

.share-note.snap {
  background: var(--status-warn-soft);
  color: var(--status-warn-deep);
  border: 1px solid #efe5ce;
}

@supports (color: color-mix(in lab, red, red)) {
  .share-note.snap {
    border: 1px solid color-mix(in srgb,var(--status-warn) 30%,var(--white));
  }
}

.share-acc {
  flex-direction: column;
  gap: 8px;
  margin-bottom: 18px;
  display: flex;
}

.share-acc-row {
  align-items: center;
  gap: 9px;
  display: flex;
}

.share-acc-row .who {
  flex: 1;
  min-width: 0;
}

.share-acc-row .nm {
  color: var(--ink-2);
  font-size: 12.5px;
}

.share-acc-row .rl {
  font-family: var(--mono);
  text-transform: uppercase;
  letter-spacing: .03em;
  color: var(--ink-4);
  font-size: 9px;
}

.share-link {
  gap: 8px;
  margin-bottom: 18px;
  display: flex;
}

.share-ft {
  justify-content: flex-end;
  gap: 8px;
  display: flex;
}

.codein {
  font-family: var(--mono);
  align-items: center;
  gap: 7px;
  display: inline-flex;
}

.codein-pre {
  color: var(--ink-3);
  letter-spacing: .08em;
  font-size: 13px;
  font-weight: 600;
}

.codein-sep {
  color: var(--ink-4);
}

.codein-seg {
  text-align: center;
  text-transform: uppercase;
  letter-spacing: .22em;
  width: 74px;
  font-family: var(--mono);
  border: 1px solid var(--rule);
  border-radius: var(--r-sm);
  background: var(--white);
  color: var(--ink);
  padding: 9px 6px;
  font-size: 14px;
}

.codein-seg::placeholder {
  letter-spacing: .22em;
  color: var(--ink-4);
}

.codein-seg:focus {
  border-color: var(--mod, var(--brand-primary));
  box-shadow: 0 0 0 3px var(--mod-soft, var(--brand-primary-soft));
  outline: none;
}

.pipeline {
  grid-template-columns: repeat(var(--pl-cols, 3),1fr);
  align-items: start;
  gap: 16px;
  display: grid;
}

.pl-col {
  flex-direction: column;
  min-width: 0;
  display: flex;
}

.pl-head {
  justify-content: space-between;
  align-items: center;
  padding: 0 4px 10px;
  display: flex;
}

.pl-title {
  color: var(--ink-2);
  align-items: center;
  gap: 8px;
  font-size: 12px;
  font-weight: 600;
  display: flex;
}

.pl-dot {
  background: var(--pl-tone, var(--status-muted));
  border-radius: 50%;
  flex-shrink: 0;
  width: 8px;
  height: 8px;
}

.pl-count {
  font-family: var(--mono);
  color: var(--ink-4);
  font-size: 11px;
}

.pl-body {
  flex-direction: column;
  gap: 10px;
  min-height: 60px;
  display: flex;
}

.pl-empty {
  color: var(--ink-4);
  text-align: center;
  border: 1px dashed var(--rule);
  border-radius: var(--r-lg);
  padding: 22px 0;
  font-size: 12px;
}

.pl-eingang {
  --pl-tone: var(--status-muted);
}

.pl-agenda {
  --pl-tone: var(--status-info);
}

.pl-entschieden {
  --pl-tone: var(--status-ok);
}

.src-chip {
  background: var(--mod-soft);
  color: var(--mod-deep);
  border-radius: 99px;
  align-items: center;
  gap: 5px;
  padding: 2px 8px;
  font-size: 10.5px;
  font-weight: 600;
  display: inline-flex;
}

.src-chip .dot {
  background: var(--mod);
  border-radius: 50%;
  flex-shrink: 0;
  width: 7px;
  height: 7px;
}

.lm-screen {
  z-index: var(--z-overlay);
  background: var(--paper);
  flex-direction: column;
  display: flex;
  position: fixed;
  inset: 0;
}

.lm-top {
  background: var(--white);
  border-bottom: 1px solid var(--rule);
  flex-shrink: 0;
  align-items: center;
  gap: 14px;
  height: 52px;
  padding: 0 20px;
  display: flex;
}

.lm-top-ic {
  background: var(--mod-soft);
  width: 30px;
  height: 30px;
  color: var(--mod-deep);
  border-radius: 8px;
  flex-shrink: 0;
  justify-content: center;
  align-items: center;
  display: flex;
}

.lm-top-tt {
  font-size: 14.5px;
  font-weight: 600;
}

.lm-top-sub {
  font-family: var(--mono);
  color: var(--ink-4);
  margin-top: 1px;
  font-size: 10.5px;
}

.lm-top-prog {
  align-items: center;
  gap: 10px;
  margin-left: auto;
  display: flex;
}

.lm-prog-bar {
  background: var(--rule-soft);
  border-radius: 99px;
  width: 130px;
  height: 6px;
  overflow: hidden;
}

.lm-prog-fill {
  background: var(--mod);
  border-radius: 99px;
  height: 100%;
  transition: width .25s;
}

.lm-x {
  color: var(--ink-4);
  cursor: pointer;
  background: none;
  border: none;
  padding: 7px;
  display: flex;
}

.lm-x:hover {
  color: var(--ink-2);
}

.lm-body {
  flex: 1;
  min-height: 0;
  display: flex;
}

.lm-rail {
  border-right: 1px solid var(--rule);
  background: var(--white);
  flex-direction: column;
  flex-shrink: 0;
  width: 300px;
  display: flex;
  overflow-y: auto;
}

.lm-rail-h {
  font-family: var(--mono);
  letter-spacing: .06em;
  text-transform: uppercase;
  color: var(--ink-4);
  padding: 14px 16px 8px;
  font-size: 9px;
}

.lm-ritem {
  border-bottom: 1px solid var(--rule-soft);
  cursor: pointer;
  align-items: flex-start;
  gap: 9px;
  padding: 10px 14px;
  display: flex;
}

.lm-ritem:hover {
  background: var(--paper);
}

.lm-ritem.is-cur {
  background: var(--mod-soft);
  border-left: 3px solid var(--mod);
  padding-left: 11px;
}

.lm-grip {
  color: var(--ink-4);
  cursor: grab;
  flex-shrink: 0;
  margin-top: 2px;
}

.lm-rist {
  border: 1.5px solid var(--rule);
  width: 20px;
  height: 20px;
  color: var(--white);
  background: var(--white);
  border-radius: 50%;
  flex-shrink: 0;
  justify-content: center;
  align-items: center;
  margin-top: 1px;
  font-size: 10px;
  display: flex;
}

.lm-rist.done {
  background: var(--status-ok);
  border-color: var(--status-ok);
}

.lm-rist.postponed {
  background: var(--status-warn);
  border-color: var(--status-warn);
}

.lm-rtxt {
  flex: 1;
  min-width: 0;
}

.lm-rtt {
  color: var(--ink-2);
  font-size: 12.5px;
  line-height: 1.4;
}

.lm-rmeta {
  color: var(--ink-4);
  align-items: center;
  gap: 4px;
  margin-top: 2px;
  font-size: 10.5px;
  display: flex;
}

.lm-rfoot {
  border-top: 1px solid var(--rule);
  margin-top: auto;
  padding: 10px 14px;
}

.lm-fbtn {
  cursor: pointer;
  width: 100%;
  font: inherit;
  color: var(--ink-3);
  background: none;
  border: none;
  justify-content: space-between;
  align-items: center;
  padding: 4px 0;
  font-size: 12.5px;
  display: flex;
}

.lm-tasklist {
  flex-direction: column;
  gap: 6px;
  margin-top: 8px;
  display: flex;
}

.lm-task {
  color: var(--ink-2);
  background: var(--paper);
  border: 1px solid var(--rule);
  border-radius: var(--r-sm);
  align-items: center;
  gap: 7px;
  padding: 6px 8px;
  font-size: 12px;
  display: flex;
}

.lm-task .who {
  font-family: var(--mono);
  color: var(--ink-4);
  margin-left: auto;
  font-size: 9.5px;
}

.lm-main {
  flex: 1;
  padding: 28px 36px;
  overflow-y: auto;
}

.lm-main-in {
  max-width: 740px;
  margin: 0 auto;
}

.lm-tt {
  margin-bottom: 6px;
  font-size: 20px;
  font-weight: 600;
}

.lm-desc {
  color: var(--ink-3);
  margin-bottom: 14px;
  font-size: 13.5px;
  line-height: 1.55;
}

.lm-sec {
  font-family: var(--mono);
  letter-spacing: .06em;
  text-transform: uppercase;
  color: var(--ink-4);
  margin: 20px 0 8px;
  font-size: 9.5px;
}

.lm-actions {
  gap: 10px;
  margin-top: 18px;
  display: flex;
}

.lm-addtask {
  align-items: center;
  gap: 8px;
  margin-top: 10px;
  display: flex;
}

.lm-banner {
  background: var(--mod-soft);
  border: 1px solid var(--mod);
  border-radius: var(--r-md);
  color: var(--mod-deep);
  align-items: center;
  gap: 10px;
  margin-bottom: 18px;
  padding: 12px 14px;
  font-size: 13px;
  display: flex;
}

.lm-snote {
  border-top: 1px solid var(--rule);
  margin-top: 26px;
  padding-top: 18px;
}

@media (prefers-reduced-motion: no-preference) {
  .hx-dialog {
    animation: hx-pop var(--transition-overlay-in);
  }

  .hx-toast {
    animation: hx-rise var(--transition-drawer-in);
  }
}

@media (max-width: 768px) {
  .hx-drawer, .hx-drawer.is-wide {
    border-radius: var(--sheet-radius) var(--sheet-radius) 0 0;
    width: 100%;
    max-height: 92vh;
    top: auto;
    left: 0;
    right: 0;
    transform: translateY(100%);
  }

  .hx-drawer.is-open {
    transform: none;
  }

  .hx-detail {
    grid-template-columns: 1fr;
  }

  .hx-detail-meta {
    order: -1;
  }
}

@media (prefers-reduced-motion: reduce) {
  .hx-drawer-backdrop, .hx-drawer {
    transition: none;
  }

  .ai-pulse, .ai-pulse:after {
    animation: none;
  }
}

@media (max-width: 1024px) {
  .overview {
    grid-template-columns: 1fr;
  }

  .overview-rail.is-sticky {
    position: static;
  }
}

.rdp-root {
  --rdp-accent-color: blue;
  --rdp-accent-background-color: #f0f0ff;
  --rdp-day-height: 44px;
  --rdp-day-width: 44px;
  --rdp-day_button-border-radius: 100%;
  --rdp-day_button-border: 2px solid transparent;
  --rdp-day_button-height: 42px;
  --rdp-day_button-width: 42px;
  --rdp-selected-border: 2px solid var(--rdp-accent-color);
  --rdp-disabled-opacity: .5;
  --rdp-outside-opacity: .75;
  --rdp-today-color: var(--rdp-accent-color);
  --rdp-dropdown-gap: .5rem;
  --rdp-months-gap: 2rem;
  --rdp-nav_button-disabled-opacity: .5;
  --rdp-nav_button-height: 2.25rem;
  --rdp-nav_button-width: 2.25rem;
  --rdp-nav-height: 2.75rem;
  --rdp-range_middle-background-color: var(--rdp-accent-background-color);
  --rdp-range_middle-color: inherit;
  --rdp-range_start-color: white;
  --rdp-range_start-background: linear-gradient(var(--rdp-gradient-direction),
    transparent 50%,
    var(--rdp-range_middle-background-color) 50%);
  --rdp-range_start-date-background-color: var(--rdp-accent-color);
  --rdp-range_end-background: linear-gradient(var(--rdp-gradient-direction),
    var(--rdp-range_middle-background-color) 50%,
    transparent 50%);
  --rdp-range_end-color: white;
  --rdp-range_end-date-background-color: var(--rdp-accent-color);
  --rdp-week_number-border-radius: 100%;
  --rdp-week_number-border: 2px solid transparent;
  --rdp-week_number-height: var(--rdp-day-height);
  --rdp-week_number-opacity: .75;
  --rdp-week_number-width: var(--rdp-day-width);
  --rdp-weeknumber-text-align: center;
  --rdp-weekday-opacity: .75;
  --rdp-weekday-padding: .5rem 0rem;
  --rdp-weekday-text-align: center;
  --rdp-gradient-direction: 90deg;
  --rdp-animation_duration: .3s;
  --rdp-animation_timing: cubic-bezier(.4, 0, .2, 1);
}

.rdp-root[dir="rtl"] {
  --rdp-gradient-direction: -90deg;
}

.rdp-root[data-broadcast-calendar="true"] {
  --rdp-outside-opacity: unset;
}

.rdp-root {
  box-sizing: border-box;
  position: relative;
}

.rdp-root * {
  box-sizing: border-box;
}

.rdp-day {
  width: var(--rdp-day-width);
  height: var(--rdp-day-height);
  text-align: center;
}

.rdp-day_button {
  cursor: pointer;
  font: inherit;
  color: inherit;
  width: var(--rdp-day_button-width);
  height: var(--rdp-day_button-height);
  border: var(--rdp-day_button-border);
  border-radius: var(--rdp-day_button-border-radius);
  background: none;
  justify-content: center;
  align-items: center;
  margin: 0;
  padding: 0;
  display: flex;
}

.rdp-day_button:disabled {
  cursor: revert;
}

.rdp-caption_label {
  z-index: 1;
  white-space: nowrap;
  border: 0;
  align-items: center;
  display: inline-flex;
  position: relative;
}

.rdp-dropdown:focus-visible ~ .rdp-caption_label {
  outline: 5px auto highlight;
  outline: 5px auto -webkit-focus-ring-color;
}

.rdp-button_next, .rdp-button_previous {
  cursor: pointer;
  font: inherit;
  color: inherit;
  appearance: none;
  width: var(--rdp-nav_button-width);
  height: var(--rdp-nav_button-height);
  background: none;
  border: none;
  justify-content: center;
  align-items: center;
  margin: 0;
  padding: 0;
  display: inline-flex;
  position: relative;
}

.rdp-button_next:disabled, .rdp-button_next[aria-disabled="true"], .rdp-button_previous:disabled, .rdp-button_previous[aria-disabled="true"] {
  cursor: revert;
  opacity: var(--rdp-nav_button-disabled-opacity);
}

.rdp-chevron {
  fill: var(--rdp-accent-color);
  display: inline-block;
}

.rdp-root[dir="rtl"] .rdp-nav .rdp-chevron {
  transform-origin: 50%;
  transform: rotate(180deg);
}

.rdp-dropdowns {
  align-items: center;
  gap: var(--rdp-dropdown-gap);
  display: inline-flex;
  position: relative;
}

.rdp-dropdown {
  z-index: 2;
  opacity: 0;
  appearance: none;
  width: 100%;
  cursor: inherit;
  line-height: inherit;
  border: none;
  margin: 0;
  padding: 0;
  position: absolute;
  inset-block: 0;
  inset-inline-start: 0;
}

.rdp-dropdown_root {
  align-items: center;
  display: inline-flex;
  position: relative;
}

.rdp-dropdown_root[data-disabled="true"] .rdp-chevron {
  opacity: var(--rdp-disabled-opacity);
}

.rdp-month_caption {
  height: var(--rdp-nav-height);
  align-content: center;
  font-size: large;
  font-weight: bold;
  display: flex;
}

.rdp-root[data-nav-layout="around"] .rdp-month, .rdp-root[data-nav-layout="after"] .rdp-month {
  position: relative;
}

.rdp-root[data-nav-layout="around"] .rdp-month_caption {
  justify-content: center;
  margin-inline-start: var(--rdp-nav_button-width);
  margin-inline-end: var(--rdp-nav_button-width);
  position: relative;
}

.rdp-root[data-nav-layout="around"] .rdp-button_previous {
  inset-inline-start: 0;
  height: var(--rdp-nav-height);
  display: inline-flex;
  position: absolute;
  top: 0;
}

.rdp-root[data-nav-layout="around"] .rdp-button_next {
  inset-inline-end: 0;
  height: var(--rdp-nav-height);
  justify-content: center;
  display: inline-flex;
  position: absolute;
  top: 0;
}

.rdp-months {
  gap: var(--rdp-months-gap);
  flex-wrap: wrap;
  max-width: fit-content;
  display: flex;
  position: relative;
}

.rdp-month_grid {
  border-collapse: collapse;
}

.rdp-nav {
  height: var(--rdp-nav-height);
  align-items: center;
  display: flex;
  position: absolute;
  inset-block-start: 0;
  inset-inline-end: 0;
}

.rdp-weekday {
  opacity: var(--rdp-weekday-opacity);
  padding: var(--rdp-weekday-padding);
  text-align: var(--rdp-weekday-text-align);
  text-transform: var(--rdp-weekday-text-transform);
  font-size: smaller;
  font-weight: 500;
}

.rdp-week_number {
  opacity: var(--rdp-week_number-opacity);
  height: var(--rdp-week_number-height);
  width: var(--rdp-week_number-width);
  border: var(--rdp-week_number-border);
  border-radius: var(--rdp-week_number-border-radius);
  text-align: var(--rdp-weeknumber-text-align);
  font-size: small;
  font-weight: 400;
}

.rdp-today:not(.rdp-outside) {
  color: var(--rdp-today-color);
}

.rdp-selected {
  font-size: large;
  font-weight: bold;
}

.rdp-selected .rdp-day_button {
  border: var(--rdp-selected-border);
}

.rdp-outside {
  opacity: var(--rdp-outside-opacity);
}

.rdp-disabled:not(.rdp-selected) {
  opacity: var(--rdp-disabled-opacity);
}

.rdp-hidden {
  visibility: hidden;
  color: var(--rdp-range_start-color);
}

.rdp-range_start {
  background: var(--rdp-range_start-background);
}

.rdp-range_start .rdp-day_button {
  background-color: var(--rdp-range_start-date-background-color);
  color: var(--rdp-range_start-color);
}

.rdp-range_middle {
  background-color: var(--rdp-range_middle-background-color);
}

.rdp-range_middle .rdp-day_button {
  border: unset;
  border-radius: unset;
  color: var(--rdp-range_middle-color);
}

.rdp-range_end {
  background: var(--rdp-range_end-background);
  color: var(--rdp-range_end-color);
}

.rdp-range_end .rdp-day_button {
  color: var(--rdp-range_start-color);
  background-color: var(--rdp-range_end-date-background-color);
}

.rdp-range_start.rdp-range_end {
  background: revert;
}

.rdp-focusable {
  cursor: pointer;
}

@keyframes rdp-slide_in_left {
  0% {
    transform: translateX(-100%);
  }

  100% {
    transform: translateX(0);
  }
}

@keyframes rdp-slide_in_right {
  0% {
    transform: translateX(100%);
  }

  100% {
    transform: translateX(0);
  }
}

@keyframes rdp-slide_out_left {
  0% {
    transform: translateX(0);
  }

  100% {
    transform: translateX(-100%);
  }
}

@keyframes rdp-slide_out_right {
  0% {
    transform: translateX(0);
  }

  100% {
    transform: translateX(100%);
  }
}

.rdp-weeks_before_enter {
  animation: rdp-slide_in_left var(--rdp-animation_duration) var(--rdp-animation_timing) forwards;
}

.rdp-weeks_before_exit {
  animation: rdp-slide_out_left var(--rdp-animation_duration) var(--rdp-animation_timing) forwards;
}

.rdp-weeks_after_enter {
  animation: rdp-slide_in_right var(--rdp-animation_duration) var(--rdp-animation_timing) forwards;
}

.rdp-weeks_after_exit {
  animation: rdp-slide_out_right var(--rdp-animation_duration) var(--rdp-animation_timing) forwards;
}

.rdp-root[dir="rtl"] .rdp-weeks_after_enter {
  animation: rdp-slide_in_left var(--rdp-animation_duration) var(--rdp-animation_timing) forwards;
}

.rdp-root[dir="rtl"] .rdp-weeks_before_exit {
  animation: rdp-slide_out_right var(--rdp-animation_duration) var(--rdp-animation_timing) forwards;
}

.rdp-root[dir="rtl"] .rdp-weeks_before_enter {
  animation: rdp-slide_in_right var(--rdp-animation_duration) var(--rdp-animation_timing) forwards;
}

.rdp-root[dir="rtl"] .rdp-weeks_after_exit {
  animation: rdp-slide_out_left var(--rdp-animation_duration) var(--rdp-animation_timing) forwards;
}

@keyframes rdp-fade_in {
  from {
    opacity: 0;
  }

  to {
    opacity: 1;
  }
}

@keyframes rdp-fade_out {
  from {
    opacity: 1;
  }

  to {
    opacity: 0;
  }
}

.rdp-caption_after_enter {
  animation: rdp-fade_in var(--rdp-animation_duration) var(--rdp-animation_timing) forwards;
}

.rdp-caption_after_exit {
  animation: rdp-fade_out var(--rdp-animation_duration) var(--rdp-animation_timing) forwards;
}

.rdp-caption_before_enter {
  animation: rdp-fade_in var(--rdp-animation_duration) var(--rdp-animation_timing) forwards;
}

.rdp-caption_before_exit {
  animation: rdp-fade_out var(--rdp-animation_duration) var(--rdp-animation_timing) forwards;
}

.horn-dt-field, .horn-dt-datetime, .horn-dt-dtd, .horn-dt-range, .horn-dt-timerange, .horn-dt-duration {
  font-family: var(--font-sans, system-ui, sans-serif);
  font-size: 14px;
}

.horn-dt-datetime, .horn-dt-timerange {
  align-items: center;
  gap: 8px;
  display: flex;
}

.horn-dt-dtd {
  flex-direction: column;
  gap: 8px;
  display: flex;
}

.horn-dt-trigger, .horn-dt-time {
  border: 1px solid var(--color-rule, #e6e3dc);
  background: var(--color-white, #fff);
  color: var(--color-ink, #1a1a1a);
  cursor: pointer;
  border-radius: 6px;
  min-height: 36px;
  padding: 6px 10px;
}

.horn-dt-popover {
  display: inline-block;
  position: relative;
}

.horn-dt-panel {
  z-index: 50;
  background: var(--color-white, #fff);
  border: 1px solid var(--color-rule, #e6e3dc);
  border-radius: 8px;
  margin-top: 4px;
  padding: 8px;
  position: absolute;
  box-shadow: 0 8px 24px #0000001f;
}

.horn-dt-duration {
  flex-wrap: wrap;
  align-items: center;
  gap: 6px;
  display: flex;
}

.horn-dt-chip {
  border: 1px solid var(--color-rule, #e6e3dc);
  background: var(--color-white, #fff);
  color: var(--color-ink-2, #3a3a3a);
  cursor: pointer;
  border-radius: 999px;
  min-height: 32px;
  padding: 4px 12px;
}

.horn-dt-chip--active {
  border-color: var(--color-horn-blue, #327cd9);
  background: var(--color-horn-blue-soft, #e6effa);
  color: var(--color-horn-blue-deep, #1e5cb0);
  font-weight: 500;
}

.horn-dt-duration-custom {
  border: 1px solid var(--color-rule, #e6e3dc);
  border-radius: 6px;
  width: 72px;
  min-height: 32px;
  padding: 4px 8px;
}

.horn-dt-endline {
  color: var(--color-ink-3, #6a6a6a);
  font-size: 13px;
}

.horn-dt-sep {
  color: var(--color-ink-3, #6a6a6a);
}

.horn-dt-range-times {
  gap: 8px;
  margin-top: 8px;
  display: flex;
}

.horn-dt-rdp {
  --rdp-accent-color: var(--color-horn-blue, #327cd9);
  --rdp-accent-background-color: var(--color-horn-blue-soft, #e6effa);
  --rdp-today-color: var(--color-horn-blue-deep, #1e5cb0);
}

@media (max-width: 640px) {
  .horn-dt-panel {
    border-radius: 12px 12px 0 0;
    margin: 0;
    padding: 16px;
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
  }
}

[data-module="cmdb"] {
  --mod: #4b5e9e;
  --mod-soft: #e9ecf6;
  --mod-deep: #33457e;
}

[data-module="regulierte-stoffe"] {
  --mod: #1f7a8c;
  --mod-soft: #e0f3f7;
  --mod-deep: #165470;
}

[data-module="projekte"] {
  --mod: #2f7e6b;
  --mod-soft: #e2efeb;
  --mod-deep: #1d5346;
}

[data-module="compliance"] {
  --mod: #a8323a;
  --mod-soft: #f5e8e9;
  --mod-deep: #7a2028;
}

[data-module="digital-puls"] {
  --mod: #b3711f;
  --mod-soft: #f6ead7;
  --mod-deep: #7a4a12;
}

[data-module="digital-puls"].dp-page {
  --mod: var(--brand-primary);
  --mod-soft: var(--brand-primary-soft);
  --mod-deep: var(--brand-primary-deep);
}

.dp-intro {
  text-align: center;
  max-width: 680px;
  margin: 0 auto;
  padding: 8px 0;
}

.dp-fun-headline {
  letter-spacing: -.01em;
  color: var(--ink-2);
  text-wrap: pretty;
  margin-bottom: 28px;
  font-size: 19px;
  font-weight: 700;
}

.dp-ai-orb {
  background: radial-gradient(circle at 32% 28%, var(--ai-bright, var(--ai)), var(--ai));
  border-radius: 50%;
  place-items: center;
  display: grid;
}

.dp-ai-orb svg {
  width: 60%;
  height: 60%;
}

@keyframes dp-orbpulse {
  0%, 100% {
    box-shadow: 0 0 0 0 color-mix(in srgb, var(--ai) 45%, transparent);
  }

  50% {
    box-shadow: 0 0 0 10px color-mix(in srgb, var(--ai) 0%, transparent);
  }
}

.dp-orb-pulse {
  animation: 2.2s ease-in-out infinite dp-orbpulse;
}

.dp-team-lineup {
  flex-wrap: wrap;
  justify-content: center;
  align-items: flex-start;
  gap: 16px;
  margin: 0 auto 22px;
  display: flex;
}

.dp-team-member {
  flex-direction: column;
  align-items: center;
  gap: 9px;
  display: flex;
}

.dp-tm-mark {
  justify-content: center;
  align-items: center;
  height: 48px;
  display: flex;
}

.dp-horn-mark {
  align-items: center;
  height: 48px;
  padding: 0 8px;
  display: flex;
}

.dp-hub-mark {
  background: var(--white);
  border: 1.5px solid var(--rule);
  letter-spacing: -.01em;
  height: 48px;
  color: var(--ink);
  border-radius: 14px;
  align-items: center;
  gap: 9px;
  padding: 0 16px;
  font-size: 18px;
  font-weight: 700;
  display: flex;
}

.dp-hub-mark .dp-h-box {
  background: var(--brand-primary);
  width: 28px;
  height: 28px;
  color: var(--white);
  border-radius: 7px;
  flex-shrink: 0;
  justify-content: center;
  align-items: center;
  font-size: 15px;
  font-weight: 800;
  display: inline-flex;
}

.dp-hub-mark > span:not(.dp-h-box) {
  color: var(--ink-3);
  margin-left: 3px;
  font-weight: 400;
}

.dp-tm-mark.dp-ai-orb {
  border-radius: 50%;
  width: 48px;
  height: 48px;
}

.dp-tm-role {
  font-family: var(--mono);
  letter-spacing: .05em;
  text-transform: uppercase;
  color: var(--ink-4);
  font-size: 9.5px;
}

.dp-team-plus {
  height: 48px;
  color: var(--ink-4);
  align-items: center;
  font-size: 22px;
  font-weight: 300;
  display: flex;
}

.dp-team-caption {
  text-align: center;
  color: var(--ink-4);
  margin-bottom: 8px;
  font-size: 12.5px;
}

.dp-hornaut-card {
  text-align: left;
  border: 1px solid var(--rule);
  border-radius: var(--r-lg);
  background: var(--white);
  margin: 0 0 22px;
  padding: 16px 18px;
}

.dp-cs-tx {
  color: var(--ink-2);
  min-height: 1.5em;
  font-size: 14px;
  line-height: 1.7;
}

.dp-cs-typing-bubble {
  background: var(--paper-2);
  border-radius: 999px;
  align-items: center;
  gap: 4px;
  padding: 11px 16px;
  display: inline-flex;
}

.dp-cs-typing-bubble i {
  background: var(--ink-4);
  border-radius: 50%;
  width: 6px;
  height: 6px;
  font-style: normal;
  animation: 1.2s ease-in-out infinite dp-typedot;
  display: inline-block;
}

.dp-cs-typing-bubble i:nth-child(2) {
  animation-delay: .18s;
}

.dp-cs-typing-bubble i:nth-child(3) {
  animation-delay: .36s;
}

@keyframes dp-typedot {
  0%, 60%, 100% {
    opacity: .35;
    transform: translateY(0);
  }

  30% {
    opacity: 1;
    transform: translateY(-2px);
  }
}

.dp-type-caret {
  background: var(--ai);
  vertical-align: text-bottom;
  width: 2px;
  height: 1.05em;
  margin-left: 1px;
  animation: .9s step-end infinite dp-caretblink;
  display: inline-block;
}

@keyframes dp-caretblink {
  50% {
    opacity: 0;
  }
}

.dp-dup-note {
  background: var(--paper);
  border: 1px solid var(--rule);
  border-radius: var(--r-md);
  color: var(--ink-3);
  align-items: center;
  gap: 9px;
  margin-bottom: 14px;
  padding: 9px 13px;
  font-size: 12.5px;
  display: flex;
}

.dp-dup-note b {
  color: var(--ink-2);
}

.dp-dup-reset {
  color: var(--ink-4);
  cursor: pointer;
  background: none;
  border: 0;
  margin-left: auto;
  font-family: inherit;
  font-size: 11.5px;
  text-decoration: underline;
}

.dp-start-btn {
  background: var(--mod);
  color: var(--white);
  border: 1.5px solid var(--mod);
  border-radius: var(--r-sm);
  cursor: pointer;
  align-items: center;
  gap: 8px;
  padding: 12px 26px;
  font-family: inherit;
  font-size: 15px;
  font-weight: 600;
  transition: background .15s, border-color .15s;
  display: inline-flex;
}

.dp-start-btn:hover {
  background: var(--mod-deep);
  border-color: var(--mod-deep);
}

@media (max-width: 640px) {
  .dp-idchoice {
    grid-template-columns: 1fr;
  }

  .dp-team-lineup {
    gap: 10px;
  }
}

.dp-page {
  background: var(--paper-2);
  min-height: 100dvh;
  color: var(--ink);
  padding: 24px 0;
}

.dp-page .shell {
  flex-direction: column;
  display: flex;
}

.dp-topbar {
  background: var(--white);
  border-bottom: 1px solid var(--rule);
  align-items: center;
  gap: 10px;
  height: 44px;
  padding: 0 24px;
  display: flex;
}

.dp-tb-logo {
  letter-spacing: -.01em;
  color: var(--ink);
  align-items: center;
  gap: 8px;
  font-size: 13px;
  font-weight: 700;
  display: flex;
}

.dp-tb-logo span {
  color: var(--ink-3);
  font-weight: 400;
}

.dp-tb-logo .dp-tb-mark {
  background: var(--brand-primary);
  width: 22px;
  height: 22px;
  color: var(--white);
  border-radius: 6px;
  justify-content: center;
  align-items: center;
  font-size: 12px;
  font-weight: 800;
  display: inline-flex;
}

.dp-tb-divider {
  background: var(--rule);
  width: 1px;
  height: 20px;
  margin: 0 2px;
}

.dp-breadcrumb {
  font-family: var(--mono);
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--ink-4);
  align-items: center;
  gap: 6px;
  font-size: 10px;
  display: flex;
}

.dp-bc-active {
  color: var(--mod);
}

.dp-tb-right {
  align-items: center;
  gap: 10px;
  margin-left: auto;
  display: flex;
}

.dp-tb-user {
  text-align: right;
}

.dp-tb-user-nm {
  color: var(--ink);
  font-size: 12px;
  font-weight: 600;
  line-height: 1.2;
}

.dp-tb-user-ro {
  color: var(--ink-4);
  font-size: 10px;
  font-family: var(--mono);
}

.dp-tb-av {
  background: var(--color-horn-blue-soft);
  width: 32px;
  height: 32px;
  color: var(--color-horn-blue-deep);
  border-radius: 50%;
  place-items: center;
  font-size: 12px;
  font-weight: 600;
  display: grid;
}

.dp-tb-logout {
  border-left: 1px solid var(--rule);
  color: var(--ink-3);
  align-items: center;
  gap: 5px;
  margin-left: 4px;
  padding: 6px 10px 6px 12px;
  font-size: 12px;
  text-decoration: none;
  display: flex;
}

.dp-tb-logout:hover {
  color: var(--status-risk);
}

.dp-stage {
  flex-direction: column;
  flex: 1;
  padding: 32px 24px 64px;
  display: flex;
}

.dp-flow {
  width: 100%;
  max-width: 680px;
  margin: 0 auto;
}

.dp-icon-mono {
  filter: grayscale();
}

.dp-main {
  grid-template-columns: 1fr 570px;
  align-items: start;
  gap: 20px;
  display: grid;
}

.dp-main .dp-flow {
  max-width: none;
}

.dp-rail {
  border: 1px solid var(--rule);
  border-radius: var(--r-lg);
  background: var(--white);
  flex-direction: column;
  display: flex;
}

.dp-rail-sec {
  flex-direction: column;
  gap: 10px;
  padding: 14px 16px;
  display: flex;
}

.dp-rail-h {
  font-family: var(--mono);
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--ink-4);
  font-size: 9px;
}

.dp-rail-id {
  background: var(--ai-tint, var(--ai-soft));
  border-radius: var(--r-md);
  align-items: center;
  gap: 10px;
  margin-bottom: 8px;
  padding: 8px 10px;
  display: flex;
}

.dp-rail-av {
  width: 32px;
  height: 32px;
  color: var(--white);
  background: linear-gradient(135deg, #a78bfa, #7c5cff);
  border-radius: 50%;
  flex-shrink: 0;
  justify-content: center;
  align-items: center;
  display: flex;
}

.dp-rail-nm {
  color: var(--ink);
  font-size: 13px;
  font-weight: 600;
  line-height: 1.2;
}

.dp-rail-ro {
  color: var(--ink-3);
  font-size: 10.5px;
  line-height: 1.3;
}

.dp-rail-float {
  box-shadow: var(--shadow-card);
  position: sticky;
  top: 24px;
}

.dp-chatlog {
  scrollbar-width: auto;
  flex-direction: column;
  gap: 8px;
  max-height: 280px;
  display: flex;
  overflow-y: auto;
}

.dp-chatlog::-webkit-scrollbar {
  width: 9px;
}

.dp-cart-list::-webkit-scrollbar {
  width: 9px;
}

.dp-chatlog::-webkit-scrollbar-thumb {
  background: var(--rule);
  border-radius: 99px;
}

.dp-cart-list::-webkit-scrollbar-thumb {
  background: var(--rule);
  border-radius: 99px;
}

.dp-chatlog::-webkit-scrollbar-thumb:hover {
  background: var(--ink-4);
}

.dp-cart-list::-webkit-scrollbar-thumb:hover {
  background: var(--ink-4);
}

.dp-chatlog-tall {
  flex: 1;
  max-height: 420px;
}

.dp-chatrow {
  align-items: flex-start;
  gap: 7px;
  display: flex;
}

.dp-chatrow-user {
  flex-direction: row-reverse;
}

.dp-chatrow-av {
  background: linear-gradient(135deg, #a78bfa, #7c5cff);
  border-radius: 50%;
  flex-shrink: 0;
  place-items: center;
  width: 20px;
  height: 20px;
  margin-top: 1px;
  display: grid;
}

.dp-chatrow-av svg {
  width: 11px;
  height: 11px;
}

.dp-chatbubble {
  min-width: 0;
  color: var(--ink-2);
  background: var(--ai-tint, var(--ai-soft));
  border: 1px solid #d5cee0;
  flex: 1;
  font-size: 12.5px;
  line-height: 1.55;
}

@supports (color: color-mix(in lab, red, red)) {
  .dp-chatbubble {
    border: 1px solid color-mix(in srgb, var(--ai) 18%, var(--rule));
  }
}

.dp-chatbubble {
  border-radius: var(--r-md);
  padding: 9px 11px;
}

.dp-chatbubble-user {
  background: var(--mod-soft);
  border-color: var(--mod);
}

@supports (color: color-mix(in lab, red, red)) {
  .dp-chatbubble-user {
    border-color: color-mix(in srgb, var(--mod) 25%, var(--rule));
  }
}

.dp-chatbubble-user {
  color: var(--ink);
  flex: 0 auto;
}

.dp-chatbubble-error {
  background: var(--status-risk-soft);
  border-color: #e2c5b8;
}

@supports (color: color-mix(in lab, red, red)) {
  .dp-chatbubble-error {
    border-color: color-mix(in srgb, var(--status-risk) 25%, var(--rule));
  }
}

.dp-chatbubble-error {
  color: var(--status-risk-deep);
}

.dp-usage-badge {
  font-size: 10px;
  font-family: var(--font-mono, monospace);
  color: var(--ink-3);
  opacity: .75;
  margin-top: 5px;
  display: block;
}

.quick-replies {
  flex-direction: column;
  align-items: flex-start;
  gap: 7px;
  margin: 8px 0 0 41px;
  display: flex;
}

.quick-replies .qr-label {
  font-family: var(--mono);
  letter-spacing: .07em;
  text-transform: uppercase;
  color: var(--ai-deep);
  align-items: center;
  gap: 5px;
  font-size: 9px;
  display: flex;
}

.quick-replies .qr-label:before {
  content: "";
  background: var(--ai);
  border-radius: 50%;
  flex-shrink: 0;
  width: 5px;
  height: 5px;
}

.quick-replies .qr-row {
  flex-wrap: wrap;
  gap: 8px;
  display: flex;
}

.qr-btn {
  font: inherit;
  background: var(--white);
  color: var(--ai-deep);
  border: 1.5px solid #c3bbe0;
  font-size: 12px;
  font-weight: 600;
}

@supports (color: color-mix(in lab, red, red)) {
  .qr-btn {
    border: 1.5px solid color-mix(in srgb, var(--ai) 32%, var(--rule));
  }
}

.qr-btn {
  cursor: pointer;
  border-radius: 999px;
  padding: 6px 12px;
}

.qr-btn:hover {
  background: var(--ai-tint);
  border-color: var(--ai);
}

.qr-btn:disabled {
  opacity: .45;
  cursor: default;
  background: var(--white);
  border-color: var(--rule);
  color: var(--ink-3);
}

.dp-chatlog .quick-replies {
  margin-left: 27px;
}

.chat-range {
  background: var(--ai-tint);
  border: 1px solid #d0c9e0;
  max-width: 300px;
  margin: 8px 0 0 27px;
}

@supports (color: color-mix(in lab, red, red)) {
  .chat-range {
    border: 1px solid color-mix(in srgb, var(--ai) 22%, var(--rule));
  }
}

.chat-range {
  border-radius: var(--r-lg);
  padding: 12px 14px;
}

.chat-range .cr-label {
  font-family: var(--mono);
  letter-spacing: .07em;
  text-transform: uppercase;
  color: var(--ai-deep);
  align-items: center;
  gap: 5px;
  margin-bottom: 9px;
  font-size: 9px;
  display: flex;
}

.chat-range .cr-label:before {
  content: "";
  background: var(--ai);
  border-radius: 50%;
  flex-shrink: 0;
  width: 5px;
  height: 5px;
}

.chat-range .cr-row {
  align-items: center;
  gap: 10px;
  display: flex;
}

.chat-range input[type="range"] {
  accent-color: var(--ai);
  flex: 1;
}

.chat-range .cr-value {
  font-family: var(--mono);
  color: var(--ai-deep);
  text-align: right;
  min-width: 56px;
  font-size: 12px;
  font-weight: 700;
}

.chat-range .cr-confirm {
  width: 100%;
  font: inherit;
  background: var(--ai);
  color: var(--white);
  border-radius: var(--r-md);
  cursor: pointer;
  border: none;
  margin-top: 10px;
  padding: 7px 12px;
  font-size: 12px;
  font-weight: 600;
}

.chat-range .cr-confirm:hover {
  background: var(--ai-deep);
}

.chat-range.is-done {
  opacity: .5;
  pointer-events: none;
}

.dp-hornaut-chat {
  flex-direction: column;
  display: flex;
}

.dp-hornaut-chat .dp-rail-sec {
  flex-direction: column;
  flex: 1;
  display: flex;
}

.dp-chat-composer {
  gap: 6px;
  margin-top: 10px;
  display: flex;
}

.dp-chat-composer-input {
  font: inherit;
  border: 1px solid var(--rule);
  color: var(--ink);
  border-radius: 999px;
  flex: 1;
  padding: 9px 14px;
  font-size: 12.5px;
}

.dp-chat-composer-input:focus {
  border-color: var(--ai);
  box-shadow: 0 0 0 3px var(--ai-soft);
  outline: none;
}

.dp-chat-composer-input:disabled {
  opacity: .6;
}

.dp-chat-composer-send {
  background: var(--mod);
  width: 34px;
  height: 34px;
  color: var(--white);
  cursor: pointer;
  border: 0;
  border-radius: 50%;
  flex-shrink: 0;
  place-items: center;
  display: grid;
}

.dp-chat-composer-send:hover:not(:disabled) {
  background: var(--mod-deep);
}

.dp-chat-composer-send:disabled {
  opacity: .4;
  cursor: not-allowed;
}

.dp-chat-mic {
  border: 1px solid var(--rule);
  background: var(--white);
  width: 34px;
  height: 34px;
  color: var(--ink-3);
  cursor: pointer;
  border-radius: 50%;
  flex-shrink: 0;
  place-items: center;
  display: grid;
}

.dp-chat-mic svg {
  stroke: currentColor;
  fill: none;
  stroke-width: 2px;
  width: 15px;
  height: 15px;
}

.dp-chat-mic:hover {
  border-color: var(--ai);
  color: var(--ai);
}

.dp-chat-mic-active {
  background: var(--status-risk);
  border-color: var(--status-risk);
  color: var(--white);
  animation: 1.4s ease-in-out infinite dp-mic-pulse;
}

@keyframes dp-mic-pulse {
  0%, 100% {
    box-shadow: 0 0 0 0 color-mix(in srgb, var(--status-risk) 45%, transparent);
  }

  50% {
    box-shadow: 0 0 0 6px #0000;
  }
}

.dp-rail-cart {
  border-top: 1px solid var(--rule);
}

.dp-cart-list {
  scrollbar-width: auto;
  flex-direction: column;
  gap: 4px;
  max-height: 220px;
  display: flex;
  overflow-y: auto;
}

.dp-cart-item {
  border-radius: var(--r-sm);
  align-items: center;
  gap: 8px;
  padding: 6px 4px;
  transition: background .12s;
  display: flex;
}

.dp-cart-item:hover {
  background: var(--paper-2);
}

.dp-cart-icon {
  flex-shrink: 0;
  font-size: 15px;
}

.dp-cart-name {
  min-width: 0;
  color: var(--ink-2);
  text-overflow: ellipsis;
  white-space: nowrap;
  flex: 1;
  font-size: 12px;
  overflow: hidden;
}

.dp-cart-remove {
  width: 20px;
  height: 20px;
  color: var(--ink-4);
  cursor: pointer;
  background: none;
  border: 0;
  border-radius: 50%;
  flex-shrink: 0;
  place-items: center;
  display: grid;
}

.dp-cart-remove:hover {
  background: var(--status-risk-soft);
  color: var(--status-risk);
}

.dp-cart-remove svg {
  stroke: currentColor;
  fill: none;
  stroke-width: 2.2px;
  width: 12px;
  height: 12px;
}

@media (max-width: 900px) {
  .dp-main {
    grid-template-columns: 1fr;
  }

  .dp-rail {
    order: 2;
    position: static;
  }
}

.dp-promise {
  flex-wrap: wrap;
  justify-content: center;
  gap: 10px;
  margin-bottom: 28px;
  display: flex;
}

.dp-promise .dp-pp {
  background: var(--white);
  border: 1px solid var(--rule);
  color: var(--ink-2);
  border-radius: 999px;
  align-items: center;
  gap: 8px;
  padding: 8px 14px;
  font-size: 13px;
  display: flex;
}

.dp-promise .dp-pp .ico {
  color: var(--mod);
}

.dp-idchoice {
  text-align: left;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  margin-bottom: 22px;
  display: grid;
}

.dp-idcard {
  border: 1.5px solid var(--rule);
  border-radius: var(--r-lg, 10px);
  background: var(--white);
  cursor: pointer;
  padding: 16px 16px 14px;
  transition: border-color .15s, box-shadow .15s;
  position: relative;
}

.dp-idcard:hover {
  border-color: var(--mod);
}

.dp-idcard.sel {
  border-color: var(--mod);
  box-shadow: 0 0 0 3px var(--mod-soft);
}

.dp-idcard .dp-ic-h {
  align-items: center;
  gap: 9px;
  margin-bottom: 7px;
  display: flex;
}

.dp-idcard .dp-ic-h .ico {
  color: var(--mod-deep);
}

.dp-idcard .dp-ic-h b {
  font-size: 14px;
}

.dp-idcard .dp-ic-d {
  color: var(--ink-3);
  font-size: 12.5px;
  line-height: 1.45;
}

.dp-ic-opts {
  border-top: 1px solid var(--rule);
  flex-direction: column;
  gap: 7px;
  margin-top: 10px;
  padding-top: 10px;
  display: flex;
}

.dp-ic-opt {
  color: var(--ink-3);
  cursor: pointer;
  align-items: flex-start;
  gap: 7px;
  font-size: 12px;
  line-height: 1.4;
  display: flex;
}

.dp-ic-opt input {
  accent-color: var(--mod);
  flex-shrink: 0;
  margin-top: 2px;
}

.dp-idcard .dp-check {
  border: 1.5px solid var(--rule);
  border-radius: 50%;
  place-items: center;
  width: 18px;
  height: 18px;
  display: grid;
  position: absolute;
  top: 13px;
  right: 13px;
}

.dp-idcard.sel .dp-check {
  background: var(--mod);
  border-color: var(--mod);
}

.dp-idcard.sel .dp-check:after {
  content: "";
  border: solid var(--white);
  border-width: 0 2px 2px 0;
  width: 5px;
  height: 9px;
  transform: rotate(45deg)translateY(-1px);
}

.dp-dup-note {
  border-radius: var(--r-md, 6px);
  background: var(--paper-2);
  border: 1px solid var(--rule);
  color: var(--ink-3);
  align-items: flex-start;
  gap: 9px;
  margin-bottom: 16px;
  padding: 10px 14px;
  font-size: 12.5px;
  display: flex;
}

.dp-auth-err {
  border-radius: var(--r-md, 6px);
  background: var(--status-risk-soft, #fef0ef);
  border: 1px solid #c45a3e4d;
  align-items: center;
  gap: 6px;
  margin-top: 8px;
  padding: 6px 10px;
  display: flex;
}

@supports (color: color-mix(in lab, red, red)) {
  .dp-auth-err {
    border: 1px solid color-mix(in srgb,var(--status-risk) 30%,transparent);
  }
}

.dp-auth-err {
  color: var(--status-risk-deep, var(--status-risk));
  font-size: 12px;
}

.dp-auth-name {
  background: var(--mod-soft);
  color: var(--mod-deep);
  border-radius: 999px;
  align-items: center;
  gap: 6px;
  margin-top: 8px;
  padding: 4px 10px;
  font-size: 12px;
  font-weight: 500;
  display: inline-flex;
}

html, body {
  background: var(--color-page-bg);
  color: var(--color-ink);
  font-family: var(--font-sans);
  -webkit-font-smoothing: antialiased;
  margin: 0;
  padding: 0;
}

.horn-shell {
  background: var(--color-paper);
  flex-direction: column;
  max-width: 1320px;
  min-height: 100vh;
  margin: 0 auto;
  display: flex;
}

@media (min-width: 1600px) {
  html:not(.hornautenbar-off) .horn-shell {
    max-width: 1660px;
  }

  html:not(.hornautenbar-off) .uw-main {
    grid-template-columns: 1fr 336px;
  }

  html:not(.hornautenbar-off) .uw-rail {
    display: flex;
  }
}

html.hornautenbar-on .horn-shell {
  max-width: 1660px;
}

html.hornautenbar-on .uw-main {
  grid-template-columns: 1fr 336px;
}

html.hornautenbar-on .uw-rail {
  display: flex;
}

html.hornautenbar-route-hidden .uw-main {
  grid-template-columns: 1fr !important;
}

html.hornautenbar-route-hidden .uw-rail {
  display: none !important;
}

.uw-main {
  flex: 1;
  grid-template-columns: 1fr;
  min-height: 0;
  display: grid;
}

.cl-stage {
  flex-direction: column;
  min-width: 0;
  display: flex;
}

.uw-rail {
  border-left: 1px solid var(--color-rule);
  scrollbar-width: thin;
  scrollbar-color: #0000001f transparent;
  background: #fff;
  flex-direction: column;
  display: none;
  overflow-y: auto;
}

.uwr-sec {
  border-bottom: 1px solid var(--color-rule);
  flex-direction: column;
  gap: 10px;
  padding: 14px 16px;
  display: flex;
}

.uwr-h {
  font-family: var(--font-mono);
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--color-ink-4);
  justify-content: space-between;
  align-items: center;
  margin-bottom: 12px;
  font-size: 9px;
  display: flex;
}

.uwr-more {
  text-transform: none;
  letter-spacing: 0;
  color: var(--color-horn-blue);
  font-size: 11px;
  font-weight: 400;
  text-decoration: none;
}

.uwr-more:hover {
  text-decoration: underline;
}

.uwr-ada {
  flex-direction: column;
  gap: 10px;
  display: flex;
}

.uwr-ada-id {
  align-items: center;
  gap: 10px;
  display: flex;
}

.uwr-ada-av {
  color: #fff;
  background: linear-gradient(135deg, #a78bfa, #7c5cff);
  border-radius: 50%;
  flex-shrink: 0;
  justify-content: center;
  align-items: center;
  width: 32px;
  height: 32px;
  font-size: 14px;
  display: flex;
}

.uwr-ada-nm {
  color: var(--color-ink);
  font-size: 13px;
  font-weight: 600;
  line-height: 1.2;
}

.uwr-ada-ro {
  color: var(--color-ink-3);
  font-size: 10.5px;
  line-height: 1.3;
}

.uwr-ada-ask {
  border: 1px solid var(--color-rule);
  background: var(--color-paper-2);
  color: var(--color-ink-4);
  cursor: text;
  border-radius: 0;
  align-items: center;
  gap: 8px;
  padding: 8px 11px;
  font-size: 12px;
  text-decoration: none;
  transition: border-color .12s;
  display: flex;
}

.uwr-ada-ask:hover, .uwr-ada-ask:focus-within {
  border-color: var(--color-ai, #6f42c1);
}

.uwr-ada-ask > span:first-child {
  color: #7c5cff;
  flex-shrink: 0;
  font-size: 14px;
  line-height: 1;
}

.uwr-recent {
  flex-direction: column;
  gap: 2px;
  display: flex;
}

.uwr-recent-item {
  color: var(--color-ink-2);
  border-radius: 6px;
  align-items: center;
  gap: 9px;
  padding: 5px 4px;
  font-size: 12px;
  line-height: 1.35;
  text-decoration: none;
  transition: background .1s;
  display: flex;
}

.uwr-recent-item:hover {
  background: var(--color-paper-2);
  color: var(--color-ink);
}

.uwr-ri-icon {
  border-radius: 5px;
  flex-shrink: 0;
  justify-content: center;
  align-items: center;
  width: 22px;
  height: 22px;
  display: flex;
}

.uwr-ri-icon--generic {
  background: var(--color-paper-2);
}

.uwr-ri-label {
  text-overflow: ellipsis;
  white-space: nowrap;
  flex: 1;
  min-width: 0;
  overflow: hidden;
}

* {
  box-sizing: border-box;
}

html.sidebar-collapsed aside.app-sidebar {
  border-right: 1px solid var(--color-rule);
  width: 56px;
  overflow: hidden;
}

html.sidebar-collapsed aside.app-sidebar nav, html.sidebar-collapsed aside.app-sidebar .app-sidebar-footer, html.sidebar-collapsed aside.app-sidebar .app-sidebar-brand-text {
  display: none;
}

aside.app-sidebar {
  transition: width .2s, transform .2s;
}

@media (max-width: 767px) {
  aside.app-sidebar {
    z-index: 40;
    height: 100dvh;
    position: fixed;
    top: 0;
    left: 0;
    transform: translateX(-100%);
    box-shadow: 0 0 24px #0000002e;
    width: min(85vw, 320px) !important;
  }

  html.sidebar-mobile-open aside.app-sidebar {
    transform: translateX(0);
  }

  html.sidebar-collapsed aside.app-sidebar nav, html.sidebar-collapsed aside.app-sidebar .app-sidebar-footer, html.sidebar-collapsed aside.app-sidebar .app-sidebar-brand-text {
    display: revert;
  }

  .sidebar-backdrop {
    display: none;
  }

  html.sidebar-mobile-open .sidebar-backdrop {
    display: block;
  }

  aside.app-sidebar [data-sidebar-resize-handle] {
    display: none;
  }
}

@media (min-width: 768px) {
  .sidebar-backdrop {
    display: none;
  }
}

@keyframes action-card-pulse {
  0% {
    box-shadow: 0 0 0 0 var(--color-horn-blue);
  }

  40% {
    box-shadow: 0 0 0 6px rgba(var(--color-horn-blue-rgb, 26, 92, 184), .15);
  }

  100% {
    box-shadow: 0 0 0 0 var(--color-horn-blue);
  }
}

.action-card-pulse {
  animation: 1.5s ease-out action-card-pulse;
}

html.text-scale-small {
  font-size: 14px;
}

html.text-scale-normal {
  font-size: 16px;
}

html.text-scale-large {
  font-size: 18px;
}

html.reduce-motion *, html.reduce-motion :before, html.reduce-motion :after {
  scroll-behavior: auto !important;
  transition-duration: .001ms !important;
  animation-duration: .001ms !important;
  animation-iteration-count: 1 !important;
}

@media (min-width: 768px) {
  body[data-sidebar-collapsed="auto"] aside.app-sidebar {
    transition: width .18s, box-shadow .18s;
    overflow: hidden;
    width: 56px !important;
  }

  body[data-sidebar-collapsed="auto"] aside.app-sidebar:hover {
    z-index: 50;
    box-shadow: 4px 0 24px #14120e1f;
    width: 244px !important;
  }

  body[data-sidebar-collapsed="auto"] aside.app-sidebar > div {
    overflow-x: hidden;
  }

  body[data-sidebar-collapsed="auto"] aside.app-sidebar [data-sidebar-resize] {
    display: none;
  }
}

.pd-grid {
  grid-template-columns: repeat(3, 1fr);
  align-items: start;
  gap: 16px;
  display: grid;
}

.pd-grid > .pd-span2 {
  grid-column: span 2;
}

@media (max-width: 920px) {
  .pd-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .pd-grid > .pd-span2 {
    grid-column: span 2;
  }
}

@media (max-width: 600px) {
  .pd-grid {
    grid-template-columns: 1fr;
  }

  .pd-grid > .pd-span2 {
    grid-column: span 1;
  }
}

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

@media (max-width: 767px) {
  .topbar-nav, .topbar-intent-bar, .topbar-assistant-btn, .admin-back-btn, .dev-banner-secondary {
    display: none !important;
  }

  .dev-banner-branch {
    text-overflow: ellipsis;
    white-space: nowrap;
    flex-shrink: 1;
    max-width: calc(100vw - 100px);
    overflow: hidden;
  }
}

.mod-dot {
  background: var(--mod);
  border-radius: 50%;
  flex-shrink: 0;
  width: 7px;
  height: 7px;
}

.picker {
  background: var(--white);
  border: 1px solid var(--rule);
  border-radius: var(--r-lg);
  box-shadow: var(--shadow-card);
  margin-top: 22px;
  overflow: hidden;
}

.pk-head {
  border-bottom: 1px solid var(--rule);
  padding: 16px 20px 14px;
}

.pk-crumb {
  font: 11px var(--mono);
  color: var(--ink-4);
  align-items: center;
  gap: 7px;
  display: flex;
}

.pk-crumb b {
  color: var(--mod-deep);
}

.pk-search {
  margin-top: 11px;
  position: relative;
}

.pk-search svg {
  width: 15px;
  height: 15px;
  color: var(--ink-4);
  position: absolute;
  top: 50%;
  left: 11px;
  transform: translateY(-50%);
}

.pk-search input {
  border: 1px solid var(--rule);
  border-radius: var(--r-sm);
  width: 100%;
  font-size: 13px;
  font-family: var(--font);
  padding: 9px 11px 9px 34px;
}

.pk-search input:focus {
  border-color: var(--mod);
  box-shadow: 0 0 0 3px var(--mod-soft);
  outline: none;
}

.pk-body {
  grid-template-columns: 240px 1fr;
  min-height: 360px;
  display: grid;
}

.domains {
  border-right: 1px solid var(--rule);
  padding: 8px;
  overflow-y: auto;
}

.domain {
  border-radius: var(--r-sm);
  cursor: pointer;
  border: 1px solid #0000;
  align-items: center;
  gap: 10px;
  padding: 9px 11px;
  display: flex;
}

.domain:hover {
  background: var(--paper);
}

.domain.on {
  background: var(--mod-soft);
  border-color: var(--mod);
}

@supports (color: color-mix(in lab, red, red)) {
  .domain.on {
    border-color: color-mix(in srgb,var(--mod) 30%, transparent);
  }
}

.domain .dn {
  color: var(--ink);
  font-size: 13px;
  font-weight: 500;
}

.domain .dc {
  font: 10px var(--mono);
  color: var(--ink-4);
  margin-left: auto;
}

.domain.on .dn {
  color: var(--mod-deep);
  font-weight: 600;
}

.types {
  padding: 16px 18px;
}

.types-h {
  font: 10px var(--mono);
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--ink-4);
  align-items: center;
  gap: 8px;
  margin-bottom: 12px;
  display: flex;
}

.type-grid {
  grid-template-columns: repeat(3, 1fr);
  gap: 9px;
  display: grid;
}

.type {
  border: 1px solid var(--rule);
  border-radius: var(--r-md);
  cursor: pointer;
  background: var(--white);
  text-align: left;
  align-items: center;
  gap: 9px;
  padding: 11px 12px;
  display: flex;
}

.type:hover {
  border-color: var(--mod);
}

.type.sel {
  border-color: var(--mod);
  box-shadow: 0 0 0 3px var(--mod-soft);
}

.type .ti {
  border-radius: var(--r-sm);
  flex: none;
  justify-content: center;
  align-items: center;
  width: 30px;
  height: 30px;
  display: flex;
}

.type .ti svg {
  width: 16px;
  height: 16px;
}

.type .tn {
  color: var(--ink);
  font-size: 12.5px;
  font-weight: 500;
  line-height: 1.2;
}

.type .tt {
  font: 9px var(--mono);
  color: var(--ink-4);
  margin-top: 2px;
}

.type .flag {
  font: 8.5px var(--mono);
  text-transform: uppercase;
  letter-spacing: .04em;
  background: var(--status-warn-soft);
  color: var(--status-warn-deep);
  border-radius: 99px;
  align-self: flex-start;
  margin-left: auto;
  padding: 1px 5px;
}

.note {
  font: 11px var(--mono);
  color: var(--ink-4);
  align-items: center;
  gap: 8px;
  margin-top: 14px;
  display: flex;
}

.btn {
  border-radius: var(--r-sm);
  cursor: pointer;
  border: 1px solid var(--rule);
  background: var(--white);
  color: var(--ink-2);
  font-size: 12px;
  font-weight: 500;
  font-family: var(--font);
  white-space: nowrap;
  align-items: center;
  gap: 5px;
  padding: 5px 12px;
  text-decoration: none;
  display: inline-flex;
}

.btn-primary {
  background: var(--brand-primary);
  color: var(--white);
  border-color: var(--brand-primary);
}

.btn-mod {
  background: var(--mod);
  color: var(--white);
  border-color: var(--mod);
}

.btn-sm {
  padding: 5px 11px;
  font-size: 12px;
}

.btn-danger {
  background: var(--status-risk);
  color: var(--white);
  border-color: var(--status-risk);
}

.btn-lg {
  padding: 8px 15px;
  font-size: 13px;
}

.btn-mod:hover {
  background: var(--mod-deep);
  border-color: var(--mod-deep);
}

.btn-ai {
  border-color: #6d5ae059;
}

@supports (color: color-mix(in lab, red, red)) {
  .btn-ai {
    border-color: color-mix(in srgb,var(--ai) 35%,transparent);
  }
}

.btn-ai {
  background: var(--ai-soft);
  color: var(--ai-deep);
}

.btn-ai.disabled {
  opacity: .45;
  cursor: not-allowed;
  pointer-events: none;
}

.page-head {
  justify-content: space-between;
  align-items: flex-start;
  gap: 24px;
  margin-bottom: 6px;
  display: flex;
}

.page-h1 {
  letter-spacing: -.02em;
  align-items: center;
  gap: 10px;
  margin-bottom: 4px;
  font-size: 24px;
  font-weight: 600;
  display: flex;
}

.page-sub {
  color: var(--ink-3);
  max-width: 720px;
  margin-top: 4px;
  margin-bottom: 20px;
  font-size: 13px;
}

.page-subtitle {
  color: var(--ink-3);
  margin-bottom: 24px;
  font-size: 13px;
}

.section-hd {
  font-family: var(--mono);
  color: var(--ink-3);
  text-transform: uppercase;
  letter-spacing: .06em;
  margin-bottom: 14px;
  font-size: 11px;
  font-weight: 600;
}

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

.panel thead tr {
  background: var(--paper);
}

.panel th {
  text-align: left;
  color: var(--ink-4);
  border-bottom: 1px solid var(--rule);
  font-size: 10px;
  font-weight: 500;
  font-family: var(--mono);
  letter-spacing: .05em;
  text-transform: uppercase;
  white-space: nowrap;
  padding: 8px 12px;
}

.panel td {
  border-bottom: 1px solid var(--paper-2);
  vertical-align: middle;
  color: var(--ink-2);
  padding: 10px 12px;
  font-size: 13px;
}

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

.panel tbody tr:hover td {
  background: var(--paper);
}

.kpi-row {
  gap: 12px;
  margin-bottom: 28px;
  display: grid;
}

.kpi-card {
  background: var(--white);
  border: 1px solid var(--rule);
  border-radius: var(--r-md);
  padding: 16px 18px;
}

.kpi-value {
  letter-spacing: -.03em;
  color: var(--ink);
  font-size: 28px;
  font-weight: 700;
  line-height: 1;
}

.kpi-sub {
  color: var(--ink-4);
  margin-top: 4px;
  font-size: 11px;
}

.fw-grid {
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
  margin-bottom: 32px;
  display: grid;
}

.fw-card {
  background: var(--white);
  border: 1px solid var(--rule);
  border-radius: var(--r-lg);
  padding: 18px;
}

.fw-card:hover {
  box-shadow: var(--shadow-card);
}

.fw-header {
  justify-content: space-between;
  align-items: flex-start;
  gap: 10px;
  margin-bottom: 14px;
  display: flex;
}

.fw-name {
  color: var(--ink);
  font-size: 15px;
  font-weight: 600;
}

.fw-meta {
  color: var(--ink-4);
  font-size: 11px;
  font-family: var(--mono);
  margin-top: 2px;
}

.fw-badge {
  font-family: var(--mono);
  white-space: nowrap;
  border-radius: 4px;
  padding: 2px 7px;
  font-size: 9.5px;
}

.fw-badge-security {
  background: var(--label-azure-soft);
  color: var(--label-azure);
}

.fw-badge-quality {
  background: var(--label-green-soft);
  color: var(--label-green);
}

.fw-actions {
  border-top: 1px solid var(--rule);
  gap: 8px;
  margin-top: 14px;
  padding-top: 14px;
  display: flex;
}

.quick-grid {
  grid-template-columns: repeat(4, 1fr);
  gap: 10px;
  margin-bottom: 32px;
  display: grid;
}

.quick-card {
  background: var(--white);
  border: 1px solid var(--rule);
  border-radius: var(--r-md);
  padding: 14px 16px;
  text-decoration: none;
  display: block;
}

.quick-card:hover {
  box-shadow: var(--shadow-card);
}

.quick-icon {
  border-radius: var(--r-md);
  background: var(--mod-soft);
  width: 32px;
  height: 32px;
  color: var(--mod-deep);
  justify-content: center;
  align-items: center;
  margin-bottom: 10px;
  display: flex;
}

.quick-icon.ai {
  background: var(--ai-soft);
  color: var(--ai-deep);
}

.quick-title {
  color: var(--ink-2);
  margin-bottom: 2px;
  font-size: 13px;
  font-weight: 500;
}

.quick-sub {
  color: var(--ink-4);
  font-size: 11px;
}

.quick-sub.ai {
  color: var(--status-risk);
}

.cov-banner {
  background: var(--white);
  border: 1px solid var(--rule);
  border-radius: var(--r-md);
  align-items: center;
  gap: 16px;
  margin-bottom: 16px;
  padding: 12px 16px;
  display: flex;
}

.cov-ico {
  border-radius: var(--r-md);
  background: var(--mod-soft);
  width: 34px;
  height: 34px;
  color: var(--mod-deep);
  flex-shrink: 0;
  justify-content: center;
  align-items: center;
  display: flex;
}

.cov-title {
  color: var(--ink);
  font-size: 13px;
  font-weight: 600;
}

.cov-sub {
  color: var(--ink-3);
  margin-top: 1px;
  font-size: 12px;
}

.cov-txt {
  flex: 1;
}

.cov-bar-wrap {
  flex-shrink: 0;
  width: 180px;
}

.cov-bar-seg {
  background: var(--rule);
  border-radius: 99px;
  height: 6px;
  display: flex;
  overflow: hidden;
}

.cov-bar-seg .linked {
  background: var(--status-ok);
}

.cov-bar-seg .free {
  background: var(--status-warn);
}

.cov-legend {
  font-family: var(--mono);
  color: var(--ink-4);
  gap: 12px;
  margin-top: 5px;
  font-size: 9.5px;
  display: flex;
}

.cov-legend i {
  vertical-align: middle;
  border-radius: 2px;
  width: 7px;
  height: 7px;
  margin-right: 3px;
  display: inline-block;
}

.tab-bar {
  flex-wrap: wrap;
  gap: 6px;
  margin-bottom: 16px;
  display: flex;
}

.tab {
  color: var(--ink-3);
  cursor: pointer;
  border: 1px solid var(--rule);
  background: var(--white);
  white-space: nowrap;
  font-size: 13px;
  font-family: var(--font);
  border-radius: 99px;
  align-items: center;
  gap: 6px;
  padding: 6px 12px;
  display: inline-flex;
}

.tab:hover {
  color: var(--ink);
}

.tab.active {
  color: var(--white);
  background: var(--mod);
  border-color: var(--mod);
  font-weight: 500;
}

.tab .cnt {
  font-family: var(--mono);
  background: var(--paper-2);
  color: var(--ink-4);
  text-align: center;
  border-radius: 99px;
  min-width: 16px;
  padding: 0 5px;
  font-size: 10px;
}

.tab.active .cnt {
  color: var(--white);
  background: #ffffff40;
}

.fw-switch-row {
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: center;
  gap: 16px;
  margin-bottom: 12px;
  display: flex;
}

.fw-switch {
  background: var(--paper);
  border: 1px solid var(--rule);
  border-radius: var(--r-sm);
  gap: 2px;
  padding: 3px;
  display: inline-flex;
}

.fw-btn {
  font-size: 12.5px;
  font-family: var(--font);
  color: var(--ink-3);
  cursor: pointer;
  white-space: nowrap;
  background: none;
  border: none;
  border-radius: 5px;
  align-items: center;
  gap: 6px;
  padding: 6px 13px;
  display: inline-flex;
}

.fw-btn:hover {
  color: var(--ink);
}

.fw-btn.active {
  background: var(--white);
  color: var(--mod-deep);
  box-shadow: var(--shadow-card);
  font-weight: 600;
}

.fw-btn .fwdot {
  border-radius: 50%;
  flex-shrink: 0;
  width: 7px;
  height: 7px;
}

.fw-view-note {
  color: var(--ink-4);
  font-size: 11.5px;
  font-family: var(--mono);
}

.two-pane {
  grid-template-columns: 1fr 400px;
  align-items: start;
  gap: 18px;
  display: grid;
}

.list-title {
  color: var(--ink);
  margin-bottom: 10px;
  font-size: 15px;
  font-weight: 600;
}

.a-name {
  color: var(--ink);
  align-items: center;
  gap: 8px;
  font-weight: 600;
  display: flex;
}

.a-ico {
  border-radius: var(--r-sm);
  flex-shrink: 0;
  justify-content: center;
  align-items: center;
  width: 26px;
  height: 26px;
  display: flex;
}

.a-ico.cmdb {
  background: var(--status-info-soft);
  color: var(--status-info);
}

.a-ico.free {
  background: var(--status-warn-soft);
  color: var(--status-warn-deep);
}

.src-badge {
  font-family: var(--mono);
  border-radius: 99px;
  align-items: center;
  gap: 4px;
  padding: 2px 7px;
  font-size: 9px;
  font-weight: 600;
  display: inline-flex;
}

.src-cmdb {
  background: var(--status-info-soft);
  color: var(--status-info);
}

.src-free {
  background: var(--status-warn-soft);
  color: var(--status-warn-deep);
}

.sub-cell {
  color: var(--ink-4);
  margin-top: 2px;
  font-size: 11px;
}

.sb-group {
  gap: 4px;
  display: inline-flex;
}

.sb {
  border-radius: var(--r-sm);
  width: 23px;
  height: 20px;
  font-family: var(--mono);
  border: 1px solid #0000;
  justify-content: center;
  align-items: center;
  font-size: 10px;
  font-weight: 700;
  display: inline-flex;
}

.sb-n {
  background: var(--status-muted-soft);
  color: var(--status-muted);
  border-color: #5f66704d;
}

@supports (color: color-mix(in lab, red, red)) {
  .sb-n {
    border-color: color-mix(in srgb,var(--status-muted) 30%,transparent);
  }
}

.sb-h {
  background: var(--status-warn-soft);
  color: var(--status-warn-deep);
  border-color: #c9a85c61;
}

@supports (color: color-mix(in lab, red, red)) {
  .sb-h {
    border-color: color-mix(in srgb,var(--status-warn) 38%,transparent);
  }
}

.sb-s {
  background: var(--status-risk-soft);
  color: var(--status-risk-deep);
  border-color: #c45a3e61;
}

@supports (color: color-mix(in lab, red, red)) {
  .sb-s {
    border-color: color-mix(in srgb,var(--status-risk) 38%,transparent);
  }
}

.fchip-iso {
  font-family: var(--mono);
  background: var(--status-info-soft);
  color: var(--status-info);
  border-radius: 99px;
  align-items: center;
  gap: 4px;
  margin-right: 4px;
  padding: 2px 7px;
  font-size: 9.5px;
  font-weight: 600;
  display: inline-flex;
}

.fchip-bsi {
  font-family: var(--mono);
  background: var(--status-warn-soft);
  color: var(--status-warn-deep);
  border-radius: 99px;
  align-items: center;
  gap: 4px;
  margin-right: 4px;
  padding: 2px 7px;
  font-size: 9.5px;
  font-weight: 600;
  display: inline-flex;
}

.fchip-qm {
  font-family: var(--mono);
  background: var(--status-ok-soft);
  color: var(--status-ok);
  border-radius: 99px;
  align-items: center;
  gap: 4px;
  margin-right: 4px;
  padding: 2px 7px;
  font-size: 9.5px;
  font-weight: 600;
  display: inline-flex;
}

.fchip-dot {
  border-radius: 50%;
  width: 6px;
  height: 6px;
}

.fchip-iso .fchip-dot {
  background: var(--status-info);
}

.fchip-bsi .fchip-dot {
  background: var(--status-warn);
}

.fchip-qm .fchip-dot {
  background: var(--status-ok);
}

.ctrl-chip {
  font-family: var(--mono);
  color: var(--status-info);
  margin-right: 5px;
  font-size: 10px;
}

.modelled-yes {
  color: var(--status-ok);
  align-items: center;
  gap: 5px;
  font-size: 12px;
  display: inline-flex;
}

.modelled-no {
  color: var(--ink-4);
  align-items: center;
  gap: 5px;
  font-size: 12px;
  display: inline-flex;
}

.assign-link {
  color: var(--mod);
  cursor: pointer;
  align-items: center;
  gap: 4px;
  font-size: 12px;
  text-decoration: none;
  display: inline-flex;
}

.row-act {
  color: var(--brand-primary);
  cursor: pointer;
  font-size: 12px;
  text-decoration: none;
}

.create-panel {
  background: var(--white);
  border: 1px solid var(--rule);
  border-radius: var(--r-md);
  position: sticky;
  top: 14px;
  overflow: hidden;
}

.create-head {
  border-bottom: 1px solid var(--rule);
  padding: 13px 16px;
}

.create-title {
  color: var(--ink);
  font-size: 14px;
  font-weight: 600;
}

.create-sub {
  color: var(--ink-4);
  margin-top: 2px;
  font-size: 11.5px;
}

.mode-seg {
  padding: 12px 16px 0;
  display: flex;
}

.mode-btn {
  border: 1px solid var(--rule);
  background: var(--white);
  cursor: pointer;
  font-family: var(--font);
  text-align: left;
  flex-direction: column;
  flex: 1;
  align-items: flex-start;
  gap: 3px;
  padding: 10px 12px;
  display: flex;
  position: relative;
}

.mode-btn:first-child {
  border-radius: var(--r-sm) 0 0 var(--r-sm);
}

.mode-btn:last-child {
  border-radius: 0 var(--r-sm) var(--r-sm) 0;
  border-left: none;
}

.mode-btn .mb-t {
  color: var(--ink-2);
  align-items: center;
  gap: 6px;
  font-size: 12.5px;
  font-weight: 600;
  display: flex;
}

.mode-btn .mb-s {
  color: var(--ink-4);
  font-size: 10.5px;
}

.mode-btn.active {
  background: var(--mod-soft);
  border-color: var(--mod);
}

.mode-btn.active .mb-t {
  color: var(--mod-deep);
}

.mode-rec-flag {
  font-family: var(--mono);
  letter-spacing: .05em;
  text-transform: uppercase;
  background: var(--mod);
  color: var(--white);
  border-radius: 99px;
  padding: 1px 6px;
  font-size: 8px;
  font-weight: 700;
  position: absolute;
  top: -8px;
  right: 8px;
}

.create-body {
  padding: 14px 16px 16px;
}

.search-box {
  border: 1px solid var(--rule);
  border-radius: var(--r-sm);
  background: var(--paper);
  align-items: center;
  gap: 8px;
  margin-bottom: 10px;
  padding: 8px 11px;
  display: flex;
}

.search-box input {
  color: var(--ink);
  width: 100%;
  font-size: 13px;
  font-family: var(--font);
  background: none;
  border: none;
  outline: none;
}

.ci-results {
  flex-direction: column;
  gap: 6px;
  max-height: 190px;
  display: flex;
  overflow-y: auto;
}

.ci-opt {
  border: 1px solid var(--rule);
  border-radius: var(--r-sm);
  cursor: pointer;
  align-items: center;
  gap: 10px;
  padding: 9px 11px;
  transition: border-color .12s, background .12s;
  display: flex;
}

.ci-opt:hover, .ci-opt.sel {
  border-color: var(--status-info);
  background: var(--status-info-soft);
}

.ci-opt-ico {
  border-radius: var(--r-sm);
  background: var(--paper-2);
  width: 28px;
  height: 28px;
  color: var(--ink-3);
  flex-shrink: 0;
  justify-content: center;
  align-items: center;
  display: flex;
}

.ci-opt-name {
  color: var(--ink);
  font-size: 13px;
  font-weight: 500;
}

.ci-opt-meta {
  font-family: var(--mono);
  color: var(--ink-4);
  font-size: 10.5px;
}

.ci-opt-state {
  font-family: var(--mono);
  border-radius: 99px;
  flex-shrink: 0;
  padding: 2px 6px;
  font-size: 9.5px;
}

.cis-free {
  background: var(--status-ok-soft);
  color: var(--status-ok);
}

.cis-linked {
  background: var(--paper-2);
  color: var(--ink-4);
}

.enrich-block {
  border-top: 1px solid var(--rule);
  margin-top: 12px;
  padding-top: 12px;
}

.pulled {
  background: var(--status-info-soft);
  border: 1px solid #1e5cb040;
}

@supports (color: color-mix(in lab, red, red)) {
  .pulled {
    border: 1px solid color-mix(in srgb,var(--status-info) 25%,transparent);
  }
}

.pulled {
  border-radius: var(--r-sm);
  margin-bottom: 14px;
  padding: 10px 12px;
}

.pulled-head {
  font-family: var(--mono);
  text-transform: uppercase;
  letter-spacing: .06em;
  color: var(--status-info);
  align-items: center;
  gap: 6px;
  margin-bottom: 7px;
  font-size: 9px;
  display: flex;
}

.pulled-grid {
  grid-template-columns: 1fr 1fr;
  gap: 7px 14px;
  display: grid;
}

.pulled-k {
  color: var(--ink-4);
  font-size: 10.5px;
  font-family: var(--mono);
}

.pulled-v {
  color: var(--ink-2);
  font-size: 12px;
  font-weight: 500;
}

.field-label .add {
  color: var(--mod-deep);
  background: var(--mod-soft);
  border-radius: 99px;
  padding: 1px 5px;
  font-size: 8px;
}

.fw-assign {
  flex-direction: column;
  gap: 6px;
  display: flex;
}

.fw-check {
  border: 1px solid var(--rule);
  border-radius: var(--r-sm);
  cursor: pointer;
  align-items: flex-start;
  gap: 8px;
  padding: 9px 11px;
  display: flex;
}

.fw-check.on {
  border-color: var(--mod);
  background: var(--mod-soft);
}

.fw-check .box {
  border: 1.5px solid var(--ink-4);
  border-radius: 4px;
  flex-shrink: 0;
  justify-content: center;
  align-items: center;
  width: 16px;
  height: 16px;
  margin-top: 1px;
  display: flex;
}

.fw-check.on .box {
  background: var(--mod);
  border-color: var(--mod);
}

.fw-check-name {
  color: var(--ink);
  font-size: 12.5px;
  font-weight: 500;
}

.fw-check-sub {
  color: var(--ink-4);
  font-size: 10.5px;
}

.sb-picker {
  gap: 16px;
  display: flex;
}

.sb-col {
  flex-direction: column;
  gap: 4px;
  display: flex;
}

.sb-col-lbl {
  font-family: var(--mono);
  color: var(--ink-4);
  font-size: 9.5px;
}

.sb-choices {
  gap: 3px;
  display: flex;
}

.sb-choice {
  border-radius: var(--r-sm);
  border: 1px solid var(--rule);
  background: var(--white);
  width: 26px;
  height: 24px;
  font-family: var(--mono);
  color: var(--ink-3);
  cursor: pointer;
  font-size: 11px;
  font-weight: 700;
}

.sb-choice.n.on {
  background: var(--status-muted-soft);
  color: var(--status-muted);
  border-color: #5f667066;
}

@supports (color: color-mix(in lab, red, red)) {
  .sb-choice.n.on {
    border-color: color-mix(in srgb,var(--status-muted) 40%,transparent);
  }
}

.sb-choice.h.on {
  background: var(--status-warn-soft);
  color: var(--status-warn-deep);
  border-color: #c9a85c73;
}

@supports (color: color-mix(in lab, red, red)) {
  .sb-choice.h.on {
    border-color: color-mix(in srgb,var(--status-warn) 45%,transparent);
  }
}

.sb-choice.s.on {
  background: var(--status-risk-soft);
  color: var(--status-risk-deep);
  border-color: #c45a3e73;
}

@supports (color: color-mix(in lab, red, red)) {
  .sb-choice.s.on {
    border-color: color-mix(in srgb,var(--status-risk) 45%,transparent);
  }
}

.inp {
  border: 1px solid var(--rule);
  border-radius: var(--r-sm);
  background: var(--white);
  width: 100%;
  color: var(--ink);
  font-size: 13px;
  font-family: var(--font);
  padding: 8px 10px;
}

.inp:focus {
  border-color: var(--brand-primary);
  box-shadow: 0 0 0 3px var(--brand-primary-soft);
  outline: none;
}

.sel {
  border: 1px solid var(--rule);
  border-radius: var(--r-sm);
  background: var(--white);
  width: 100%;
  color: var(--ink);
  font-size: 13px;
  font-family: var(--font);
  padding: 8px 10px;
}

.input, .select {
  border: 1px solid var(--rule);
  border-radius: var(--r-sm);
  background: var(--white);
  width: 100%;
  color: var(--ink);
  font-size: 13px;
  font-family: var(--font);
  padding: 9px 11px;
}

.input:focus, .select:focus {
  border-color: var(--mod, var(--brand-primary));
  box-shadow: 0 0 0 3px var(--mod-soft, var(--brand-primary-soft));
  outline: none;
}

.btn-link {
  background: var(--mod);
  width: 100%;
  color: var(--white);
  border-radius: var(--r-sm);
  cursor: pointer;
  font-size: 13px;
  font-weight: 600;
  font-family: var(--font);
  border: none;
  justify-content: center;
  align-items: center;
  gap: 7px;
  padding: 10px;
  display: flex;
}

.btn-link:hover {
  background: var(--mod-deep);
}

.empty-hint {
  text-align: center;
  color: var(--ink-4);
  padding: 18px 12px;
  font-size: 12.5px;
}

.free-warn {
  background: var(--status-warn-soft);
  border: 1px solid #c9a85c4d;
  gap: 9px;
  display: flex;
}

@supports (color: color-mix(in lab, red, red)) {
  .free-warn {
    border: 1px solid color-mix(in srgb,var(--status-warn) 30%,transparent);
  }
}

.free-warn {
  border-radius: var(--r-sm);
  margin-bottom: 14px;
  padding: 10px 12px;
}

.free-warn svg {
  color: var(--status-warn);
  flex-shrink: 0;
  margin-top: 1px;
}

.free-warn-txt {
  color: var(--status-warn-deep);
  font-size: 11.5px;
  line-height: 1.45;
}

.btn-free {
  background: var(--white);
  width: 100%;
  color: var(--ink-2);
  border: 1px solid var(--rule);
  border-radius: var(--r-sm);
  cursor: pointer;
  font-size: 13px;
  font-weight: 500;
  font-family: var(--font);
  padding: 9px;
}

.btn-free:hover {
  border-color: var(--ink-4);
}

.sa-backdrop {
  opacity: 0;
  pointer-events: none;
  z-index: 900;
  background: #1a1a1a2e;
  transition: opacity .2s;
  position: fixed;
  inset: 0;
}

.sa-backdrop.show {
  opacity: 1;
  pointer-events: auto;
}

.sa-drawer {
  background: var(--white);
  border-left: 1px solid var(--rule);
  z-index: 950;
  flex-direction: column;
  width: 440px;
  max-width: 92vw;
  transition: transform .28s cubic-bezier(.4, 0, .2, 1);
  display: flex;
  position: fixed;
  top: 0;
  bottom: 0;
  right: 0;
  transform: translateX(100%);
  box-shadow: 0 24px 60px #00000038;
}

.sa-drawer.show {
  transform: translateX(0);
}

.sa-drawer-head {
  border-bottom: 1px solid var(--rule);
  align-items: flex-start;
  gap: 12px;
  padding: 16px 20px;
  display: flex;
}

.sa-drawer-ico {
  border-radius: var(--r-md);
  background: var(--mod-soft);
  width: 34px;
  height: 34px;
  color: var(--mod-deep);
  flex-shrink: 0;
  justify-content: center;
  align-items: center;
  display: flex;
}

.sa-drawer-titles {
  flex: 1;
  min-width: 0;
}

.sa-drawer-title {
  color: var(--ink);
  font-size: 15px;
  font-weight: 600;
}

.sa-drawer-sub {
  color: var(--ink-4);
  margin-top: 1px;
  font-size: 11.5px;
}

.sa-drawer-x {
  border-radius: var(--r-sm);
  border: 1px solid var(--rule);
  background: var(--white);
  width: 28px;
  height: 28px;
  color: var(--ink-4);
  cursor: pointer;
  flex-shrink: 0;
  justify-content: center;
  align-items: center;
  display: flex;
}

.sa-drawer-x:hover {
  background: var(--paper);
}

.sa-drawer-body {
  flex: 1;
  padding: 18px 20px;
  overflow-y: auto;
}

.sa-drawer-foot {
  border-top: 1px solid var(--rule);
  justify-content: flex-end;
  gap: 8px;
  padding: 14px 20px;
  display: flex;
}

.asset-ref {
  background: var(--paper);
  border: 1px solid var(--rule);
  border-radius: var(--r-sm);
  align-items: center;
  gap: 9px;
  margin-bottom: 16px;
  padding: 9px 12px;
  display: flex;
}

.asset-ref-name {
  color: var(--ink);
  font-size: 13px;
  font-weight: 600;
}

.asset-ref-meta {
  font-family: var(--mono);
  color: var(--ink-4);
  font-size: 10.5px;
}

.two {
  grid-template-columns: 1fr 400px;
  align-items: start;
  gap: 18px;
  display: grid;
}

.create {
  background: var(--white);
  border: 1px solid var(--rule);
  border-radius: var(--r-md);
  position: sticky;
  top: 14px;
  overflow: hidden;
}

.enrich {
  display: none;
}

.enrich.show {
  border-top: 1px solid var(--rule);
  margin-top: 12px;
  padding-top: 12px;
  display: block;
}

.mode-pane {
  display: none;
}

.mode-pane.show {
  display: block;
}

.grp td {
  font-size: 11px;
  font-family: var(--mono);
  text-transform: uppercase;
  letter-spacing: .06em;
  border-bottom: none;
  padding: 7px 10px;
  font-weight: 600;
}

.grp-warn td {
  background: var(--status-warn-soft);
  color: var(--status-warn-deep);
}

.grp-ok td {
  background: var(--status-ok-soft);
  color: var(--status-ok);
}

.grp-n {
  opacity: .8;
  margin-left: 7px;
  font-weight: 400;
}

.schip {
  font-family: var(--mono);
  border: 1px solid var(--rule);
  background: var(--paper);
  color: var(--ink-3);
  border-radius: 99px;
  align-items: center;
  gap: 5px;
  padding: 2px 8px;
  font-size: 11px;
  display: inline-flex;
}

.schip.info {
  background: var(--status-info-soft);
  color: var(--status-info);
  border-color: #1e5cb04d;
}

@supports (color: color-mix(in lab, red, red)) {
  .schip.info {
    border-color: color-mix(in srgb,var(--status-info) 30%,transparent);
  }
}

.schip .dot {
  background: currentColor;
  border-radius: 50%;
  flex-shrink: 0;
  width: 6px;
  height: 6px;
  display: inline-block;
}

.sa-extra {
  font-family: var(--mono);
  color: var(--ink-4);
  font-size: 11px;
}

tr.unassigned td {
  opacity: .72;
}

.tab.tab-warn .cnt {
  background: var(--status-warn-soft);
  color: var(--status-warn-deep);
}

.fchip i {
  border-radius: 50%;
  flex-shrink: 0;
  width: 6px;
  height: 6px;
  font-style: normal;
  display: inline-block;
}

.fchip.iso {
  background: var(--status-info-soft);
  color: var(--status-info);
  cursor: default;
  border: none;
  padding: 2px 7px;
  font-size: 9.5px;
  font-weight: 600;
}

.fchip.iso i {
  background: var(--status-info);
}

.fchip.bsi {
  background: var(--status-warn-soft);
  color: var(--status-warn-deep);
  cursor: default;
  border: none;
  padding: 2px 7px;
  font-size: 9.5px;
  font-weight: 600;
}

.fchip.bsi i {
  background: var(--status-warn);
}

.fchip.qm {
  background: var(--status-ok-soft);
  color: var(--status-ok);
  cursor: default;
  border: none;
  padding: 2px 7px;
  font-size: 9.5px;
  font-weight: 600;
}

.fchip.qm i {
  background: var(--status-ok);
}

.modelled {
  align-items: center;
  gap: 5px;
  font-size: 12px;
  display: inline-flex;
}

.modelled.yes {
  color: var(--status-ok);
}

.modelled.no {
  color: var(--ink-4);
}

.ctrl-multi {
  flex-direction: column;
  gap: 5px;
  display: flex;
}

.ctrl-pick {
  border: 1px solid var(--rule);
  border-radius: var(--r-sm);
  color: var(--ink-2);
  background: var(--white);
  cursor: pointer;
  -webkit-user-select: none;
  user-select: none;
  align-items: flex-start;
  gap: 8px;
  padding: 7px 10px;
  font-size: 12px;
  display: flex;
}

.ctrl-pick.on {
  border-color: var(--mod);
  background: var(--mod-soft);
  color: var(--mod-deep);
}

.ctrl-pick .box {
  border: 1.5px solid var(--ink-4);
  color: #0000;
  border-radius: 3px;
  flex-shrink: 0;
  justify-content: center;
  align-items: center;
  width: 15px;
  height: 15px;
  margin-top: 1px;
  display: flex;
}

.ctrl-pick.on .box {
  background: var(--mod);
  border-color: var(--mod);
  color: var(--white);
}

.backdrop {
  opacity: 0;
  pointer-events: none;
  z-index: 900;
  background: #1a1a1a2e;
  transition: opacity .2s;
  position: fixed;
  inset: 0;
}

.backdrop.show {
  opacity: 1;
  pointer-events: auto;
}

.drawer {
  background: var(--white);
  border-left: 1px solid var(--rule);
  z-index: 950;
  flex-direction: column;
  width: 440px;
  max-width: 92vw;
  transition: transform .28s cubic-bezier(.4, 0, .2, 1);
  display: flex;
  position: fixed;
  top: 0;
  bottom: 0;
  right: 0;
  transform: translateX(100%);
  box-shadow: 0 24px 60px #00000038;
}

.drawer.show {
  transform: translateX(0);
}

.drawer-head {
  border-bottom: 1px solid var(--rule);
  align-items: flex-start;
  gap: 12px;
  padding: 16px 20px;
  display: flex;
}

.drawer-ico {
  border-radius: var(--r-md);
  background: var(--mod-soft);
  width: 34px;
  height: 34px;
  color: var(--mod-deep);
  flex-shrink: 0;
  justify-content: center;
  align-items: center;
  display: flex;
}

.drawer-titles {
  flex: 1;
  min-width: 0;
}

.drawer-title {
  color: var(--ink);
  font-size: 15px;
  font-weight: 600;
}

.drawer-sub {
  color: var(--ink-4);
  margin-top: 1px;
  font-size: 11.5px;
}

.drawer-x {
  border-radius: var(--r-sm);
  border: 1px solid var(--rule);
  background: var(--white);
  width: 28px;
  height: 28px;
  color: var(--ink-4);
  cursor: pointer;
  flex-shrink: 0;
  justify-content: center;
  align-items: center;
  display: flex;
}

.drawer-x:hover {
  background: var(--paper);
}

.drawer-body {
  flex: 1;
  padding: 18px 20px;
  overflow-y: auto;
}

.drawer-foot {
  border-top: 1px solid var(--rule);
  justify-content: flex-end;
  gap: 8px;
  padding: 14px 20px;
  display: flex;
}

.hx-toast .t-x {
  opacity: .6;
  cursor: pointer;
  padding: 0 2px;
  font-weight: 700;
}

@media (prefers-reduced-motion: no-preference) {
  @keyframes hx-pop {
    from {
      opacity: 0;
      transform: scale(.96);
    }

    to {
      opacity: 1;
      transform: scale(1);
    }
  }

  @keyframes hx-rise {
    from {
      opacity: 0;
      transform: translateY(8px);
    }

    to {
      opacity: 1;
      transform: translateY(0);
    }
  }
}

.lock-banner {
  border-radius: var(--r-md);
  background: var(--insp-locked-soft);
  border: 1px solid #7a1f1866;
  align-items: center;
  gap: 12px;
  padding: 11px 15px;
  display: flex;
}

@supports (color: color-mix(in lab, red, red)) {
  .lock-banner {
    border: 1px solid color-mix(in srgb,var(--insp-locked) 40%,transparent);
  }
}

.lock-banner {
  margin-bottom: 16px;
}

.lock-banner .li {
  border-radius: var(--r-sm);
  background: var(--insp-locked);
  color: #fff;
  flex: none;
  justify-content: center;
  align-items: center;
  width: 30px;
  height: 30px;
  display: flex;
}

.lock-banner .lt {
  color: #5e1812;
  font-size: 13px;
}

.lock-banner .lt b {
  color: #7a1f18;
}

.lock-banner .btn {
  margin-left: auto;
}

.filt {
  flex-wrap: wrap;
  gap: 7px;
  margin-bottom: 16px;
  display: flex;
}

.fchip {
  font: 11px var(--mono);
  border: 1px solid var(--rule);
  background: var(--white);
  color: var(--ink-3);
  cursor: pointer;
  border-radius: 99px;
  align-items: center;
  gap: 6px;
  padding: 4px 10px;
  display: inline-flex;
}

.fchip .sw {
  border-radius: 50%;
  width: 8px;
  height: 8px;
}

.fchip.on {
  border-color: var(--mod);
  background: var(--mod-soft);
  color: var(--mod-deep);
  font-weight: 600;
}

.tl {
  padding-left: 22px;
  position: relative;
}

.tl:before {
  content: "";
  background: var(--rule);
  border-radius: 2px;
  width: 2px;
  position: absolute;
  top: 4px;
  bottom: 4px;
  left: 6px;
}

.tl-item {
  padding: 0 0 18px 16px;
  position: relative;
}

.tl-item:before {
  content: "";
  background: var(--d, var(--mod));
  border: 2px solid var(--white);
  width: 10px;
  height: 10px;
  box-shadow: 0 0 0 1px var(--rule);
  border-radius: 50%;
  position: absolute;
  top: 4px;
  left: -16px;
}

.tl-item.ok {
  --d: var(--status-ok);
}

.tl-item.remarks {
  --d: var(--status-warn);
}

.tl-item.failed {
  --d: var(--status-risk);
}

.tl-item.locked {
  --d: var(--insp-locked);
}

.tl-head {
  flex-wrap: wrap;
  align-items: center;
  gap: 9px;
  display: flex;
}

.tl-date {
  font: 11px var(--mono);
  color: var(--ink-4);
}

.tl-type {
  font: 10px var(--mono);
  border: 1px solid var(--it);
  color: var(--it);
  background: var(--it);
  border-radius: 99px;
  padding: 2px 8px;
}

@supports (color: color-mix(in lab, red, red)) {
  .tl-type {
    background: color-mix(in srgb,var(--it) 9%,var(--white));
  }
}

.tl-res {
  font-size: 12.5px;
  font-weight: 500;
}

.tl-meta {
  font: 11px var(--mono);
  color: var(--ink-4);
  flex-wrap: wrap;
  align-items: center;
  gap: 10px;
  margin-top: 4px;
  display: flex;
}

.tl-meta a {
  color: var(--mod-deep);
}

.actor {
  align-items: center;
  gap: 5px;
  display: inline-flex;
}

.actor .k {
  text-transform: uppercase;
  letter-spacing: .04em;
  background: var(--paper-2);
  color: var(--ink-4);
  border-radius: 3px;
  padding: 1px 5px;
  font-size: 9px;
}

.actor.system .k {
  background: var(--ai-soft);
  color: var(--ai-deep);
}

.actor.hornaut .k {
  background: var(--status-info-soft);
  color: var(--status-info);
}

.norm {
  border: 1px solid var(--rule);
  border-radius: var(--r-md);
  background: var(--white);
  align-items: center;
  gap: 12px;
  padding: 12px 14px;
  display: flex;
}

.norm + .norm {
  margin-top: 8px;
}

.norm .code {
  font: 11px var(--mono);
  color: var(--mod-deep);
  background: var(--mod-soft);
  border-radius: var(--r-sm);
  flex: none;
  padding: 3px 9px;
  font-weight: 700;
}

.norm .nt {
  color: var(--ink);
  font-size: 13px;
}

.norm .nf {
  font: 10px var(--mono);
  color: var(--ink-4);
  margin-top: 2px;
}

.norm .lt {
  font: 9px var(--mono);
  text-transform: uppercase;
  letter-spacing: .04em;
  border-radius: 99px;
  flex: none;
  margin-left: auto;
  padding: 2px 8px;
}

.lt.asset {
  background: var(--status-info-soft);
  color: var(--status-info);
}

.lt.evidence {
  background: var(--status-ok-soft);
  color: var(--status-ok);
}

.lt.nc {
  background: var(--status-risk-soft);
  color: var(--status-risk-deep);
}

.lt.infra {
  background: var(--paper-2);
  color: var(--ink-3);
}

.auto-badge {
  font: 9.5px var(--mono);
  color: var(--ai-deep);
  background: var(--ai-soft);
  border-radius: 99px;
  align-items: center;
  gap: 5px;
  padding: 2px 7px;
  display: inline-flex;
}

.sidebar-badge.risk {
  background: var(--status-risk-soft);
  color: var(--status-risk-deep);
}

:root {
  --overlay-backdrop: #1a1a1a59;
  --overlay-backdrop-strong: #1a1a1a59;
  --overlay-backdrop-light: #1a1a1a2e;
  --overlay-radius: 12px;
  --overlay-shadow: 0 24px 60px #00000038;
  --overlay-bg: var(--white);
  --overlay-hairline: var(--rule);
  --drawer-width: 480px;
  --drawer-width-wide: 640px;
  --drawer-width-detail: 760px;
  --sheet-handle: 36px;
  --sheet-radius: 16px;
  --wizard-width: 760px;
  --wizard-width-wide: 880px;
  --wizard-max-height: 90vh;
  --wizard-step-rail: 184px;
  --z-backdrop: 900;
  --z-overlay: 901;
  --z-picker: 950;
  --z-toast: 1000;
  --transition-overlay-in: .2s cubic-bezier(.4,0,.2,1);
  --transition-drawer-in: .28s cubic-bezier(.4,0,.2,1);
  --transition-out: .18s ease-in;
  --transition-backdrop: .2s ease;
  --step-todo: var(--ink-4);
  --step-rail: var(--rule);
}

[data-module] {
  --step-done: var(--mod);
  --step-current: var(--mod-deep);
  --step-rail-done: var(--mod);
}

.cs-backdrop {
  z-index: var(--z-backdrop);
  background: var(--overlay-backdrop);
  opacity: 0;
  pointer-events: none;
  transition: opacity var(--transition-backdrop);
  position: fixed;
  inset: 0;
}

.cs-backdrop.open {
  opacity: 1;
  pointer-events: auto;
}

.cs-wizard {
  z-index: var(--z-overlay);
  pointer-events: none;
  place-items: center;
  padding: 24px;
  display: grid;
  position: fixed;
  inset: 0;
}

.cs-wizard-card {
  width: min(var(--wizard-width),100%);
  max-height: var(--wizard-max-height);
  background: var(--overlay-bg);
  border-radius: var(--overlay-radius);
  box-shadow: var(--overlay-shadow);
  pointer-events: auto;
  opacity: 0;
  transition: opacity var(--transition-overlay-in), transform var(--transition-overlay-in);
  flex-direction: column;
  display: flex;
  position: relative;
  overflow: hidden;
  transform: scale(.97)translateY(6px);
}

.cs-wizard.open .cs-wizard-card {
  opacity: 1;
  transform: none;
}

.cs-head {
  border-bottom: 1px solid var(--overlay-hairline);
  flex: none;
  padding: 16px 20px 14px;
}

.cs-head-top {
  justify-content: space-between;
  align-items: flex-start;
  gap: 16px;
  display: flex;
}

.cs-crumb {
  font: 11px/1.4 var(--mono);
  color: var(--ink-4);
  letter-spacing: .02em;
  flex-wrap: wrap;
  align-items: center;
  gap: 6px;
  display: flex;
}

.cs-crumb .mod-dot {
  width: 8px;
  height: 8px;
}

.cs-crumb .sep {
  opacity: .5;
}

.cs-crumb b {
  color: var(--mod-deep);
  font-weight: 600;
}

.cs-title {
  letter-spacing: -.01em;
  margin-top: 7px;
  font-size: 18px;
  font-weight: 600;
}

.cs-x {
  border: 1px solid var(--rule);
  border-radius: var(--r-sm);
  background: var(--white);
  width: 30px;
  height: 30px;
  color: var(--ink-3);
  cursor: pointer;
  flex: none;
  justify-content: center;
  align-items: center;
  font-size: 15px;
  line-height: 1;
  display: flex;
}

.cs-x:hover {
  border-color: var(--ink-4);
  color: var(--ink);
}

.cs-steps {
  align-items: center;
  gap: 0;
  margin-top: 16px;
  display: flex;
}

.cs-step {
  cursor: default;
  flex: none;
  align-items: center;
  gap: 9px;
  display: flex;
}

.cs-step .num {
  width: 22px;
  height: 22px;
  font: 600 11px var(--mono);
  background: var(--white);
  color: var(--step-todo);
  border: 1.5px solid var(--step-rail);
  border-radius: 50%;
  flex: none;
  justify-content: center;
  align-items: center;
  display: flex;
}

.cs-step .lbl {
  color: var(--ink-4);
  white-space: nowrap;
  font-size: 12px;
  font-weight: 500;
}

.cs-step.done .num {
  background: var(--step-done);
  border-color: var(--step-done);
  color: var(--white);
}

.cs-step.done .lbl {
  color: var(--ink-2);
}

.cs-step.done {
  cursor: pointer;
}

.cs-step.current .num {
  border-color: var(--step-current);
  color: var(--step-current);
  box-shadow: 0 0 0 3px var(--mod-soft);
}

.cs-step.current .lbl {
  color: var(--mod-deep);
  font-weight: 600;
}

.cs-rail {
  background: var(--step-rail);
  border-radius: 2px;
  flex: auto;
  min-width: 14px;
  height: 1.5px;
  margin: 0 10px;
}

.cs-rail.done {
  background: var(--step-rail-done);
}

.cs-body {
  flex: auto;
  padding: 22px 24px;
  overflow-y: auto;
}

.cs-pane {
  display: none;
}

.cs-pane.active {
  animation: csFade var(--transition-overlay-in);
  display: block;
}

@keyframes csFade {
  from {
    opacity: 0;
    transform: translateY(4px);
  }

  to {
    opacity: 1;
    transform: none;
  }
}

.cs-section-label {
  font: 10px var(--mono);
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--ink-4);
  margin: 0 0 12px;
}

.cs-hint {
  color: var(--ink-3);
  margin-top: 4px;
  font-size: 12px;
}

.cs-rel {
  border: 1px solid var(--rule);
  border-radius: var(--r-md);
  background: var(--white);
  align-items: center;
  gap: 10px;
  padding: 11px 13px;
  display: flex;
}

.cs-rel + .cs-rel {
  margin-top: 8px;
}

.cs-rel .rt {
  font: 10px var(--mono);
  text-transform: uppercase;
  letter-spacing: .06em;
  color: var(--ink-4);
  flex: none;
  width: 96px;
}

.cs-rel .rn {
  color: var(--ink);
  font-size: 13px;
  font-weight: 500;
}

.cs-rel .rs {
  font: 11px var(--mono);
  color: var(--ink-4);
}

.cs-rel .rx {
  color: var(--ink-4);
  cursor: pointer;
  background: none;
  border: none;
  margin-left: auto;
  font-size: 14px;
}

.cs-rel .rx:hover {
  color: var(--status-risk);
}

.cs-add {
  border: 1.5px dashed var(--rule);
  border-radius: var(--r-md);
  background: var(--paper);
  color: var(--mod-deep);
  font: 500 12.5px var(--font);
  cursor: pointer;
  justify-content: center;
  align-items: center;
  gap: 7px;
  width: 100%;
  margin-top: 11px;
  padding: 9px 13px;
  display: inline-flex;
}

.cs-add:hover {
  border-color: var(--mod);
  background: var(--mod-soft);
}

.cs-fields {
  grid-template-columns: 1fr 1fr;
  gap: 14px 16px;
  display: grid;
}

.cs-field {
  flex-direction: column;
  gap: 6px;
  display: flex;
}

.cs-field.col2 {
  grid-column: 1 / -1;
}

.cs-label {
  color: var(--ink-2);
  font-size: 12px;
  font-weight: 500;
}

.cs-label .req {
  color: var(--status-risk);
  margin-left: 2px;
}

.cs-label .opt {
  color: var(--ink-4);
  font-weight: 400;
  font-family: var(--mono);
  margin-left: 4px;
  font-size: 10px;
}

.cs-crit-pick {
  gap: 8px;
  display: flex;
}

.cs-crit-opt {
  border: 1px solid var(--rule);
  border-radius: var(--r-sm);
  cursor: pointer;
  background: var(--white);
  color: var(--ink-3);
  align-items: center;
  gap: 7px;
  padding: 7px 11px 7px 8px;
  font-size: 12px;
  display: flex;
}

.cs-crit-opt:hover {
  border-color: var(--ink-4);
}

.cs-crit-opt.sel {
  border-color: var(--mod);
  background: var(--mod-soft);
  color: var(--mod-deep);
  font-weight: 600;
}

.cs-taginput {
  border: 1px solid var(--rule);
  border-radius: var(--r-sm);
  background: var(--white);
  flex-wrap: wrap;
  align-items: center;
  gap: 6px;
  padding: 7px 9px;
  display: flex;
}

.cs-taginput input {
  font: 12px var(--mono);
  min-width: 90px;
  color: var(--ink);
  background: none;
  border: none;
  outline: none;
  flex: 90px;
}

.cs-pruef-box {
  border: 1px solid var(--rule);
  border-radius: var(--r-md);
  background: var(--paper);
  grid-column: 1 / -1;
  padding: 13px 14px;
}

.cs-pruef-grid {
  grid-template-columns: 1fr 1fr 1fr;
  gap: 12px;
  margin-top: 11px;
  display: grid;
}

.pruef {
  font: 600 11px var(--mono);
  border-radius: var(--r-sm);
  border: 1px solid #0000;
  align-items: center;
  gap: 6px;
  padding: 4px 10px 4px 8px;
  display: inline-flex;
}

.pruef svg {
  width: 13px;
  height: 13px;
}

.pruef-ok {
  background: var(--status-ok-soft);
  color: var(--status-ok);
  border-color: #2f8a4d4d;
}

@supports (color: color-mix(in lab, red, red)) {
  .pruef-ok {
    border-color: color-mix(in srgb,var(--status-ok) 30%,transparent);
  }
}

.pruef-due {
  background: var(--status-warn-soft);
  color: var(--status-warn-deep);
  border-color: #c9a85c61;
}

@supports (color: color-mix(in lab, red, red)) {
  .pruef-due {
    border-color: color-mix(in srgb,var(--status-warn) 38%,transparent);
  }
}

.pruef-over {
  background: var(--status-risk-soft);
  color: var(--status-risk-deep);
  border-color: #c45a3e59;
}

@supports (color: color-mix(in lab, red, red)) {
  .pruef-over {
    border-color: color-mix(in srgb,var(--status-risk) 35%,transparent);
  }
}

.pruef-na {
  background: var(--paper-2);
  color: var(--ink-4);
  border-color: var(--rule);
}

.cs-summary {
  border: 1px solid var(--rule);
  border-radius: var(--r-md);
  overflow: hidden;
}

.cs-srow {
  border-bottom: 1px solid var(--rule-soft);
  grid-template-columns: 140px 1fr;
  align-items: center;
  gap: 12px;
  padding: 10px 14px;
  display: grid;
}

.cs-srow:last-child {
  border-bottom: none;
}

.cs-srow .k {
  font: 10px var(--mono);
  text-transform: uppercase;
  letter-spacing: .06em;
  color: var(--ink-4);
}

.cs-srow .v {
  color: var(--ink);
  flex-wrap: wrap;
  align-items: center;
  gap: 7px;
  font-size: 13px;
  display: flex;
}

.cs-ai {
  border: 1px solid var(--ai-soft);
  background: #f6f3fd;
  margin-top: 14px;
}

@supports (color: color-mix(in lab, red, red)) {
  .cs-ai {
    background: color-mix(in srgb, var(--ai-soft) 55%, var(--white));
  }
}

.cs-ai {
  border-radius: var(--r-md);
  padding: 13px 15px;
}

.cs-ai-h {
  font: 600 12px var(--font);
  color: var(--ai-deep);
  align-items: center;
  gap: 8px;
  display: flex;
}

.cs-ai-h .spark {
  width: 16px;
  height: 16px;
  color: var(--ai);
}

.cs-ai-item {
  color: var(--ink-2);
  align-items: flex-start;
  gap: 9px;
  margin-top: 10px;
  font-size: 12.5px;
  display: flex;
}

.cs-ai-item .acc {
  font: 600 12px var(--mono);
  color: var(--ai-deep);
  cursor: pointer;
  white-space: nowrap;
  border: 1px solid var(--ai-soft);
  background: var(--white);
  border-radius: 99px;
  padding: 2px 8px;
}

.cs-ai-item .acc:hover {
  background: var(--ai-soft);
}

.cs-foot {
  border-top: 1px solid var(--overlay-hairline);
  background: var(--white);
  flex: none;
  align-items: center;
  gap: 10px;
  padding: 13px 20px;
  display: flex;
}

.cs-foot .grow {
  flex: auto;
}

.cs-link {
  color: var(--ink-4);
  font: 12.5px var(--font);
  cursor: pointer;
  background: none;
  border: none;
  padding: 6px 4px;
}

.cs-link:hover {
  color: var(--status-risk);
}

.cs-draft {
  align-items: center;
  gap: 6px;
  display: inline-flex;
}

.cs-toast {
  z-index: var(--z-toast);
  background: var(--ink);
  color: var(--white);
  border-radius: var(--r-md);
  box-shadow: var(--shadow-pop);
  opacity: 0;
  pointer-events: none;
  align-items: center;
  gap: 14px;
  padding: 11px 14px 11px 16px;
  font-size: 13px;
  transition: opacity .2s, transform .2s;
  display: flex;
  position: fixed;
  bottom: 26px;
  left: 50%;
  transform: translateX(-50%)translateY(20px);
}

.cs-toast.show {
  opacity: 1;
  pointer-events: auto;
  transform: translateX(-50%);
}

.cs-toast .undo {
  color: #ffd;
  cursor: pointer;
  font-size: 13px;
  font-weight: 600;
  font-family: var(--font);
  background: none;
  border: none;
}

.cs-toast .undo:hover {
  text-decoration: underline;
}

.cs-inline-picker {
  background: var(--white);
  z-index: 2;
  transition: transform var(--transition-overlay-in);
  flex-direction: column;
  display: flex;
  position: absolute;
  inset: 0;
  transform: translateX(100%);
}

.cs-inline-picker.open {
  transform: none;
}

.cs-ip-head {
  border-bottom: 1px solid var(--rule);
  align-items: center;
  gap: 10px;
  padding: 14px 18px;
  display: flex;
}

.cs-ip-head .b {
  color: var(--mod-deep);
  font: 13px var(--font);
  cursor: pointer;
  background: none;
  border: none;
  align-items: center;
  gap: 6px;
  display: flex;
}

.cs-ip-head .t {
  font-size: 14px;
  font-weight: 600;
}

.cs-ip-body {
  flex: 1;
  padding: 14px 18px;
  overflow-y: auto;
}

.cs-ip-search {
  margin-bottom: 12px;
}

.cs-ip-item {
  border: 1px solid var(--rule);
  border-radius: var(--r-sm);
  cursor: pointer;
  background: var(--white);
  align-items: center;
  gap: 9px;
  margin-bottom: 7px;
  padding: 9px 11px;
  display: flex;
}

.cs-ip-item:hover {
  border-color: var(--mod);
  background: var(--mod-soft);
}

.cs-ip-item .n {
  color: var(--ink);
  font-size: 13px;
  font-weight: 500;
}

.cs-ip-item .m {
  font: 11px var(--mono);
  color: var(--ink-4);
  margin-left: auto;
}

@media (max-width: 860px) {
  .cs-wizard {
    padding: 0;
  }

  .cs-wizard-card {
    border-radius: 0;
    width: 100%;
    height: 100%;
    max-height: 100%;
  }

  .cs-step .lbl {
    display: none;
  }

  .cs-step.current .lbl {
    display: inline;
  }

  .cs-fields {
    grid-template-columns: 1fr;
  }

  .cs-foot .cs-link, .cs-foot .cs-draft, .cs-foot .grow {
    display: none;
  }

  .cs-foot .btn {
    flex: auto;
  }
}

@media (prefers-reduced-motion: reduce) {
  .cs-backdrop, .cs-wizard-card, .cs-pane, .cs-toast, .cs-inline-picker {
    transition: none !important;
    animation: none !important;
  }

  .cs-wizard-card {
    transform: none;
  }
}

.dom-chips {
  flex-wrap: wrap;
  gap: 7px;
  margin-bottom: 16px;
  display: flex;
}

.dchip {
  border: 1px solid var(--rule);
  background: var(--white);
  cursor: pointer;
  font: 500 12.5px var(--font);
  color: var(--ink-2);
  white-space: nowrap;
  border-radius: 99px;
  align-items: center;
  gap: 7px;
  padding: 6px 11px;
  display: inline-flex;
}

.dchip:hover {
  border-color: var(--mod);
}

.dchip.on {
  background: var(--mod-soft);
  border-color: var(--mod);
}

@supports (color: color-mix(in lab, red, red)) {
  .dchip.on {
    border-color: color-mix(in srgb,var(--mod) 35%,transparent);
  }
}

.dchip.on {
  color: var(--mod-deep);
  font-weight: 600;
}

.dchip .cnt {
  font: 10px var(--mono);
  color: var(--ink-4);
  background: var(--paper-2);
  border-radius: 99px;
  padding: 1px 6px;
}

.dchip.on .cnt {
  background: var(--white);
  color: var(--mod-deep);
}

.dchip[hidden] {
  display: none;
}

.type .tx {
  min-width: 0;
}

.ico {
  vertical-align: -.18em;
  stroke: currentColor;
  flex: none;
  width: 1.15em;
  height: 1.15em;
  display: inline-block;
}

@media (max-width: 860px) {
  .type-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 520px) {
  .type-grid {
    grid-template-columns: 1fr;
  }
}

:root {
  --ok: var(--status-ok);
  --ok-soft: var(--status-ok-soft);
  --bad: var(--status-risk);
  --bad-soft: var(--status-risk-soft);
  --ai-line: #d6d1f6;
}

@supports (color: color-mix(in lab, red, red)) {
  :root {
    --ai-line: color-mix(in srgb, var(--ai) 28%, var(--white));
  }
}

.panel-head {
  border-bottom: 1px solid var(--rule-soft);
  justify-content: space-between;
  align-items: center;
  gap: 16px;
  padding: 13px 16px;
  display: flex;
}

.panel-body {
  padding: 14px 16px;
}

.page-sub {
  color: var(--ink-3);
  max-width: 720px;
  margin-top: 4px;
  font-size: 13px;
  line-height: 1.5;
}

.chip-bad {
  background: var(--bad-soft);
  color: var(--status-risk-deep);
}

.chip-bad .dot {
  background: var(--bad);
}

.kpi-value.ok {
  color: var(--ok);
}

.kpi-value.bad {
  color: var(--bad);
}

.seg {
  border: 1px solid var(--rule);
  border-radius: var(--r-sm);
  display: inline-flex;
  overflow: hidden;
}

.seg button {
  background: var(--white);
  border: none;
  border-right: 1px solid var(--rule);
  cursor: pointer;
  color: var(--ink-3);
  font-size: 12px;
  font-family: var(--font);
  padding: 7px 13px;
}

.seg button:last-child {
  border-right: none;
}

.seg button.on {
  background: var(--mod-soft);
  color: var(--mod-deep);
  font-weight: 600;
}

.field-hint {
  color: var(--ink-4);
  font-size: 11px;
  font-weight: 400;
}

.textarea {
  resize: vertical;
  min-height: 70px;
  line-height: 1.5;
}

[data-module] .note {
  background: var(--mod-soft);
  border: 1px solid var(--mod);
  align-items: flex-start;
  gap: 10px;
  display: flex;
}

@supports (color: color-mix(in lab, red, red)) {
  [data-module] .note {
    border: 1px solid color-mix(in srgb, var(--mod) 28%, var(--white));
  }
}

[data-module] .note {
  border-radius: var(--r-md);
  color: var(--mod-deep);
  padding: 11px 14px;
  font-size: 12.5px;
}

[data-module] .note.amber {
  background: var(--status-warn-soft);
  border-color: #ece1c6;
}

@supports (color: color-mix(in lab, red, red)) {
  [data-module] .note.amber {
    border-color: color-mix(in srgb, var(--status-warn) 35%, var(--white));
  }
}

[data-module] .note.amber {
  color: var(--status-warn-deep);
}

[data-module] .note .ic {
  font-weight: 700;
}

.horn-av {
  background: var(--ai-soft);
  border: 1px solid var(--ai-line);
  border-radius: 9px;
  flex-shrink: 0;
  justify-content: center;
  align-items: center;
  width: 34px;
  height: 34px;
  display: flex;
}

.horn-av.lg {
  border-radius: 11px;
  width: 44px;
  height: 44px;
}

.horn-card {
  background: var(--ai-grad);
  border: 1px solid var(--ai-line);
  border-radius: var(--r-md);
  padding: 16px 18px;
}

.horn-head {
  align-items: center;
  gap: 10px;
  margin-bottom: 4px;
  display: flex;
}

.horn-name {
  color: var(--ai-deep);
  font-size: 13px;
  font-weight: 700;
}

.horn-name small {
  color: var(--ai);
  font-weight: 500;
  font-family: var(--mono);
  letter-spacing: .04em;
  margin-left: 6px;
  font-size: 10px;
}

.horn-badge {
  font-family: var(--mono);
  letter-spacing: .06em;
  text-transform: uppercase;
  color: var(--ai-deep);
  background: var(--ai-soft);
  border: 1px solid var(--ai-line);
  border-radius: 99px;
  padding: 3px 8px;
  font-size: 9.5px;
}

.hitl {
  color: var(--ink-3);
  align-items: center;
  gap: 6px;
  font-size: 11px;
  display: inline-flex;
}

.horn-alert {
  background: #f9f8fe;
  grid-template-columns: 44px 1fr auto;
  gap: 16px;
  display: grid;
}

@supports (color: color-mix(in lab, red, red)) {
  .horn-alert {
    background: color-mix(in srgb, var(--ai) 4%, var(--white));
  }
}

.horn-alert {
  border: 1px solid var(--ai-line);
  border-left: 4px solid var(--ai);
  border-radius: var(--r-lg);
  align-items: start;
  margin-bottom: 22px;
  padding: 18px 20px;
}

.horn-alert .ha-top {
  flex-wrap: wrap;
  align-items: center;
  gap: 10px;
  margin-bottom: 6px;
  display: flex;
}

.horn-alert .ha-time {
  font-family: var(--mono);
  color: var(--ink-4);
  margin-left: auto;
  font-size: 10px;
}

.horn-alert .ha-title {
  color: var(--ink);
  letter-spacing: -.01em;
  font-size: 16px;
  font-weight: 600;
}

.horn-alert .ha-text {
  color: var(--ink-2);
  max-width: 760px;
  margin-top: 5px;
  font-size: 13px;
  line-height: 1.5;
}

.horn-alert .ha-sources {
  font-family: var(--mono);
  color: var(--ink-4);
  margin-top: 9px;
  font-size: 10.5px;
}

.horn-alert .ha-sources b {
  color: var(--ai-deep);
  font-weight: 600;
}

.horn-alert .ha-actions {
  flex-direction: column;
  align-items: stretch;
  gap: 8px;
  min-width: 180px;
  display: flex;
}

.feed-item {
  border-bottom: 1px solid var(--rule-soft);
  grid-template-columns: 34px 1fr;
  gap: 11px;
  padding: 12px 0;
  display: grid;
}

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

.feed-item .fi-title {
  color: var(--ink);
  font-size: 13px;
  font-weight: 600;
}

.feed-item .fi-desc {
  color: var(--ink-3);
  margin-top: 2px;
  font-size: 12px;
  line-height: 1.45;
}

.feed-item .fi-meta {
  font-family: var(--mono);
  color: var(--ink-4);
  margin-top: 5px;
  font-size: 10px;
}

.frist-row {
  border-bottom: 1px solid var(--rule-soft);
  justify-content: space-between;
  align-items: center;
  padding: 10px 0;
  font-size: 13px;
  display: flex;
}

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

.frist-row .fl {
  color: var(--ink-2);
}

.frist-row .fl small {
  color: var(--ink-4);
  font-size: 11px;
  display: block;
}

.col-2 {
  grid-template-columns: 1fr 1fr;
  gap: 14px;
  display: grid;
}

.flex-row {
  gap: 10px;
  display: flex;
}

[data-module="regulierte-stoffe"] .btn-primary {
  background: var(--mod);
  border-color: var(--mod);
  color: var(--white);
}

[data-module="regulierte-stoffe"] .btn-primary:hover {
  background: var(--mod-deep);
  border-color: var(--mod-deep);
}

[data-module="regulierte-stoffe"] .field-label {
  font-weight: 600;
}

@media print {
  .rs-no-print {
    display: none !important;
  }

  body {
    background: #fff !important;
  }
}

.hx-drawer-ft .grow, .grow {
  flex: 1;
}

.timeline .tl-item {
  --tc: var(--ink-4);
  gap: 10px;
  padding: 7px 0;
  display: flex;
  position: relative;
}

.timeline .tl-item:not(:last-child):before {
  content: "";
  background: var(--rule);
  width: 1px;
  position: absolute;
  top: 17px;
  bottom: -7px;
  left: 4px;
}

.timeline .tl-dot {
  z-index: 1;
  background: var(--tc);
  width: 9px;
  height: 9px;
  box-shadow: 0 0 0 2px var(--white);
  border-radius: 99px;
  flex-shrink: 0;
  margin-top: 4px;
  position: relative;
}

.timeline .tl-body {
  flex: 1;
  min-width: 0;
}

.timeline .tl-top {
  flex-wrap: wrap;
  align-items: center;
  gap: 6px;
  display: flex;
}

.timeline .tl-text {
  color: var(--ink-2);
  font-size: 12.5px;
  line-height: 1.45;
}

.timeline .tl-meta {
  font-family: var(--mono);
  color: var(--ink-4);
  margin-top: 2px;
  font-size: 9.5px;
}

.timeline .tl-meta .rel {
  opacity: .62;
}

.timeline .tl-more {
  font-family: var(--mono);
  color: var(--mod-deep);
  cursor: pointer;
  padding: 7px 0 2px 19px;
  font-size: 10.5px;
  display: inline-block;
}

.timeline .tl-more:hover {
  text-decoration: underline;
}

.timeline .tl-create {
  --tc: var(--status-info);
}

.timeline .tl-edit {
  --tc: var(--ink-3);
}

.timeline .tl-archive {
  --tc: var(--status-risk);
}

.timeline .tl-restore {
  --tc: var(--status-ok);
}

.timeline .tl-nis2 {
  --tc: var(--ai-deep);
}

.timeline .tl-review {
  --tc: var(--status-ok);
}

@keyframes ai-pulse {
  0% {
    opacity: .75;
    transform: scale(1);
  }

  70% {
    opacity: 0;
    transform: scale(3.4);
  }

  100% {
    opacity: 0;
    transform: scale(3.4);
  }
}

@keyframes ai-pulse-core {
  0%, 100% {
    box-shadow: 0 0 0 0 color-mix(in srgb,var(--ai) 55%,transparent);
    transform: scale(1);
  }

  50% {
    box-shadow: 0 0 6px 1px color-mix(in srgb,var(--ai) 60%,transparent);
    transform: scale(1.3);
  }
}

.fk-rsn {
  font-family: var(--mono);
  background: var(--paper-2);
  color: var(--ink-3);
  border-radius: 99px;
  padding: 2px 7px;
  font-size: 10px;
}

.fk-rsn.warn {
  background: var(--status-warn-soft);
  color: var(--status-warn-deep);
}

.fk-rsn.risk {
  background: var(--status-risk-soft);
  color: var(--status-risk-deep);
}

.card-tags {
  flex-wrap: wrap;
  gap: 5px;
  margin-top: 9px;
  display: flex;
}

.pbar {
  background: var(--rule);
  border-radius: 99px;
  height: 3px;
  margin-top: 9px;
  overflow: hidden;
}

.pbar i {
  background: var(--mod);
  border-radius: 99px;
  height: 100%;
  display: block;
}

.assign-suggest {
  border: 1px solid var(--ai-soft, #6d5ae033);
  flex-direction: column;
  gap: 0;
  display: flex;
}

@supports (color: color-mix(in lab, red, red)) {
  .assign-suggest {
    border: 1px solid var(--ai-soft, color-mix(in srgb,var(--ai, #7c3aed) 20%,transparent));
  }
}

.assign-suggest {
  border-radius: 8px;
  font-size: 12px;
  overflow: hidden;
}

.assign-suggest-head {
  background: var(--ai-soft, #6d5ae01a);
  align-items: center;
  gap: 6px;
  padding: 7px 10px;
  display: flex;
}

@supports (color: color-mix(in lab, red, red)) {
  .assign-suggest-head {
    background: var(--ai-soft, color-mix(in srgb,var(--ai, #7c3aed) 10%,transparent));
  }
}

.assign-suggest-head {
  border-bottom: 1px solid var(--ai-soft, #6d5ae033);
}

@supports (color: color-mix(in lab, red, red)) {
  .assign-suggest-head {
    border-bottom: 1px solid var(--ai-soft, color-mix(in srgb,var(--ai, #7c3aed) 20%,transparent));
  }
}

.assign-suggest-badge {
  letter-spacing: .04em;
  background: var(--ai, #7c3aed);
  color: var(--white, #fff);
  font-size: 10px;
  font-weight: 600;
  font-family: var(--mono);
  border-radius: 99px;
  align-items: center;
  gap: 3px;
  padding: 2px 7px;
  display: inline-flex;
}

.assign-suggest-body {
  flex-direction: column;
  gap: 0;
  display: flex;
}

.assign-suggest-row {
  border-bottom: 1px solid var(--rule, #00000012);
  flex-direction: column;
  gap: 5px;
  padding: 9px 10px;
  display: flex;
}

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

.assign-suggest-meta {
  flex-wrap: wrap;
  align-items: center;
  gap: 6px;
  display: flex;
}

.assign-suggest-name {
  color: var(--ink-2);
  white-space: nowrap;
  text-overflow: ellipsis;
  flex: 1;
  min-width: 0;
  font-weight: 500;
  overflow: hidden;
}

.assign-suggest-role {
  font-size: 10px;
  font-family: var(--mono);
  color: var(--ink-4);
}

.assign-suggest-conf {
  align-items: center;
  gap: 5px;
  display: flex;
}

.assign-suggest-bar {
  background: var(--rule);
  border-radius: 99px;
  flex: 1;
  height: 4px;
  overflow: hidden;
}

.assign-suggest-bar-fill {
  background: var(--ai, #7c3aed);
  border-radius: 99px;
  height: 100%;
  transition: width .2s;
}

.assign-suggest-pct {
  font-size: 10px;
  font-family: var(--mono);
  color: var(--ink-3);
  text-align: right;
  min-width: 2.5ch;
}

.assign-suggest-keywords {
  flex-wrap: wrap;
  gap: 4px;
  display: flex;
}

.assign-suggest-capacity {
  color: var(--ink-4);
  font-size: 10px;
}

.assign-suggest-foot {
  color: var(--ink-4);
  padding: 6px 10px;
  font-size: 10px;
  font-style: italic;
  line-height: 1.4;
}

.assign-suggest-empty {
  color: var(--ink-4);
  text-align: center;
  padding: 10px;
  font-size: 12px;
  font-style: italic;
}

.ki-badge {
  background: var(--ai, #7c3aed);
  color: var(--white, #fff);
  font-size: 9px;
  font-weight: 700;
  font-family: var(--mono);
  letter-spacing: .03em;
  vertical-align: middle;
  border-radius: 99px;
  align-items: center;
  margin-left: 3px;
  padding: 1px 5px;
  display: inline-flex;
}

.subtask-disc {
  cursor: pointer;
  background: conic-gradient(var(--mod) calc(var(--p, 0) * 1%), var(--paper-2) 0);
  border-radius: 50%;
  flex-shrink: 0;
  justify-content: center;
  align-items: center;
  width: 18px;
  height: 18px;
  display: flex;
  position: relative;
}

.subtask-disc:after {
  content: "";
  background: var(--white);
  border-radius: 50%;
  width: 11px;
  height: 11px;
}

.subtask-disc.is-done {
  background: var(--mod);
}

.subtask-disc.is-done:after {
  background: var(--mod-soft, var(--mod));
}

@supports (color: color-mix(in lab, red, red)) {
  .subtask-disc.is-done:after {
    background: var(--mod-soft, color-mix(in srgb,var(--mod) 20%,var(--white)));
  }
}

.subtask-pct {
  font-family: var(--mono);
  color: var(--mod-deep, var(--mod));
  font-size: 10px;
  font-weight: 600;
}

.subtask-edit {
  background: var(--paper-2);
  border: 1px solid var(--rule);
  border-radius: var(--r-md, 6px);
  flex-direction: column;
  gap: 10px;
  margin: 0 0 8px 28px;
  padding: 10px 12px;
  display: flex;
}

.subtask-edit .r {
  justify-content: space-between;
  align-items: center;
  gap: 10px;
  display: flex;
}

.subtask-edit .r.stack {
  flex-direction: column;
  align-items: stretch;
  gap: 6px;
}

.subtask-edit .lbl {
  font-size: 10px;
  font-family: var(--mono);
  text-transform: uppercase;
  letter-spacing: .04em;
  color: var(--ink-4);
  justify-content: space-between;
  align-items: center;
  gap: 8px;
  display: flex;
}

.subtask-edit .lbl b {
  color: var(--mod-deep, var(--mod));
  font-family: var(--font);
  font-size: 11px;
  font-weight: 600;
}

.subtask-edit .range-ov {
  opacity: 0;
  cursor: pointer;
  width: 100%;
  height: 100%;
  margin: 0;
  position: absolute;
  inset: 0;
}

.subtask-type-warn {
  border-radius: var(--r-md, 6px);
  background: var(--status-warn-soft);
  border: 1px solid #c9a85c4d;
  align-items: flex-start;
  gap: 8px;
  margin-top: 8px;
  padding: 8px 10px;
  display: flex;
}

@supports (color: color-mix(in lab, red, red)) {
  .subtask-type-warn {
    border: 1px solid color-mix(in srgb,var(--status-warn) 30%,transparent);
  }
}

.subtask-type-warn {
  color: var(--status-warn-deep);
  flex-wrap: wrap;
  font-size: 12px;
  line-height: 1.45;
}

.subtask-type-warn .tw-acts {
  gap: 7px;
  margin-left: auto;
  display: flex;
}

.role-field {
  flex-direction: column;
  gap: 6px;
  display: flex;
}

.role-field-chips {
  flex-wrap: wrap;
  gap: 4px;
  min-height: 24px;
  display: flex;
}

.rf-chip {
  background: var(--paper-2);
  border: 1px solid var(--rule);
  color: var(--ink-2);
  border-radius: 99px;
  align-items: center;
  gap: 5px;
  max-width: 160px;
  padding: 3px 8px;
  font-size: 11px;
  display: inline-flex;
}

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

.rf-chip-x {
  cursor: pointer;
  color: var(--ink-4);
  background: none;
  border: none;
  flex-shrink: 0;
  align-items: center;
  padding: 0;
  line-height: 1;
  display: inline-flex;
}

.rf-chip-x:hover {
  color: var(--status-risk);
}

.dp-prog {
  background: var(--rule);
  border-radius: 3px;
  height: 5px;
  margin-bottom: 14px;
  overflow: hidden;
}

.dp-seg-bar {
  background: var(--mod);
  border-radius: 3px;
  height: 100%;
  transition: width .4s;
}

.dp-counter {
  color: var(--ink-3);
  background: var(--mod-soft);
  border-radius: 999px;
  align-items: center;
  gap: 9px;
  margin-bottom: 26px;
  padding: 7px 15px;
  font-size: 13px;
  display: inline-flex;
}

.dp-counter b {
  color: var(--mod-deep);
  font-variant-numeric: tabular-nums;
  font-size: 15px;
}

.dp-counter .live {
  background: var(--status-ok);
  border-radius: 50%;
  width: 7px;
  height: 7px;
  animation: 1.8s ease-out infinite blip;
}

.dp-flow-foot {
  justify-content: space-between;
  align-items: center;
  margin-top: 16px;
  display: flex;
}

.dp-flow-foot .dp-skip {
  color: var(--ink-4);
  cursor: pointer;
  background: none;
  border: 0;
  font-family: inherit;
  font-size: 13px;
}

.dp-flow-foot .dp-skip:hover {
  color: var(--ink-2);
}

.dp-pickwrap {
  background: var(--white);
  border: 1px solid var(--rule);
  border-radius: var(--r-lg);
  margin-top: 18px;
  padding: 18px;
}

.dp-domtabs {
  flex-wrap: wrap;
  gap: 6px;
  margin-bottom: 18px;
  display: flex;
}

.dp-domtab {
  font: inherit;
  white-space: nowrap;
  border: 1.5px solid var(--rule);
  background: var(--white);
  color: var(--ink-3);
  cursor: pointer;
  border-radius: 999px;
  align-items: center;
  gap: 7px;
  padding: 8px 16px;
  font-size: 12.5px;
  font-weight: 600;
  transition: all .15s;
  display: flex;
}

.dp-domtab .n {
  font-family: var(--mono);
  background: var(--paper);
  color: var(--ink-4);
  border-radius: 999px;
  padding: 1px 6px;
  font-size: 10px;
}

.dp-domtab:hover {
  border-color: var(--mod);
  color: var(--mod-deep);
}

.dp-domtab.on {
  background: var(--mod);
  border-color: var(--mod);
  color: #fff;
}

.dp-domtab.on .n {
  color: #fff;
  background: #ffffff40;
}

.dp-domtab.has .n {
  background: var(--mod-soft);
  color: var(--mod-deep);
}

.dp-domtab.on.has .n {
  color: #fff;
  background: #ffffff40;
}

.dp-tilegrid {
  grid-template-columns: repeat(auto-fill, minmax(168px, 1fr));
  gap: 12px;
  display: grid;
}

.dp-tile {
  background: var(--white);
  border: 1.5px solid var(--rule);
  border-radius: var(--r-lg);
  cursor: pointer;
  text-align: center;
  padding: 18px 14px 15px;
  transition: transform .16s, border-color .16s, box-shadow .16s;
  position: relative;
  overflow: hidden;
}

.dp-tile:hover {
  border-color: var(--mod);
  box-shadow: var(--shadow-card);
  transform: translateY(-3px);
}

.dp-tile .ti {
  margin-bottom: 10px;
  font-size: 30px;
  line-height: 1;
  transition: transform .25s;
  display: inline-block;
}

.dp-tile:hover .ti {
  transform: scale(1.12)rotate(-4deg);
}

.dp-tile .tn {
  color: var(--ink-2);
  font-size: 12.5px;
  font-weight: 600;
  line-height: 1.35;
}

.dp-tile .dp-tcheck {
  border: 1.5px solid var(--rule);
  background: var(--white);
  border-radius: 50%;
  place-items: center;
  width: 22px;
  height: 22px;
  transition: all .15s;
  display: grid;
  position: absolute;
  top: 9px;
  right: 9px;
}

.dp-tile.sel {
  border-color: var(--mod);
  background: var(--mod-soft);
  box-shadow: 0 0 0 3px var(--mod);
}

@supports (color: color-mix(in lab, red, red)) {
  .dp-tile.sel {
    box-shadow: 0 0 0 3px color-mix(in srgb,var(--mod) 18%,transparent);
  }
}

.dp-tile.sel .dp-tcheck {
  background: var(--mod);
  border-color: var(--mod);
}

.dp-tile.sel .dp-tcheck:after {
  content: "";
  border: 2px solid #fff;
  border-width: 0 2px 2px 0;
  width: 6px;
  height: 10px;
  transform: rotate(45deg)translateY(-1px);
}

.dp-tile.sel .tn {
  color: var(--mod-deep);
  font-weight: 700;
}

.dp-tile-custom {
  cursor: default;
  border-style: dashed;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 8px;
  display: flex;
}

.dp-tile-custom:hover {
  box-shadow: none;
  transform: none;
}

.dp-tile-input {
  width: 100%;
  font: inherit;
  text-align: center;
  border: 1px solid var(--rule);
  border-radius: var(--r-sm);
  color: var(--ink);
  padding: 7px 8px;
  font-size: 12.5px;
}

.dp-tile-input:focus {
  border-color: var(--ai);
  box-shadow: 0 0 0 3px var(--ai-soft);
  outline: none;
}

.dp-tile-addbtn {
  font: inherit;
  background: var(--ai);
  color: var(--white);
  border-radius: var(--r-sm);
  cursor: pointer;
  border: 0;
  padding: 6px 12px;
  font-size: 11.5px;
  font-weight: 600;
}

.dp-tile-addbtn:hover {
  background: var(--ai-deep);
}

.dp-tempo-track {
  background: linear-gradient(90deg, var(--status-risk), #e8c14a 52%, var(--status-ok));
  border-radius: 5px;
  height: 8px;
  position: relative;
}

.dp-tempo-input {
  appearance: none;
  cursor: pointer;
  background: none;
  width: 100%;
  height: 34px;
  margin-top: -21px;
  display: block;
  position: relative;
}

.dp-tempo-input::-webkit-slider-thumb {
  -webkit-appearance: none;
  background: var(--white);
  border: 3px solid var(--mod);
  width: 24px;
  height: 24px;
  box-shadow: var(--shadow-card);
  cursor: grab;
  border-radius: 50%;
}

.dp-tempo-input::-moz-range-thumb {
  background: var(--white);
  border: 3px solid var(--mod);
  width: 24px;
  height: 24px;
  box-shadow: var(--shadow-card);
  cursor: grab;
  border-style: solid;
  border-radius: 50%;
}

.dp-tempo-ends {
  color: var(--ink-4);
  justify-content: space-between;
  align-items: center;
  margin-top: 5px;
  font-size: 11.5px;
  display: flex;
}

.dp-tempo-current {
  white-space: nowrap;
  align-items: center;
  gap: 5px;
  font-size: 12.5px;
  font-weight: 700;
  display: inline-flex;
}

.dp-tempo-sub {
  color: var(--ink-3);
  font-size: 11.5px;
  font-weight: 400;
}

.dp-tempo-main {
  position: relative;
}

.dp-tempo-track-emoji {
  height: 10px;
}

.dp-tempo-input-emoji::-webkit-slider-thumb {
  opacity: 0;
}

.dp-tempo-input-emoji::-moz-range-thumb {
  opacity: 0;
}

.dp-tempo-main-emoji {
  padding-top: 32px;
}

.dp-tempo-emoji-thumb {
  background: var(--white);
  border: 2.5px solid var(--mod);
  pointer-events: none;
  z-index: 2;
  width: 54px;
  height: 54px;
  box-shadow: var(--shadow-card);
  border-radius: 50%;
  place-items: center;
  font-size: 37px;
  line-height: 1;
  display: grid;
  position: absolute;
  top: 37px;
  transform: translate(-50%, -50%);
}

.dp-tempo-emoji-pop {
  animation: .35s cubic-bezier(.34, 1.56, .64, 1) dp-emoji-pop;
}

@keyframes dp-emoji-pop {
  0% {
    opacity: 0;
    transform: translate(-50%, -50%)scale(.3)rotate(-12deg);
  }

  60% {
    opacity: 1;
    transform: translate(-50%, -50%)scale(1.25)rotate(4deg);
  }

  100% {
    transform: translate(-50%, -50%)scale(1)rotate(0);
  }
}

.dp-tempo-suggest-marker {
  cursor: pointer;
  background: radial-gradient(circle at 32% 28%, var(--ai-bright, var(--ai)), var(--ai));
  border-radius: 50%;
  place-items: center;
  width: 16px;
  height: 16px;
  animation: 2.2s ease-in-out infinite dp-orbpulse;
  display: grid;
  position: absolute;
  top: -22px;
  transform: translateX(-50%);
}

.dp-tempo-suggest-marker svg {
  stroke: #fff;
  fill: none;
  stroke-width: 2.6px;
  stroke-linecap: round;
  stroke-linejoin: round;
  width: 9px;
  height: 9px;
}

.dp-tempo-suggest-marker:after {
  content: "";
  background: var(--ai);
  width: 1px;
  height: 6px;
  position: absolute;
  top: 16px;
  left: 50%;
  transform: translateX(-50%);
}

.dp-tempo-suggest-marker:hover {
  filter: brightness(1.08);
}

.dp-tempo-suggest-chip {
  font-family: var(--mono);
  letter-spacing: .05em;
  text-transform: uppercase;
  background: var(--ai-tint);
  color: var(--ai-deep);
  border: 1px solid #c6bde0;
  align-items: center;
  gap: 6px;
  margin-top: 8px;
  font-size: 10.5px;
  display: inline-flex;
}

@supports (color: color-mix(in lab, red, red)) {
  .dp-tempo-suggest-chip {
    border: 1px solid color-mix(in srgb, var(--ai) 30%, var(--rule));
  }
}

.dp-tempo-suggest-chip {
  cursor: pointer;
  border-radius: 999px;
  padding: 5px 12px;
}

.dp-tempo-suggest-chip:before {
  content: "";
  background: var(--ai);
  border-radius: 50%;
  flex-shrink: 0;
  width: 5px;
  height: 5px;
}

.dp-tempo-suggest-chip:hover {
  filter: brightness(1.08);
}

.dp-suggest-all {
  background: var(--ai-tint, var(--ai-soft));
  border: 1px solid #d0c9e0;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  display: flex;
}

@supports (color: color-mix(in lab, red, red)) {
  .dp-suggest-all {
    border: 1px solid color-mix(in srgb, var(--ai) 22%, var(--rule));
  }
}

.dp-suggest-all {
  border-radius: var(--r-md);
  margin-top: 4px;
  padding: 10px 14px;
}

.dp-suggest-all-label {
  color: var(--ai-deep);
  font-size: 12.5px;
  font-weight: 600;
}

.dp-suggest-all-actions {
  gap: 8px;
  display: flex;
}

.dp-rc-meta {
  justify-content: space-between;
  align-items: center;
  margin-bottom: 8px;
  display: flex;
}

.dp-rc-of {
  font-family: var(--mono);
  letter-spacing: .05em;
  color: var(--ink-4);
  font-size: 11px;
}

.dp-rc-of b {
  color: var(--mod-deep);
}

.dp-rc-card {
  background: var(--white);
  border: 1px solid var(--rule);
  border-radius: var(--r-lg);
  box-shadow: var(--shadow-card);
  overflow: hidden;
}

.dp-rc-top {
  border-bottom: 1px solid var(--rule);
  align-items: center;
  gap: 11px;
  padding: 12px 20px;
  display: flex;
}

.dp-rc-top .pico {
  background: var(--mod-soft);
  border-radius: 9px;
  flex-shrink: 0;
  place-items: center;
  width: 34px;
  height: 34px;
  font-size: 17px;
  display: grid;
}

.dp-rc-top h3 {
  font-size: 15px;
}

.dp-rc-top .pdom {
  color: var(--ink-4);
  font-size: 12px;
}

.dp-rc-body {
  flex-direction: column;
  gap: 13px;
  padding: 14px 20px;
  display: flex;
}

.dp-rc-q .ql {
  color: var(--ink);
  align-items: center;
  gap: 8px;
  margin-bottom: 6px;
  font-size: 13.5px;
  font-weight: 600;
  display: flex;
}

.dp-rc-q .ql .opt {
  color: var(--ink-4);
  font-size: 12px;
  font-weight: 400;
}

.dp-mbchip {
  font: inherit;
  border: 1.5px solid var(--rule);
  background: var(--white);
  color: var(--ink-2);
  border-radius: var(--r-md);
  cursor: pointer;
  align-items: center;
  gap: 8px;
  padding: 8px 13px;
  font-size: 12.5px;
  transition: all .13s;
  display: inline-flex;
}

.dp-mbchip:hover {
  border-color: var(--mod);
}

.dp-mbchip.sel {
  border-color: var(--mod);
  background: var(--mod-soft);
  color: var(--mod-deep);
  font-weight: 600;
}

.dp-mbchip.bad.sel {
  border-color: var(--status-risk);
  background: #faf0ee;
}

@supports (color: color-mix(in lab, red, red)) {
  .dp-mbchip.bad.sel {
    background: color-mix(in srgb,var(--status-risk) 9%,var(--white));
  }
}

.dp-mbchip.bad.sel {
  color: var(--status-risk);
}

.dp-freq-chips {
  flex-wrap: wrap;
  gap: 8px;
  display: flex;
}

.dp-freq-chip {
  font: inherit;
  border: 1.5px solid var(--rule);
  background: var(--white);
  color: var(--ink-2);
  border-radius: var(--r-md);
  cursor: pointer;
  padding: 8px 14px;
  font-size: 12.5px;
  transition: all .13s;
}

.dp-freq-chip:hover {
  border-color: var(--mod);
}

.dp-freq-chip.sel {
  border-color: var(--mod);
  background: var(--mod-soft);
  color: var(--mod-deep);
  font-weight: 600;
}

.dp-emo {
  gap: 10px;
  display: flex;
}

.dp-emo button {
  border-radius: var(--r-md);
  border: 1.5px solid var(--rule);
  background: var(--white);
  cursor: pointer;
  filter: grayscale(.4);
  width: 54px;
  height: 54px;
  font-size: 26px;
  line-height: 1;
  transition: all .13s;
}

.dp-emo button:hover {
  border-color: var(--mod);
  filter: none;
}

.dp-emo button.sel {
  border-color: var(--mod);
  background: var(--mod-soft);
  filter: none;
  transform: scale(1.06);
}

.dp-rc-note {
  resize: none;
  width: 100%;
  font: inherit;
  border: 1px solid var(--rule);
  border-radius: var(--r-md);
  color: var(--ink);
  min-height: 44px;
  padding: 9px 12px;
  font-size: 13.5px;
}

.dp-rc-note:focus {
  border-color: var(--mod);
  box-shadow: 0 0 0 3px var(--mod-soft);
  outline: none;
}

.dp-rc-note::placeholder {
  color: var(--ink-4);
}

.dp-answer-summary {
  background: var(--paper);
  border: 1px solid var(--rule);
  border-radius: var(--r-md);
  color: var(--ink-3);
  margin-top: 4px;
  padding: 12px 14px;
  font-size: 12.5px;
  line-height: 1.5;
}

.dp-answer-summary b {
  color: var(--ink-2);
}

.dp-answer-summary .lbl {
  font-family: var(--mono);
  letter-spacing: .06em;
  text-transform: uppercase;
  color: var(--ink-4);
  margin-bottom: 5px;
  font-size: 9px;
  display: block;
}

.dp-spiegel {
  text-align: center;
  max-width: 640px;
  margin: 0 auto;
}

.dp-done-mark {
  background: radial-gradient(circle at 32% 28%, var(--ai-bright, var(--ai)), var(--ai));
  border-radius: 50%;
  place-items: center;
  width: 60px;
  height: 60px;
  margin: 0 auto 18px;
  display: grid;
}

.dp-done-mark svg {
  stroke: #fff;
  fill: none;
  stroke-width: 2.4px;
  stroke-linecap: round;
  stroke-linejoin: round;
  width: 30px;
  height: 30px;
}

.dp-mirror {
  background: var(--white);
  border: 1px solid var(--rule);
  border-radius: var(--r-lg);
  box-shadow: var(--shadow-card);
  text-align: left;
  margin: 22px 0;
  padding: 20px 22px;
}

.dp-mirror .mh {
  justify-content: space-between;
  align-items: center;
  margin-bottom: 16px;
  display: flex;
}

.dp-mirror .mh b {
  font-size: 14px;
}

.dp-mirror .mh .tag-mod {
  font-family: var(--mono);
  letter-spacing: .05em;
  text-transform: uppercase;
  color: var(--mod-deep);
  background: var(--mod-soft);
  border-radius: 999px;
  padding: 3px 9px;
  font-size: 10px;
}

.dp-mrow {
  grid-template-columns: 160px 1fr 60px;
  align-items: center;
  gap: 12px;
  padding: 7px 0;
  display: grid;
}

.dp-mrow + .dp-mrow {
  border-top: 1px solid var(--rule);
}

.dp-mrow .mn {
  color: var(--ink-2);
  font-size: 13px;
}

.dp-mrow .mbar {
  background: var(--paper);
  border-radius: 5px;
  height: 9px;
  overflow: hidden;
}

.dp-mrow .mfill {
  border-radius: 5px;
  height: 100%;
}

.dp-mrow .mv {
  font-size: 12px;
  font-family: var(--mono);
  color: var(--ink-3);
  text-align: right;
}

.dp-closer {
  color: var(--ink-3);
  text-wrap: pretty;
  font-size: 13.5px;
}

.dp-confetti-piece {
  pointer-events: none;
  z-index: 50;
  opacity: .9;
  border-radius: 2px;
  position: fixed;
  top: -12px;
}

.dp-drei-wege-title {
  color: var(--ink);
  text-align: center;
  margin-top: 28px;
  margin-bottom: 8px;
  font-size: 19px;
  font-weight: 700;
}

.dp-drei-wege-sub {
  color: var(--ink-3);
  text-align: center;
  max-width: 560px;
  margin: 0 auto 6px;
  font-size: 13px;
  line-height: 1.5;
}

.dp-mirror .mh .tag-mod.ai {
  background: var(--ai-soft);
  color: var(--ai-deep);
}

.dp-mirror .mh .tag-mod.ok {
  background: var(--status-ok-soft, var(--ai-soft));
  color: var(--status-ok);
}

.dp-mirror .pain {
  margin-bottom: 12px;
  padding-top: 4px;
}

.dp-mirror .pain:last-child {
  margin-bottom: 0;
}

.dp-mirror .pt {
  align-items: center;
  gap: 10px;
  margin-bottom: 6px;
  display: flex;
}

.dp-mirror .rank {
  color: #fff;
  border-radius: 50%;
  flex-shrink: 0;
  place-items: center;
  width: 22px;
  height: 22px;
  font-size: 11px;
  font-weight: 700;
  display: grid;
}

.dp-mirror .rank.r1 {
  background: var(--ai-deep);
}

.dp-mirror .rank.r2 {
  background: var(--ai);
}

.dp-mirror .rank.r3 {
  background: var(--mod);
}

.dp-mirror .rank.rok {
  background: var(--status-ok);
}

.dp-mirror .rank.rneutral {
  background: var(--ink-4);
}

.dp-mirror .pn {
  color: var(--ink);
  font-size: 13px;
  font-weight: 600;
}

.dp-mirror .quote {
  color: var(--ink-3);
  border-left: 2px solid var(--rule);
  margin-left: 32px;
  padding-left: 14px;
  font-size: 12.5px;
  line-height: 1.5;
}

.dp-mirror .quote.q1 {
  border-left-color: var(--ai-deep);
}

.dp-mirror .quote.q2 {
  border-left-color: var(--ai);
}

.dp-mirror .quote.q3 {
  border-left-color: var(--mod);
}

.dp-mirror .quote.qok {
  border-left-color: var(--status-ok);
}

.dp-mirror .quote.qneutral {
  border-left-color: var(--ink-4);
}

.dp-two-col {
  grid-template-columns: 1fr 1fr;
  gap: 16px;
  margin: 22px 0;
  display: grid;
}

.dp-two-col .dp-mirror {
  margin: 0;
}

@media (max-width: 640px) {
  .dp-two-col {
    grid-template-columns: 1fr;
  }
}

.dp-hornaut-closer {
  text-align: left;
  background: var(--ai-tint, var(--ai-soft));
  border: 1px solid #d5cee0;
  align-items: flex-start;
  gap: 10px;
  display: flex;
}

@supports (color: color-mix(in lab, red, red)) {
  .dp-hornaut-closer {
    border: 1px solid color-mix(in srgb, var(--ai) 18%, var(--rule));
  }
}

.dp-hornaut-closer {
  border-radius: var(--r-lg);
  margin: 18px 0;
  padding: 14px 16px;
}

.dp-hornaut-closer .dp-rail-av {
  flex-shrink: 0;
}

.dp-hornaut-closer .tx {
  color: var(--ink-2);
  font-size: 13px;
  line-height: 1.55;
}

.dp-hornaut-closer .tx b {
  color: var(--ink);
}

@keyframes dp-confetti-fall {
  to {
    opacity: 0;
    transform: translateY(110vh)rotate(540deg);
  }
}

@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-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-space-x-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-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: 0;
}

@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-ease {
  syntax: "*";
  inherits: false
}

@keyframes pulse {
  50% {
    opacity: .5;
  }
}

/* [project]/packages/editor/src/theme.css [app-client] (css) */
.horn-editor {
  --horn-editor-bg: var(--color-paper, #f6f4ef);
  --horn-editor-fg: var(--color-ink, #1a1a1a);
  --horn-editor-muted: var(--color-ink-3, #6a6a6a);
  --horn-editor-accent: var(--color-horn-blue, #327cd9);
  --horn-editor-accent-deep: var(--color-horn-blue-deep, #1e5cb0);
  --horn-editor-accent-soft: var(--color-horn-blue-soft, #e6effa);
  --horn-editor-rule: var(--color-rule, #e6e3dc);
  color: var(--horn-editor-fg);
  border: 1px solid var(--horn-editor-rule);
  font-family: var(--font-sans, system-ui, sans-serif);
  background: #fff;
  border-radius: 6px;
  font-size: 14px;
  line-height: 1.55;
}

.horn-editor .ProseMirror {
  outline: none;
  min-height: 8rem;
  padding: 1rem 1.25rem;
}

.horn-editor .ProseMirror:focus {
  outline: none;
}

.horn-editor .ProseMirror h1 {
  margin: 1em 0 .4em;
  font-size: 1.7em;
  font-weight: 700;
  line-height: 1.25;
}

.horn-editor .ProseMirror h2 {
  margin: .9em 0 .35em;
  font-size: 1.35em;
  font-weight: 600;
  line-height: 1.3;
}

.horn-editor .ProseMirror h3 {
  margin: .8em 0 .3em;
  font-size: 1.15em;
  font-weight: 600;
  line-height: 1.35;
}

.horn-editor .ProseMirror p {
  margin: .5em 0;
}

.horn-editor .ProseMirror ul, .horn-editor .ProseMirror ol {
  margin: .5em 0;
  padding-left: 1.4em;
}

.horn-editor .ProseMirror ul {
  list-style: outside;
}

.horn-editor .ProseMirror ol {
  list-style: decimal;
}

.horn-editor .ProseMirror li {
  margin: .15em 0;
}

.horn-editor .ProseMirror li > p {
  margin: 0;
}

.horn-editor .ProseMirror blockquote {
  border-left: 3px solid var(--horn-editor-rule);
  color: var(--horn-editor-muted);
  margin: .5em 0;
  padding: .1em .8em;
}

.horn-editor .ProseMirror code {
  background: var(--horn-editor-accent-soft);
  color: var(--horn-editor-accent-deep);
  font-family: var(--font-mono, ui-monospace, monospace);
  border-radius: 3px;
  padding: .1em .3em;
  font-size: .9em;
}

.horn-editor .ProseMirror pre {
  border: 1px solid var(--horn-editor-rule);
  font-family: var(--font-mono, ui-monospace, monospace);
  background: #f3f1eb;
  border-radius: 4px;
  margin: .6em 0;
  padding: .6em .8em;
  font-size: .9em;
  line-height: 1.45;
  overflow-x: auto;
}

.horn-editor .ProseMirror pre code {
  color: inherit;
  background: none;
  padding: 0;
}

.horn-editor .ProseMirror a {
  color: var(--horn-editor-accent-deep);
  text-decoration: underline;
}

.horn-editor .ProseMirror hr {
  border: 0;
  border-top: 1px solid var(--horn-editor-rule);
  margin: 1em 0;
}

.horn-editor .ProseMirror strong {
  font-weight: 600;
}

.horn-editor .ProseMirror em {
  font-style: italic;
}

.horn-editor .horn-variable-chip {
  background: var(--horn-editor-accent-soft);
  color: var(--horn-editor-accent-deep);
  white-space: nowrap;
  cursor: default;
  -webkit-user-select: none;
  user-select: none;
  border-radius: 999px;
  margin: 0 .1em;
  padding: 0 .4em;
  font-size: .9em;
  font-weight: 500;
  display: inline-block;
}

.horn-editor .horn-variable-chip.ProseMirror-selectednode {
  outline: 2px solid var(--horn-editor-accent);
}

.horn-editor .horn-locked-region {
  background: var(--horn-editor-accent-soft);
  border-left: 3px solid var(--horn-editor-accent);
  opacity: .85;
  border-radius: 0 4px 4px 0;
  margin: .5rem 0;
  padding: .5rem .75rem;
}

.horn-editor .horn-table {
  border-collapse: collapse;
  width: 100%;
  margin: .75rem 0;
}

.horn-editor .horn-table td, .horn-editor .horn-table th {
  border: 1px solid var(--horn-editor-rule);
  vertical-align: top;
  padding: .4em .7em;
}

.horn-editor .horn-table th {
  background: var(--horn-editor-accent-soft);
  text-align: left;
  font-weight: 600;
}

.horn-editor-toolbar {
  border-bottom: 1px solid var(--horn-editor-rule);
  background: var(--horn-editor-bg);
  border-radius: 6px 6px 0 0;
  flex-wrap: wrap;
  gap: .25rem;
  padding: .4rem;
  display: flex;
}

.horn-editor-toolbar button {
  color: var(--horn-editor-fg);
  cursor: pointer;
  background: none;
  border: 1px solid #0000;
  border-radius: 4px;
  padding: .25rem .5rem;
  font-size: 13px;
}

.horn-editor-toolbar button:hover {
  border-color: var(--horn-editor-rule);
  background: #fff;
}

.horn-editor-toolbar button.is-active {
  background: var(--horn-editor-accent-soft);
  color: var(--horn-editor-accent-deep);
  border-color: var(--horn-editor-accent-soft);
}

.horn-editor-toolbar .horn-variable-insert {
  position: relative;
}

.horn-editor-toolbar .horn-variable-insert-menu {
  z-index: 10;
  border: 1px solid var(--horn-editor-rule);
  background: #fff;
  border-radius: 6px;
  min-width: 220px;
  max-height: 320px;
  padding: .4rem;
  position: absolute;
  top: 100%;
  left: 0;
  overflow: auto;
  box-shadow: 0 6px 18px #00000014;
}

.horn-editor-toolbar .horn-variable-insert-menu .group-label {
  text-transform: uppercase;
  color: var(--horn-editor-muted);
  padding: .3rem .5rem .15rem;
  font-size: 11px;
}

.horn-editor-toolbar .horn-variable-insert-menu .item {
  cursor: pointer;
  border-radius: 4px;
  justify-content: space-between;
  align-items: baseline;
  gap: .5rem;
  padding: .3rem .5rem;
  display: flex;
}

.horn-editor-toolbar .horn-variable-insert-menu .item:hover {
  background: var(--horn-editor-accent-soft);
}

.horn-editor-toolbar .horn-variable-insert-menu .item .example {
  color: var(--horn-editor-muted);
  font-size: 11px;
  font-family: var(--font-mono, ui-monospace, monospace);
}

/*# sourceMappingURL=_0tu123l._.css.map*/