/*! tailwindcss v4.1.18 | MIT License | https://tailwindcss.com */
@charset "UTF-8";
@layer properties;
@layer theme, base, components, utilities;
@layer theme {
  :root, :host {
    --font-sans: ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji",
      "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";
    --font-serif: ui-serif, Georgia, Cambria, "Times New Roman", Times, serif;
    --font-mono: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono",
      "Courier New", monospace;
    --color-red-50: oklch(97.1% 0.013 17.38);
    --color-red-100: oklch(93.6% 0.032 17.717);
    --color-red-200: oklch(88.5% 0.062 18.334);
    --color-red-300: oklch(80.8% 0.114 19.571);
    --color-red-400: oklch(70.4% 0.191 22.216);
    --color-red-500: oklch(63.7% 0.237 25.331);
    --color-red-600: oklch(57.7% 0.245 27.325);
    --color-red-700: oklch(50.5% 0.213 27.518);
    --color-red-800: oklch(44.4% 0.177 26.899);
    --color-red-900: oklch(39.6% 0.141 25.723);
    --color-red-950: oklch(25.8% 0.092 26.042);
    --color-orange-50: oklch(98% 0.016 73.684);
    --color-orange-100: oklch(95.4% 0.038 75.164);
    --color-orange-200: oklch(90.1% 0.076 70.697);
    --color-orange-300: oklch(83.7% 0.128 66.29);
    --color-orange-400: oklch(75% 0.183 55.934);
    --color-orange-500: oklch(70.5% 0.213 47.604);
    --color-orange-600: oklch(64.6% 0.222 41.116);
    --color-orange-700: oklch(55.3% 0.195 38.402);
    --color-orange-800: oklch(47% 0.157 37.304);
    --color-orange-900: oklch(40.8% 0.123 38.172);
    --color-orange-950: oklch(26.6% 0.079 36.259);
    --color-amber-50: oklch(98.7% 0.022 95.277);
    --color-amber-100: oklch(96.2% 0.059 95.617);
    --color-amber-200: oklch(92.4% 0.12 95.746);
    --color-amber-300: oklch(87.9% 0.169 91.605);
    --color-amber-400: oklch(82.8% 0.189 84.429);
    --color-amber-500: oklch(76.9% 0.188 70.08);
    --color-amber-600: oklch(66.6% 0.179 58.318);
    --color-amber-700: oklch(55.5% 0.163 48.998);
    --color-amber-800: oklch(47.3% 0.137 46.201);
    --color-amber-900: oklch(41.4% 0.112 45.904);
    --color-amber-950: oklch(27.9% 0.077 45.635);
    --color-yellow-50: oklch(98.7% 0.026 102.212);
    --color-yellow-100: oklch(97.3% 0.071 103.193);
    --color-yellow-200: oklch(94.5% 0.129 101.54);
    --color-yellow-300: oklch(90.5% 0.182 98.111);
    --color-yellow-400: oklch(85.2% 0.199 91.936);
    --color-yellow-500: oklch(79.5% 0.184 86.047);
    --color-yellow-600: oklch(68.1% 0.162 75.834);
    --color-yellow-700: oklch(55.4% 0.135 66.442);
    --color-yellow-800: oklch(47.6% 0.114 61.907);
    --color-yellow-900: oklch(42.1% 0.095 57.708);
    --color-yellow-950: oklch(28.6% 0.066 53.813);
    --color-lime-50: oklch(98.6% 0.031 120.757);
    --color-lime-100: oklch(96.7% 0.067 122.328);
    --color-lime-200: oklch(93.8% 0.127 124.321);
    --color-lime-300: oklch(89.7% 0.196 126.665);
    --color-lime-400: oklch(84.1% 0.238 128.85);
    --color-lime-500: oklch(76.8% 0.233 130.85);
    --color-lime-600: oklch(64.8% 0.2 131.684);
    --color-lime-700: oklch(53.2% 0.157 131.589);
    --color-lime-800: oklch(45.3% 0.124 130.933);
    --color-lime-900: oklch(40.5% 0.101 131.063);
    --color-lime-950: oklch(27.4% 0.072 132.109);
    --color-green-50: oklch(98.2% 0.018 155.826);
    --color-green-100: oklch(96.2% 0.044 156.743);
    --color-green-200: oklch(92.5% 0.084 155.995);
    --color-green-300: oklch(87.1% 0.15 154.449);
    --color-green-400: oklch(79.2% 0.209 151.711);
    --color-green-500: oklch(72.3% 0.219 149.579);
    --color-green-600: oklch(62.7% 0.194 149.214);
    --color-green-700: oklch(52.7% 0.154 150.069);
    --color-green-800: oklch(44.8% 0.119 151.328);
    --color-green-900: oklch(39.3% 0.095 152.535);
    --color-green-950: oklch(26.6% 0.065 152.934);
    --color-emerald-50: oklch(97.9% 0.021 166.113);
    --color-emerald-100: oklch(95% 0.052 163.051);
    --color-emerald-200: oklch(90.5% 0.093 164.15);
    --color-emerald-300: oklch(84.5% 0.143 164.978);
    --color-emerald-400: oklch(76.5% 0.177 163.223);
    --color-emerald-500: oklch(69.6% 0.17 162.48);
    --color-emerald-600: oklch(59.6% 0.145 163.225);
    --color-emerald-700: oklch(50.8% 0.118 165.612);
    --color-emerald-800: oklch(43.2% 0.095 166.913);
    --color-emerald-900: oklch(37.8% 0.077 168.94);
    --color-emerald-950: oklch(26.2% 0.051 172.552);
    --color-teal-50: oklch(98.4% 0.014 180.72);
    --color-teal-100: oklch(95.3% 0.051 180.801);
    --color-teal-200: oklch(91% 0.096 180.426);
    --color-teal-300: oklch(85.5% 0.138 181.071);
    --color-teal-400: oklch(77.7% 0.152 181.912);
    --color-teal-500: oklch(70.4% 0.14 182.503);
    --color-teal-600: oklch(60% 0.118 184.704);
    --color-teal-700: oklch(51.1% 0.096 186.391);
    --color-teal-800: oklch(43.7% 0.078 188.216);
    --color-teal-900: oklch(38.6% 0.063 188.416);
    --color-teal-950: oklch(27.7% 0.046 192.524);
    --color-cyan-50: oklch(98.4% 0.019 200.873);
    --color-cyan-100: oklch(95.6% 0.045 203.388);
    --color-cyan-200: oklch(91.7% 0.08 205.041);
    --color-cyan-300: oklch(86.5% 0.127 207.078);
    --color-cyan-400: oklch(78.9% 0.154 211.53);
    --color-cyan-500: oklch(71.5% 0.143 215.221);
    --color-cyan-600: oklch(60.9% 0.126 221.723);
    --color-cyan-700: oklch(52% 0.105 223.128);
    --color-cyan-800: oklch(45% 0.085 224.283);
    --color-cyan-900: oklch(39.8% 0.07 227.392);
    --color-cyan-950: oklch(30.2% 0.056 229.695);
    --color-sky-50: oklch(97.7% 0.013 236.62);
    --color-sky-100: oklch(95.1% 0.026 236.824);
    --color-sky-200: oklch(90.1% 0.058 230.902);
    --color-sky-300: oklch(82.8% 0.111 230.318);
    --color-sky-400: oklch(74.6% 0.16 232.661);
    --color-sky-500: oklch(68.5% 0.169 237.323);
    --color-sky-600: oklch(58.8% 0.158 241.966);
    --color-sky-700: oklch(50% 0.134 242.749);
    --color-sky-800: oklch(44.3% 0.11 240.79);
    --color-sky-900: oklch(39.1% 0.09 240.876);
    --color-sky-950: oklch(29.3% 0.066 243.157);
    --color-blue-50: oklch(97% 0.014 254.604);
    --color-blue-100: oklch(93.2% 0.032 255.585);
    --color-blue-200: oklch(88.2% 0.059 254.128);
    --color-blue-300: oklch(80.9% 0.105 251.813);
    --color-blue-400: oklch(70.7% 0.165 254.624);
    --color-blue-500: oklch(62.3% 0.214 259.815);
    --color-blue-600: oklch(54.6% 0.245 262.881);
    --color-blue-700: oklch(48.8% 0.243 264.376);
    --color-blue-800: oklch(42.4% 0.199 265.638);
    --color-blue-900: oklch(37.9% 0.146 265.522);
    --color-blue-950: oklch(28.2% 0.091 267.935);
    --color-indigo-50: oklch(96.2% 0.018 272.314);
    --color-indigo-100: oklch(93% 0.034 272.788);
    --color-indigo-200: oklch(87% 0.065 274.039);
    --color-indigo-300: oklch(78.5% 0.115 274.713);
    --color-indigo-400: oklch(67.3% 0.182 276.935);
    --color-indigo-500: oklch(58.5% 0.233 277.117);
    --color-indigo-600: oklch(51.1% 0.262 276.966);
    --color-indigo-700: oklch(45.7% 0.24 277.023);
    --color-indigo-800: oklch(39.8% 0.195 277.366);
    --color-indigo-900: oklch(35.9% 0.144 278.697);
    --color-indigo-950: oklch(25.7% 0.09 281.288);
    --color-violet-50: oklch(96.9% 0.016 293.756);
    --color-violet-100: oklch(94.3% 0.029 294.588);
    --color-violet-200: oklch(89.4% 0.057 293.283);
    --color-violet-300: oklch(81.1% 0.111 293.571);
    --color-violet-400: oklch(70.2% 0.183 293.541);
    --color-violet-500: oklch(60.6% 0.25 292.717);
    --color-violet-600: oklch(54.1% 0.281 293.009);
    --color-violet-700: oklch(49.1% 0.27 292.581);
    --color-violet-800: oklch(43.2% 0.232 292.759);
    --color-violet-900: oklch(38% 0.189 293.745);
    --color-violet-950: oklch(28.3% 0.141 291.089);
    --color-purple-50: oklch(97.7% 0.014 308.299);
    --color-purple-100: oklch(94.6% 0.033 307.174);
    --color-purple-200: oklch(90.2% 0.063 306.703);
    --color-purple-300: oklch(82.7% 0.119 306.383);
    --color-purple-400: oklch(71.4% 0.203 305.504);
    --color-purple-500: oklch(62.7% 0.265 303.9);
    --color-purple-600: oklch(55.8% 0.288 302.321);
    --color-purple-700: oklch(49.6% 0.265 301.924);
    --color-purple-800: oklch(43.8% 0.218 303.724);
    --color-purple-900: oklch(38.1% 0.176 304.987);
    --color-purple-950: oklch(29.1% 0.149 302.717);
    --color-fuchsia-50: oklch(97.7% 0.017 320.058);
    --color-fuchsia-100: oklch(95.2% 0.037 318.852);
    --color-fuchsia-200: oklch(90.3% 0.076 319.62);
    --color-fuchsia-300: oklch(83.3% 0.145 321.434);
    --color-fuchsia-400: oklch(74% 0.238 322.16);
    --color-fuchsia-500: oklch(66.7% 0.295 322.15);
    --color-fuchsia-600: oklch(59.1% 0.293 322.896);
    --color-fuchsia-700: oklch(51.8% 0.253 323.949);
    --color-fuchsia-800: oklch(45.2% 0.211 324.591);
    --color-fuchsia-900: oklch(40.1% 0.17 325.612);
    --color-fuchsia-950: oklch(29.3% 0.136 325.661);
    --color-pink-50: oklch(97.1% 0.014 343.198);
    --color-pink-100: oklch(94.8% 0.028 342.258);
    --color-pink-200: oklch(89.9% 0.061 343.231);
    --color-pink-300: oklch(82.3% 0.12 346.018);
    --color-pink-400: oklch(71.8% 0.202 349.761);
    --color-pink-500: oklch(65.6% 0.241 354.308);
    --color-pink-600: oklch(59.2% 0.249 0.584);
    --color-pink-700: oklch(52.5% 0.223 3.958);
    --color-pink-800: oklch(45.9% 0.187 3.815);
    --color-pink-900: oklch(40.8% 0.153 2.432);
    --color-pink-950: oklch(28.4% 0.109 3.907);
    --color-rose-50: oklch(96.9% 0.015 12.422);
    --color-rose-100: oklch(94.1% 0.03 12.58);
    --color-rose-200: oklch(89.2% 0.058 10.001);
    --color-rose-300: oklch(81% 0.117 11.638);
    --color-rose-400: oklch(71.2% 0.194 13.428);
    --color-rose-500: oklch(64.5% 0.246 16.439);
    --color-rose-600: oklch(58.6% 0.253 17.585);
    --color-rose-700: oklch(51.4% 0.222 16.935);
    --color-rose-800: oklch(45.5% 0.188 13.697);
    --color-rose-900: oklch(41% 0.159 10.272);
    --color-rose-950: oklch(27.1% 0.105 12.094);
    --color-slate-50: oklch(98.4% 0.003 247.858);
    --color-slate-100: oklch(96.8% 0.007 247.896);
    --color-slate-200: oklch(92.9% 0.013 255.508);
    --color-slate-300: oklch(86.9% 0.022 252.894);
    --color-slate-400: oklch(70.4% 0.04 256.788);
    --color-slate-500: oklch(55.4% 0.046 257.417);
    --color-slate-600: oklch(44.6% 0.043 257.281);
    --color-slate-700: oklch(37.2% 0.044 257.287);
    --color-slate-800: oklch(27.9% 0.041 260.031);
    --color-slate-900: oklch(20.8% 0.042 265.755);
    --color-slate-950: oklch(12.9% 0.042 264.695);
    --color-gray-50: oklch(98.5% 0.002 247.839);
    --color-gray-100: oklch(96.7% 0.003 264.542);
    --color-gray-200: oklch(92.8% 0.006 264.531);
    --color-gray-300: oklch(87.2% 0.01 258.338);
    --color-gray-400: oklch(70.7% 0.022 261.325);
    --color-gray-500: oklch(55.1% 0.027 264.364);
    --color-gray-600: oklch(44.6% 0.03 256.802);
    --color-gray-700: oklch(37.3% 0.034 259.733);
    --color-gray-800: oklch(27.8% 0.033 256.848);
    --color-gray-900: oklch(21% 0.034 264.665);
    --color-gray-950: oklch(13% 0.028 261.692);
    --color-zinc-50: oklch(98.5% 0 0);
    --color-zinc-100: oklch(96.7% 0.001 286.375);
    --color-zinc-200: oklch(92% 0.004 286.32);
    --color-zinc-300: oklch(87.1% 0.006 286.286);
    --color-zinc-400: oklch(70.5% 0.015 286.067);
    --color-zinc-500: oklch(55.2% 0.016 285.938);
    --color-zinc-600: oklch(44.2% 0.017 285.786);
    --color-zinc-700: oklch(37% 0.013 285.805);
    --color-zinc-800: oklch(27.4% 0.006 286.033);
    --color-zinc-900: oklch(21% 0.006 285.885);
    --color-zinc-950: oklch(14.1% 0.005 285.823);
    --color-neutral-50: oklch(98.5% 0 0);
    --color-neutral-100: oklch(97% 0 0);
    --color-neutral-200: oklch(92.2% 0 0);
    --color-neutral-300: oklch(87% 0 0);
    --color-neutral-400: oklch(70.8% 0 0);
    --color-neutral-500: oklch(55.6% 0 0);
    --color-neutral-600: oklch(43.9% 0 0);
    --color-neutral-700: oklch(37.1% 0 0);
    --color-neutral-800: oklch(26.9% 0 0);
    --color-neutral-900: oklch(20.5% 0 0);
    --color-neutral-950: oklch(14.5% 0 0);
    --color-stone-50: oklch(98.5% 0.001 106.423);
    --color-stone-100: oklch(97% 0.001 106.424);
    --color-stone-200: oklch(92.3% 0.003 48.717);
    --color-stone-300: oklch(86.9% 0.005 56.366);
    --color-stone-400: oklch(70.9% 0.01 56.259);
    --color-stone-500: oklch(55.3% 0.013 58.071);
    --color-stone-600: oklch(44.4% 0.011 73.639);
    --color-stone-700: oklch(37.4% 0.01 67.558);
    --color-stone-800: oklch(26.8% 0.007 34.298);
    --color-stone-900: oklch(21.6% 0.006 56.043);
    --color-stone-950: oklch(14.7% 0.004 49.25);
    --color-black: #000;
    --color-white: #fff;
    --spacing: 0.25rem;
    --breakpoint-sm: 40rem;
    --breakpoint-md: 48rem;
    --breakpoint-lg: 64rem;
    --breakpoint-xl: 80rem;
    --breakpoint-2xl: 96rem;
    --container-3xs: 16rem;
    --container-2xs: 18rem;
    --container-xs: 20rem;
    --container-sm: 24rem;
    --container-md: 28rem;
    --container-lg: 32rem;
    --container-xl: 36rem;
    --container-2xl: 42rem;
    --container-3xl: 48rem;
    --container-4xl: 56rem;
    --container-5xl: 64rem;
    --container-6xl: 72rem;
    --container-7xl: 80rem;
    --text-xs: 0.75rem;
    --text-xs--line-height: calc(1 / 0.75);
    --text-sm: 0.875rem;
    --text-sm--line-height: calc(1.25 / 0.875);
    --text-base: 1rem;
    --text-base--line-height: calc(1.5 / 1);
    --text-lg: 1.125rem;
    --text-lg--line-height: calc(1.75 / 1.125);
    --text-xl: 1.25rem;
    --text-xl--line-height: calc(1.75 / 1.25);
    --text-2xl: 1.5rem;
    --text-2xl--line-height: calc(2 / 1.5);
    --text-3xl: 1.875rem;
    --text-3xl--line-height: calc(2.25 / 1.875);
    --text-4xl: 2.25rem;
    --text-4xl--line-height: calc(2.5 / 2.25);
    --text-5xl: 3rem;
    --text-5xl--line-height: 1;
    --text-6xl: 3.75rem;
    --text-6xl--line-height: 1;
    --text-7xl: 4.5rem;
    --text-7xl--line-height: 1;
    --text-8xl: 6rem;
    --text-8xl--line-height: 1;
    --text-9xl: 8rem;
    --text-9xl--line-height: 1;
    --font-weight-thin: 100;
    --font-weight-extralight: 200;
    --font-weight-light: 300;
    --font-weight-normal: 400;
    --font-weight-medium: 500;
    --font-weight-semibold: 600;
    --font-weight-bold: 700;
    --font-weight-extrabold: 800;
    --font-weight-black: 900;
    --tracking-tighter: -0.05em;
    --tracking-tight: -0.025em;
    --tracking-normal: 0em;
    --tracking-wide: 0.025em;
    --tracking-wider: 0.05em;
    --tracking-widest: 0.1em;
    --leading-tight: 1.25;
    --leading-snug: 1.375;
    --leading-normal: 1.5;
    --leading-relaxed: 1.625;
    --leading-loose: 2;
    --radius-xs: 0.125rem;
    --radius-sm: 0.25rem;
    --radius-md: 0.375rem;
    --radius-lg: 0.5rem;
    --radius-xl: 0.75rem;
    --radius-2xl: 1rem;
    --radius-3xl: 1.5rem;
    --radius-4xl: 2rem;
    --shadow-2xs: 0 1px rgb(0 0 0 / 0.05);
    --shadow-xs: 0 1px 2px 0 rgb(0 0 0 / 0.05);
    --shadow-sm: 0 1px 3px 0 rgb(0 0 0 / 0.1), 0 1px 2px -1px rgb(0 0 0 / 0.1);
    --shadow-md: 0 4px 6px -1px rgb(0 0 0 / 0.1), 0 2px 4px -2px rgb(0 0 0 / 0.1);
    --shadow-lg: 0 10px 15px -3px rgb(0 0 0 / 0.1), 0 4px 6px -4px rgb(0 0 0 / 0.1);
    --shadow-xl: 0 20px 25px -5px rgb(0 0 0 / 0.1), 0 8px 10px -6px rgb(0 0 0 / 0.1);
    --shadow-2xl: 0 25px 50px -12px rgb(0 0 0 / 0.25);
    --inset-shadow-2xs: inset 0 1px rgb(0 0 0 / 0.05);
    --inset-shadow-xs: inset 0 1px 1px rgb(0 0 0 / 0.05);
    --inset-shadow-sm: inset 0 2px 4px rgb(0 0 0 / 0.05);
    --drop-shadow-xs: 0 1px 1px rgb(0 0 0 / 0.05);
    --drop-shadow-sm: 0 1px 2px rgb(0 0 0 / 0.15);
    --drop-shadow-md: 0 3px 3px rgb(0 0 0 / 0.12);
    --drop-shadow-lg: 0 4px 4px rgb(0 0 0 / 0.15);
    --drop-shadow-xl: 0 9px 7px rgb(0 0 0 / 0.1);
    --drop-shadow-2xl: 0 25px 25px rgb(0 0 0 / 0.15);
    --ease-in: cubic-bezier(0.4, 0, 1, 1);
    --ease-out: cubic-bezier(0, 0, 0.2, 1);
    --ease-in-out: cubic-bezier(0.4, 0, 0.2, 1);
    --animate-spin: spin 1s linear infinite;
    --animate-ping: ping 1s cubic-bezier(0, 0, 0.2, 1) infinite;
    --animate-pulse: pulse 2s cubic-bezier(0.4, 0, 0.6, 1) infinite;
    --animate-bounce: bounce 1s infinite;
    --blur-xs: 4px;
    --blur-sm: 8px;
    --blur-md: 12px;
    --blur-lg: 16px;
    --blur-xl: 24px;
    --blur-2xl: 40px;
    --blur-3xl: 64px;
    --perspective-dramatic: 100px;
    --perspective-near: 300px;
    --perspective-normal: 500px;
    --perspective-midrange: 800px;
    --perspective-distant: 1200px;
    --aspect-video: 16 / 9;
    --default-transition-duration: 150ms;
    --default-transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
    --default-font-family: var(--font-sans);
    --default-mono-font-family: var(--font-mono);
  }
}
@layer base {
  *, ::after, ::before, ::backdrop, ::file-selector-button {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
    border: 0 solid;
  }
  html, :host {
    line-height: 1.5;
    -webkit-text-size-adjust: 100%;
    -moz-tab-size: 4;
      -o-tab-size: 4;
         tab-size: 4;
    font-family: var(--default-font-family, ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji");
    font-feature-settings: var(--default-font-feature-settings, normal);
    font-variation-settings: var(--default-font-variation-settings, normal);
    -webkit-tap-highlight-color: transparent;
  }
  hr {
    height: 0;
    color: inherit;
    border-top-width: 1px;
  }
  abbr:where([title]) {
    -webkit-text-decoration: underline dotted;
    text-decoration: underline dotted;
  }
  h1, h2, h3, h4, h5, h6 {
    font-size: inherit;
    font-weight: inherit;
  }
  a {
    color: inherit;
    -webkit-text-decoration: inherit;
    text-decoration: inherit;
  }
  b, strong {
    font-weight: bolder;
  }
  code, kbd, samp, pre {
    font-family: var(--default-mono-font-family, ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace);
    font-feature-settings: var(--default-mono-font-feature-settings, normal);
    font-variation-settings: var(--default-mono-font-variation-settings, normal);
    font-size: 1em;
  }
  small {
    font-size: 80%;
  }
  sub, sup {
    font-size: 75%;
    line-height: 0;
    position: relative;
    vertical-align: baseline;
  }
  sub {
    bottom: -0.25em;
  }
  sup {
    top: -0.5em;
  }
  table {
    text-indent: 0;
    border-color: inherit;
    border-collapse: collapse;
  }
  :-moz-focusring {
    outline: auto;
  }
  progress {
    vertical-align: baseline;
  }
  summary {
    display: list-item;
  }
  ol, ul, menu {
    list-style: none;
  }
  img, svg, video, canvas, audio, iframe, embed, object {
    display: block;
    vertical-align: middle;
  }
  img, video {
    max-width: 100%;
    height: auto;
  }
  button, input, select, optgroup, textarea, ::file-selector-button {
    font: inherit;
    font-feature-settings: inherit;
    font-variation-settings: inherit;
    letter-spacing: inherit;
    color: inherit;
    border-radius: 0;
    background-color: transparent;
    opacity: 1;
  }
  :where(select:is([multiple], [size])) optgroup {
    font-weight: bolder;
  }
  :where(select:is([multiple], [size])) optgroup option {
    padding-inline-start: 20px;
  }
  ::file-selector-button {
    margin-inline-end: 4px;
  }
  ::-moz-placeholder {
    opacity: 1;
  }
  ::placeholder {
    opacity: 1;
  }
  @supports (not (-webkit-appearance: -apple-pay-button))  or (contain-intrinsic-size: 1px) {
    ::-moz-placeholder {
      color: currentcolor;
      @supports (color: color-mix(in lab, red, red)) {
        color: color-mix(in oklab, currentcolor 50%, transparent);
      }
    }
    ::placeholder {
      color: currentcolor;
      @supports (color: color-mix(in lab, red, red)) {
        color: color-mix(in oklab, currentcolor 50%, transparent);
      }
    }
  }
  textarea {
    resize: vertical;
  }
  ::-webkit-search-decoration {
    -webkit-appearance: none;
  }
  ::-webkit-date-and-time-value {
    min-height: 1lh;
    text-align: inherit;
  }
  ::-webkit-datetime-edit {
    display: inline-flex;
  }
  ::-webkit-datetime-edit-fields-wrapper {
    padding: 0;
  }
  ::-webkit-datetime-edit, ::-webkit-datetime-edit-year-field, ::-webkit-datetime-edit-month-field, ::-webkit-datetime-edit-day-field, ::-webkit-datetime-edit-hour-field, ::-webkit-datetime-edit-minute-field, ::-webkit-datetime-edit-second-field, ::-webkit-datetime-edit-millisecond-field, ::-webkit-datetime-edit-meridiem-field {
    padding-block: 0;
  }
  ::-webkit-calendar-picker-indicator {
    line-height: 1;
  }
  :-moz-ui-invalid {
    box-shadow: none;
  }
  button, input:where([type="button"], [type="reset"], [type="submit"]), ::file-selector-button {
    -webkit-appearance: button;
       -moz-appearance: button;
            appearance: button;
  }
  ::-webkit-inner-spin-button, ::-webkit-outer-spin-button {
    height: auto;
  }
  [hidden]:where(:not([hidden="until-found"])) {
    display: none !important;
  }
}
@layer utilities {
  .pointer-events-none {
    pointer-events: none;
  }
  .invisible {
    visibility: hidden;
  }
  .visible {
    visibility: visible;
  }
  .sr-only {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip-path: inset(50%);
    white-space: nowrap;
    border-width: 0;
  }
  .absolute {
    position: absolute;
  }
  .fixed {
    position: fixed;
  }
  .relative {
    position: relative;
  }
  .static {
    position: static;
  }
  .sticky {
    position: sticky;
  }
  .inset-0 {
    inset: calc(var(--spacing) * 0);
  }
  .inset-2 {
    inset: calc(var(--spacing) * 2);
  }
  .inset-4 {
    inset: calc(var(--spacing) * 4);
  }
  .start-0 {
    inset-inline-start: calc(var(--spacing) * 0);
  }
  .end-0 {
    inset-inline-end: calc(var(--spacing) * 0);
  }
  .top-0 {
    top: calc(var(--spacing) * 0);
  }
  .top-1\/2 {
    top: calc(1/2 * 100%);
  }
  .top-2 {
    top: calc(var(--spacing) * 2);
  }
  .top-6 {
    top: calc(var(--spacing) * 6);
  }
  .top-full {
    top: 100%;
  }
  .right-0 {
    right: calc(var(--spacing) * 0);
  }
  .right-2 {
    right: calc(var(--spacing) * 2);
  }
  .left-0 {
    left: calc(var(--spacing) * 0);
  }
  .z-50 {
    z-index: 50;
  }
  .z-\[9999\] {
    z-index: 9999;
  }
  .col-span-2 {
    grid-column: span 2 / span 2;
  }
  .col-span-full {
    grid-column: 1 / -1;
  }
  .container {
    width: 100%;
    @media (width >= 40rem) {
      max-width: 40rem;
    }
    @media (width >= 48rem) {
      max-width: 48rem;
    }
    @media (width >= 64rem) {
      max-width: 64rem;
    }
    @media (width >= 80rem) {
      max-width: 80rem;
    }
    @media (width >= 96rem) {
      max-width: 96rem;
    }
  }
  .mx-2 {
    margin-inline: calc(var(--spacing) * 2);
  }
  .mx-auto {
    margin-inline: auto;
  }
  .my-1 {
    margin-block: calc(var(--spacing) * 1);
  }
  .my-4 {
    margin-block: calc(var(--spacing) * 4);
  }
  .ms-1 {
    margin-inline-start: calc(var(--spacing) * 1);
  }
  .ms-3 {
    margin-inline-start: calc(var(--spacing) * 3);
  }
  .ms-4 {
    margin-inline-start: calc(var(--spacing) * 4);
  }
  .-me-2 {
    margin-inline-end: calc(var(--spacing) * -2);
  }
  .-mt-\[4\.9rem\] {
    margin-top: calc(4.9rem * -1);
  }
  .mt-0\.5 {
    margin-top: calc(var(--spacing) * 0.5);
  }
  .mt-1 {
    margin-top: calc(var(--spacing) * 1);
  }
  .mt-2 {
    margin-top: calc(var(--spacing) * 2);
  }
  .mt-3 {
    margin-top: calc(var(--spacing) * 3);
  }
  .mt-4 {
    margin-top: calc(var(--spacing) * 4);
  }
  .mt-6 {
    margin-top: calc(var(--spacing) * 6);
  }
  .mr-1 {
    margin-right: calc(var(--spacing) * 1);
  }
  .mr-2 {
    margin-right: calc(var(--spacing) * 2);
  }
  .-mb-px {
    margin-bottom: -1px;
  }
  .mb-1 {
    margin-bottom: calc(var(--spacing) * 1);
  }
  .mb-2 {
    margin-bottom: calc(var(--spacing) * 2);
  }
  .mb-3 {
    margin-bottom: calc(var(--spacing) * 3);
  }
  .mb-4 {
    margin-bottom: calc(var(--spacing) * 4);
  }
  .mb-6 {
    margin-bottom: calc(var(--spacing) * 6);
  }
  .-ml-8 {
    margin-left: calc(var(--spacing) * -8);
  }
  .ml-1 {
    margin-left: calc(var(--spacing) * 1);
  }
  .ml-2 {
    margin-left: calc(var(--spacing) * 2);
  }
  .ml-4 {
    margin-left: calc(var(--spacing) * 4);
  }
  .ml-auto {
    margin-left: auto;
  }
  .line-clamp-3 {
    overflow: hidden;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 3;
  }
  .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;
  }
  .list-item {
    display: list-item;
  }
  .table {
    display: table;
  }
  .aspect-\[335\/376\] {
    aspect-ratio: 335/376;
  }
  .h-0\.5 {
    height: calc(var(--spacing) * 0.5);
  }
  .h-1 {
    height: calc(var(--spacing) * 1);
  }
  .h-1\.5 {
    height: calc(var(--spacing) * 1.5);
  }
  .h-2 {
    height: calc(var(--spacing) * 2);
  }
  .h-2\.5 {
    height: calc(var(--spacing) * 2.5);
  }
  .h-3 {
    height: calc(var(--spacing) * 3);
  }
  .h-3\.5 {
    height: calc(var(--spacing) * 3.5);
  }
  .h-4 {
    height: calc(var(--spacing) * 4);
  }
  .h-5 {
    height: calc(var(--spacing) * 5);
  }
  .h-6 {
    height: calc(var(--spacing) * 6);
  }
  .h-8 {
    height: calc(var(--spacing) * 8);
  }
  .h-9 {
    height: calc(var(--spacing) * 9);
  }
  .h-11 {
    height: calc(var(--spacing) * 11);
  }
  .h-12 {
    height: calc(var(--spacing) * 12);
  }
  .h-14 {
    height: calc(var(--spacing) * 14);
  }
  .h-14\.5 {
    height: calc(var(--spacing) * 14.5);
  }
  .h-16 {
    height: calc(var(--spacing) * 16);
  }
  .h-full {
    height: 100%;
  }
  .max-h-32 {
    max-height: calc(var(--spacing) * 32);
  }
  .max-h-48 {
    max-height: calc(var(--spacing) * 48);
  }
  .max-h-60 {
    max-height: calc(var(--spacing) * 60);
  }
  .max-h-64 {
    max-height: calc(var(--spacing) * 64);
  }
  .max-h-72 {
    max-height: calc(var(--spacing) * 72);
  }
  .max-h-96 {
    max-height: calc(var(--spacing) * 96);
  }
  .max-h-400 {
    max-height: calc(var(--spacing) * 400);
  }
  .max-h-500 {
    max-height: calc(var(--spacing) * 500);
  }
  .max-h-\[85vh\] {
    max-height: 85vh;
  }
  .max-h-\[420px\] {
    max-height: 420px;
  }
  .max-h-dvh {
    max-height: 100dvh;
  }
  .min-h-24 {
    min-height: calc(var(--spacing) * 24);
  }
  .min-h-\[10rem\] {
    min-height: 10rem;
  }
  .min-h-\[200px\] {
    min-height: 200px;
  }
  .min-h-screen {
    min-height: 100vh;
  }
  .w-1 {
    width: calc(var(--spacing) * 1);
  }
  .w-1\.5 {
    width: calc(var(--spacing) * 1.5);
  }
  .w-2 {
    width: calc(var(--spacing) * 2);
  }
  .w-2\.5 {
    width: calc(var(--spacing) * 2.5);
  }
  .w-3 {
    width: calc(var(--spacing) * 3);
  }
  .w-3\.5 {
    width: calc(var(--spacing) * 3.5);
  }
  .w-3\/4 {
    width: calc(3/4 * 100%);
  }
  .w-4 {
    width: calc(var(--spacing) * 4);
  }
  .w-5 {
    width: calc(var(--spacing) * 5);
  }
  .w-6 {
    width: calc(var(--spacing) * 6);
  }
  .w-8 {
    width: calc(var(--spacing) * 8);
  }
  .w-9 {
    width: calc(var(--spacing) * 9);
  }
  .w-10 {
    width: calc(var(--spacing) * 10);
  }
  .w-11 {
    width: calc(var(--spacing) * 11);
  }
  .w-12 {
    width: calc(var(--spacing) * 12);
  }
  .w-20 {
    width: calc(var(--spacing) * 20);
  }
  .w-24 {
    width: calc(var(--spacing) * 24);
  }
  .w-40 {
    width: calc(var(--spacing) * 40);
  }
  .w-48 {
    width: calc(var(--spacing) * 48);
  }
  .w-120 {
    width: calc(var(--spacing) * 120);
  }
  .w-\[448px\] {
    width: 448px;
  }
  .w-auto {
    width: auto;
  }
  .w-full {
    width: 100%;
  }
  .w-max {
    width: -moz-max-content;
    width: max-content;
  }
  .max-w-2xl {
    max-width: var(--container-2xl);
  }
  .max-w-3xl {
    max-width: var(--container-3xl);
  }
  .max-w-6xl {
    max-width: var(--container-6xl);
  }
  .max-w-7xl {
    max-width: var(--container-7xl);
  }
  .max-w-500 {
    max-width: calc(var(--spacing) * 500);
  }
  .max-w-600 {
    max-width: calc(var(--spacing) * 600);
  }
  .max-w-\[85\%\] {
    max-width: 85%;
  }
  .max-w-\[335px\] {
    max-width: 335px;
  }
  .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);
  }
  .min-w-0 {
    min-width: calc(var(--spacing) * 0);
  }
  .min-w-10 {
    min-width: calc(var(--spacing) * 10);
  }
  .min-w-60 {
    min-width: calc(var(--spacing) * 60);
  }
  .min-w-\[70rem\] {
    min-width: 70rem;
  }
  .min-w-\[200px\] {
    min-width: 200px;
  }
  .flex-1 {
    flex: 1;
  }
  .flex-shrink {
    flex-shrink: 1;
  }
  .flex-shrink-0 {
    flex-shrink: 0;
  }
  .shrink-0 {
    flex-shrink: 0;
  }
  .flex-grow {
    flex-grow: 1;
  }
  .table-fixed {
    table-layout: fixed;
  }
  .border-collapse {
    border-collapse: collapse;
  }
  .origin-top {
    transform-origin: top;
  }
  .-translate-y-1\/2 {
    --tw-translate-y: calc(calc(1/2 * 100%) * -1);
    translate: var(--tw-translate-x) var(--tw-translate-y);
  }
  .translate-y-0 {
    --tw-translate-y: calc(var(--spacing) * 0);
    translate: var(--tw-translate-x) var(--tw-translate-y);
  }
  .translate-y-4 {
    --tw-translate-y: calc(var(--spacing) * 4);
    translate: var(--tw-translate-x) var(--tw-translate-y);
  }
  .scale-95 {
    --tw-scale-x: 95%;
    --tw-scale-y: 95%;
    --tw-scale-z: 95%;
    scale: var(--tw-scale-x) var(--tw-scale-y);
  }
  .scale-100 {
    --tw-scale-x: 100%;
    --tw-scale-y: 100%;
    --tw-scale-z: 100%;
    scale: var(--tw-scale-x) var(--tw-scale-y);
  }
  .rotate-90 {
    rotate: 90deg;
  }
  .transform {
    transform: var(--tw-rotate-x,) var(--tw-rotate-y,) var(--tw-rotate-z,) var(--tw-skew-x,) var(--tw-skew-y,);
  }
  .animate-bounce {
    animation: var(--animate-bounce);
  }
  .animate-pulse {
    animation: var(--animate-pulse);
  }
  .animate-spin {
    animation: var(--animate-spin);
  }
  .cursor-pointer {
    cursor: pointer;
  }
  .touch-pan-x {
    --tw-pan-x: pan-x;
    touch-action: var(--tw-pan-x,) var(--tw-pan-y,) var(--tw-pinch-zoom,);
  }
  .resize {
    resize: both;
  }
  .scroll-mt-4 {
    scroll-margin-top: calc(var(--spacing) * 4);
  }
  .list-inside {
    list-style-position: inside;
  }
  .list-decimal {
    list-style-type: decimal;
  }
  .list-disc {
    list-style-type: disc;
  }
  .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));
  }
  .flex-col {
    flex-direction: column;
  }
  .flex-col-reverse {
    flex-direction: column-reverse;
  }
  .flex-wrap {
    flex-wrap: wrap;
  }
  .items-center {
    align-items: center;
  }
  .items-end {
    align-items: flex-end;
  }
  .items-start {
    align-items: flex-start;
  }
  .justify-between {
    justify-content: space-between;
  }
  .justify-center {
    justify-content: center;
  }
  .justify-end {
    justify-content: flex-end;
  }
  .justify-start {
    justify-content: flex-start;
  }
  .gap-1 {
    gap: calc(var(--spacing) * 1);
  }
  .gap-1\.5 {
    gap: calc(var(--spacing) * 1.5);
  }
  .gap-2 {
    gap: calc(var(--spacing) * 2);
  }
  .gap-3 {
    gap: calc(var(--spacing) * 3);
  }
  .gap-4 {
    gap: calc(var(--spacing) * 4);
  }
  .gap-5 {
    gap: calc(var(--spacing) * 5);
  }
  .space-y-0\.5 {
    :where(& > :not(:last-child)) {
      --tw-space-y-reverse: 0;
      margin-block-start: calc(calc(var(--spacing) * 0.5) * var(--tw-space-y-reverse));
      margin-block-end: calc(calc(var(--spacing) * 0.5) * calc(1 - var(--tw-space-y-reverse)));
    }
  }
  .space-y-1 {
    :where(& > :not(:last-child)) {
      --tw-space-y-reverse: 0;
      margin-block-start: calc(calc(var(--spacing) * 1) * var(--tw-space-y-reverse));
      margin-block-end: calc(calc(var(--spacing) * 1) * calc(1 - var(--tw-space-y-reverse)));
    }
  }
  .space-y-1\.5 {
    :where(& > :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)));
    }
  }
  .space-y-2 {
    :where(& > :not(:last-child)) {
      --tw-space-y-reverse: 0;
      margin-block-start: calc(calc(var(--spacing) * 2) * var(--tw-space-y-reverse));
      margin-block-end: calc(calc(var(--spacing) * 2) * calc(1 - var(--tw-space-y-reverse)));
    }
  }
  .space-y-3 {
    :where(& > :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)));
    }
  }
  .space-y-4 {
    :where(& > :not(:last-child)) {
      --tw-space-y-reverse: 0;
      margin-block-start: calc(calc(var(--spacing) * 4) * var(--tw-space-y-reverse));
      margin-block-end: calc(calc(var(--spacing) * 4) * calc(1 - var(--tw-space-y-reverse)));
    }
  }
  .space-y-5 {
    :where(& > :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)));
    }
  }
  .space-y-6 {
    :where(& > :not(:last-child)) {
      --tw-space-y-reverse: 0;
      margin-block-start: calc(calc(var(--spacing) * 6) * var(--tw-space-y-reverse));
      margin-block-end: calc(calc(var(--spacing) * 6) * calc(1 - var(--tw-space-y-reverse)));
    }
  }
  .space-x-1 {
    :where(& > :not(:last-child)) {
      --tw-space-x-reverse: 0;
      margin-inline-start: calc(calc(var(--spacing) * 1) * var(--tw-space-x-reverse));
      margin-inline-end: calc(calc(var(--spacing) * 1) * calc(1 - var(--tw-space-x-reverse)));
    }
  }
  .space-x-8 {
    :where(& > :not(:last-child)) {
      --tw-space-x-reverse: 0;
      margin-inline-start: calc(calc(var(--spacing) * 8) * var(--tw-space-x-reverse));
      margin-inline-end: calc(calc(var(--spacing) * 8) * calc(1 - var(--tw-space-x-reverse)));
    }
  }
  .divide-y {
    :where(& > :not(:last-child)) {
      --tw-divide-y-reverse: 0;
      border-bottom-style: var(--tw-border-style);
      border-top-style: var(--tw-border-style);
      border-top-width: calc(1px * var(--tw-divide-y-reverse));
      border-bottom-width: calc(1px * calc(1 - var(--tw-divide-y-reverse)));
    }
  }
  .divide-black\/10 {
    :where(& > :not(:last-child)) {
      border-color: color-mix(in srgb, #000 10%, transparent);
      @supports (color: color-mix(in lab, red, red)) {
        border-color: color-mix(in oklab, var(--color-black) 10%, transparent);
      }
    }
  }
  .self-center {
    align-self: center;
  }
  .truncate {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
  }
  .overflow-auto {
    overflow: auto;
  }
  .overflow-hidden {
    overflow: hidden;
  }
  .overflow-x-auto {
    overflow-x: auto;
  }
  .overflow-x-scroll {
    overflow-x: scroll;
  }
  .overflow-y-auto {
    overflow-y: auto;
  }
  .overflow-y-hidden {
    overflow-y: hidden;
  }
  .overscroll-contain {
    overscroll-behavior: contain;
  }
  .rounded {
    border-radius: 0.25rem;
  }
  .rounded-2xl {
    border-radius: var(--radius-2xl);
  }
  .rounded-3xl {
    border-radius: var(--radius-3xl);
  }
  .rounded-full {
    border-radius: calc(infinity * 1px);
  }
  .rounded-lg {
    border-radius: var(--radius-lg);
  }
  .rounded-md {
    border-radius: var(--radius-md);
  }
  .rounded-sm {
    border-radius: var(--radius-sm);
  }
  .rounded-xl {
    border-radius: var(--radius-xl);
  }
  .rounded-t-lg {
    border-top-left-radius: var(--radius-lg);
    border-top-right-radius: var(--radius-lg);
  }
  .rounded-br-lg {
    border-bottom-right-radius: var(--radius-lg);
  }
  .rounded-br-sm {
    border-bottom-right-radius: var(--radius-sm);
  }
  .rounded-bl-lg {
    border-bottom-left-radius: var(--radius-lg);
  }
  .rounded-bl-sm {
    border-bottom-left-radius: var(--radius-sm);
  }
  .border {
    border-style: var(--tw-border-style);
    border-width: 1px;
  }
  .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-b-2 {
    border-bottom-style: var(--tw-border-style);
    border-bottom-width: 2px;
  }
  .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-\[\#19140035\] {
    border-color: #19140035;
  }
  .border-\[\#e3e3e0\] {
    border-color: #e3e3e0;
  }
  .border-\[var\(--color-border\)\] {
    border-color: var(--color-border);
  }
  .border-black {
    border-color: var(--color-black);
  }
  .border-black\/5 {
    border-color: color-mix(in srgb, #000 5%, transparent);
    @supports (color: color-mix(in lab, red, red)) {
      border-color: color-mix(in oklab, var(--color-black) 5%, transparent);
    }
  }
  .border-black\/10 {
    border-color: color-mix(in srgb, #000 10%, transparent);
    @supports (color: color-mix(in lab, red, red)) {
      border-color: color-mix(in oklab, var(--color-black) 10%, transparent);
    }
  }
  .border-blue-500 {
    border-color: var(--color-blue-500);
  }
  .border-emerald-500\/30 {
    border-color: color-mix(in srgb, oklch(69.6% 0.17 162.48) 30%, transparent);
    @supports (color: color-mix(in lab, red, red)) {
      border-color: color-mix(in oklab, var(--color-emerald-500) 30%, transparent);
    }
  }
  .border-gray-100 {
    border-color: var(--color-gray-100);
  }
  .border-gray-200 {
    border-color: var(--color-gray-200);
  }
  .border-gray-300 {
    border-color: var(--color-gray-300);
  }
  .border-green-500\/30 {
    border-color: color-mix(in srgb, oklch(72.3% 0.219 149.579) 30%, transparent);
    @supports (color: color-mix(in lab, red, red)) {
      border-color: color-mix(in oklab, var(--color-green-500) 30%, transparent);
    }
  }
  .border-indigo-400 {
    border-color: var(--color-indigo-400);
  }
  .border-orange-500\/30 {
    border-color: color-mix(in srgb, oklch(70.5% 0.213 47.604) 30%, transparent);
    @supports (color: color-mix(in lab, red, red)) {
      border-color: color-mix(in oklab, var(--color-orange-500) 30%, transparent);
    }
  }
  .border-red-500\/30 {
    border-color: color-mix(in srgb, oklch(63.7% 0.237 25.331) 30%, transparent);
    @supports (color: color-mix(in lab, red, red)) {
      border-color: color-mix(in oklab, var(--color-red-500) 30%, transparent);
    }
  }
  .border-slate-200 {
    border-color: var(--color-slate-200);
  }
  .border-transparent {
    border-color: transparent;
  }
  .bg-\[\#0b93f6\] {
    background-color: #0b93f6;
  }
  .bg-\[\#1b1b18\] {
    background-color: #1b1b18;
  }
  .bg-\[\#FDFDFC\] {
    background-color: #FDFDFC;
  }
  .bg-\[\#dbdbd7\] {
    background-color: #dbdbd7;
  }
  .bg-\[\#e5e5ea\] {
    background-color: #e5e5ea;
  }
  .bg-\[\#fff2f2\] {
    background-color: #fff2f2;
  }
  .bg-\[var\(--color-primary\)\] {
    background-color: var(--color-primary);
  }
  .bg-black {
    background-color: var(--color-black);
  }
  .bg-black\/5 {
    background-color: color-mix(in srgb, #000 5%, transparent);
    @supports (color: color-mix(in lab, red, red)) {
      background-color: color-mix(in oklab, var(--color-black) 5%, transparent);
    }
  }
  .bg-black\/10 {
    background-color: color-mix(in srgb, #000 10%, transparent);
    @supports (color: color-mix(in lab, red, red)) {
      background-color: color-mix(in oklab, var(--color-black) 10%, transparent);
    }
  }
  .bg-black\/20 {
    background-color: color-mix(in srgb, #000 20%, transparent);
    @supports (color: color-mix(in lab, red, red)) {
      background-color: color-mix(in oklab, var(--color-black) 20%, transparent);
    }
  }
  .bg-black\/50 {
    background-color: color-mix(in srgb, #000 50%, transparent);
    @supports (color: color-mix(in lab, red, red)) {
      background-color: color-mix(in oklab, var(--color-black) 50%, transparent);
    }
  }
  .bg-black\/60 {
    background-color: color-mix(in srgb, #000 60%, transparent);
    @supports (color: color-mix(in lab, red, red)) {
      background-color: color-mix(in oklab, var(--color-black) 60%, transparent);
    }
  }
  .bg-black\/\[\.03\] {
    background-color: color-mix(in srgb, #000 3%, transparent);
    @supports (color: color-mix(in lab, red, red)) {
      background-color: color-mix(in oklab, var(--color-black) 3%, transparent);
    }
  }
  .bg-black\/\[0\.02\] {
    background-color: color-mix(in srgb, #000 2%, transparent);
    @supports (color: color-mix(in lab, red, red)) {
      background-color: color-mix(in oklab, var(--color-black) 2%, transparent);
    }
  }
  .bg-blue-100 {
    background-color: var(--color-blue-100);
  }
  .bg-blue-500\/20 {
    background-color: color-mix(in srgb, oklch(62.3% 0.214 259.815) 20%, transparent);
    @supports (color: color-mix(in lab, red, red)) {
      background-color: color-mix(in oklab, var(--color-blue-500) 20%, transparent);
    }
  }
  .bg-blue-600 {
    background-color: var(--color-blue-600);
  }
  .bg-emerald-500\/10 {
    background-color: color-mix(in srgb, oklch(69.6% 0.17 162.48) 10%, transparent);
    @supports (color: color-mix(in lab, red, red)) {
      background-color: color-mix(in oklab, var(--color-emerald-500) 10%, transparent);
    }
  }
  .bg-gray-500 {
    background-color: var(--color-gray-500);
  }
  .bg-gray-500\/20 {
    background-color: color-mix(in srgb, oklch(55.1% 0.027 264.364) 20%, transparent);
    @supports (color: color-mix(in lab, red, red)) {
      background-color: color-mix(in oklab, var(--color-gray-500) 20%, transparent);
    }
  }
  .bg-gray-800 {
    background-color: var(--color-gray-800);
  }
  .bg-green-100 {
    background-color: var(--color-green-100);
  }
  .bg-green-500\/10 {
    background-color: color-mix(in srgb, oklch(72.3% 0.219 149.579) 10%, transparent);
    @supports (color: color-mix(in lab, red, red)) {
      background-color: color-mix(in oklab, var(--color-green-500) 10%, transparent);
    }
  }
  .bg-green-500\/20 {
    background-color: color-mix(in srgb, oklch(72.3% 0.219 149.579) 20%, transparent);
    @supports (color: color-mix(in lab, red, red)) {
      background-color: color-mix(in oklab, var(--color-green-500) 20%, transparent);
    }
  }
  .bg-indigo-50 {
    background-color: var(--color-indigo-50);
  }
  .bg-orange-100 {
    background-color: var(--color-orange-100);
  }
  .bg-orange-500 {
    background-color: var(--color-orange-500);
  }
  .bg-orange-500\/10 {
    background-color: color-mix(in srgb, oklch(70.5% 0.213 47.604) 10%, transparent);
    @supports (color: color-mix(in lab, red, red)) {
      background-color: color-mix(in oklab, var(--color-orange-500) 10%, transparent);
    }
  }
  .bg-purple-100 {
    background-color: var(--color-purple-100);
  }
  .bg-red-500\/10 {
    background-color: color-mix(in srgb, oklch(63.7% 0.237 25.331) 10%, transparent);
    @supports (color: color-mix(in lab, red, red)) {
      background-color: color-mix(in oklab, var(--color-red-500) 10%, transparent);
    }
  }
  .bg-red-500\/20 {
    background-color: color-mix(in srgb, oklch(63.7% 0.237 25.331) 20%, transparent);
    @supports (color: color-mix(in lab, red, red)) {
      background-color: color-mix(in oklab, var(--color-red-500) 20%, transparent);
    }
  }
  .bg-red-600 {
    background-color: var(--color-red-600);
  }
  .bg-white {
    background-color: var(--color-white);
  }
  .bg-white\/50 {
    background-color: color-mix(in srgb, #fff 50%, transparent);
    @supports (color: color-mix(in lab, red, red)) {
      background-color: color-mix(in oklab, var(--color-white) 50%, transparent);
    }
  }
  .bg-white\/60 {
    background-color: color-mix(in srgb, #fff 60%, transparent);
    @supports (color: color-mix(in lab, red, red)) {
      background-color: color-mix(in oklab, var(--color-white) 60%, transparent);
    }
  }
  .bg-white\/70 {
    background-color: color-mix(in srgb, #fff 70%, transparent);
    @supports (color: color-mix(in lab, red, red)) {
      background-color: color-mix(in oklab, var(--color-white) 70%, transparent);
    }
  }
  .bg-white\/80 {
    background-color: color-mix(in srgb, #fff 80%, transparent);
    @supports (color: color-mix(in lab, red, red)) {
      background-color: color-mix(in oklab, var(--color-white) 80%, transparent);
    }
  }
  .bg-white\/90 {
    background-color: color-mix(in srgb, #fff 90%, transparent);
    @supports (color: color-mix(in lab, red, red)) {
      background-color: color-mix(in oklab, var(--color-white) 90%, transparent);
    }
  }
  .bg-white\/95 {
    background-color: color-mix(in srgb, #fff 95%, transparent);
    @supports (color: color-mix(in lab, red, red)) {
      background-color: color-mix(in oklab, var(--color-white) 95%, transparent);
    }
  }
  .bg-yellow-100 {
    background-color: var(--color-yellow-100);
  }
  .bg-yellow-500\/50 {
    background-color: color-mix(in srgb, oklch(79.5% 0.184 86.047) 50%, transparent);
    @supports (color: color-mix(in lab, red, red)) {
      background-color: color-mix(in oklab, var(--color-yellow-500) 50%, transparent);
    }
  }
  .bg-zinc-500 {
    background-color: var(--color-zinc-500);
  }
  .fill-current {
    fill: currentcolor;
  }
  .object-contain {
    -o-object-fit: contain;
       object-fit: contain;
  }
  .p-0 {
    padding: calc(var(--spacing) * 0);
  }
  .p-1 {
    padding: calc(var(--spacing) * 1);
  }
  .p-2 {
    padding: calc(var(--spacing) * 2);
  }
  .p-3 {
    padding: calc(var(--spacing) * 3);
  }
  .p-4 {
    padding: calc(var(--spacing) * 4);
  }
  .p-6 {
    padding: calc(var(--spacing) * 6);
  }
  .p-123 {
    padding: calc(var(--spacing) * 123);
  }
  .px-1 {
    padding-inline: calc(var(--spacing) * 1);
  }
  .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-4 {
    padding-inline: calc(var(--spacing) * 4);
  }
  .px-5 {
    padding-inline: calc(var(--spacing) * 5);
  }
  .px-6 {
    padding-inline: calc(var(--spacing) * 6);
  }
  .py-0\.5 {
    padding-block: calc(var(--spacing) * 0.5);
  }
  .py-1 {
    padding-block: calc(var(--spacing) * 1);
  }
  .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-4 {
    padding-block: calc(var(--spacing) * 4);
  }
  .py-6 {
    padding-block: calc(var(--spacing) * 6);
  }
  .py-8 {
    padding-block: calc(var(--spacing) * 8);
  }
  .py-12 {
    padding-block: calc(var(--spacing) * 12);
  }
  .ps-3 {
    padding-inline-start: calc(var(--spacing) * 3);
  }
  .pe-4 {
    padding-inline-end: calc(var(--spacing) * 4);
  }
  .pt-1 {
    padding-top: calc(var(--spacing) * 1);
  }
  .pt-2 {
    padding-top: calc(var(--spacing) * 2);
  }
  .pt-3 {
    padding-top: calc(var(--spacing) * 3);
  }
  .pt-4 {
    padding-top: calc(var(--spacing) * 4);
  }
  .pt-6 {
    padding-top: calc(var(--spacing) * 6);
  }
  .pr-3 {
    padding-right: calc(var(--spacing) * 3);
  }
  .pr-4 {
    padding-right: calc(var(--spacing) * 4);
  }
  .pr-8 {
    padding-right: calc(var(--spacing) * 8);
  }
  .pb-1 {
    padding-bottom: calc(var(--spacing) * 1);
  }
  .pb-2 {
    padding-bottom: calc(var(--spacing) * 2);
  }
  .pb-3 {
    padding-bottom: calc(var(--spacing) * 3);
  }
  .pb-10 {
    padding-bottom: calc(var(--spacing) * 10);
  }
  .pb-12 {
    padding-bottom: calc(var(--spacing) * 12);
  }
  .pl-5 {
    padding-left: calc(var(--spacing) * 5);
  }
  .text-center {
    text-align: center;
  }
  .text-left {
    text-align: left;
  }
  .text-right {
    text-align: right;
  }
  .text-start {
    text-align: start;
  }
  .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-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-\[10px\] {
    font-size: 10px;
  }
  .text-\[11px\] {
    font-size: 11px;
  }
  .text-\[13px\] {
    font-size: 13px;
  }
  .text-\[15px\] {
    font-size: 15px;
  }
  .leading-4 {
    --tw-leading: calc(var(--spacing) * 4);
    line-height: calc(var(--spacing) * 4);
  }
  .leading-5 {
    --tw-leading: calc(var(--spacing) * 5);
    line-height: calc(var(--spacing) * 5);
  }
  .leading-\[20px\] {
    --tw-leading: 20px;
    line-height: 20px;
  }
  .leading-normal {
    --tw-leading: var(--leading-normal);
    line-height: var(--leading-normal);
  }
  .leading-relaxed {
    --tw-leading: var(--leading-relaxed);
    line-height: var(--leading-relaxed);
  }
  .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-tight {
    --tw-tracking: var(--tracking-tight);
    letter-spacing: var(--tracking-tight);
  }
  .tracking-wider {
    --tw-tracking: var(--tracking-wider);
    letter-spacing: var(--tracking-wider);
  }
  .tracking-widest {
    --tw-tracking: var(--tracking-widest);
    letter-spacing: var(--tracking-widest);
  }
  .whitespace-nowrap {
    white-space: nowrap;
  }
  .text-\[\#1b1b18\] {
    color: #1b1b18;
  }
  .text-\[\#706f6c\] {
    color: #706f6c;
  }
  .text-\[\#F53003\] {
    color: #F53003;
  }
  .text-\[\#f53003\] {
    color: #f53003;
  }
  .text-\[var\(--color-text\)\] {
    color: var(--color-text);
  }
  .text-\[var\(--color-text-muted\)\] {
    color: var(--color-text-muted);
  }
  .text-black {
    color: var(--color-black);
  }
  .text-black\/60 {
    color: color-mix(in srgb, #000 60%, transparent);
    @supports (color: color-mix(in lab, red, red)) {
      color: color-mix(in oklab, var(--color-black) 60%, transparent);
    }
  }
  .text-black\/70 {
    color: color-mix(in srgb, #000 70%, transparent);
    @supports (color: color-mix(in lab, red, red)) {
      color: color-mix(in oklab, var(--color-black) 70%, transparent);
    }
  }
  .text-black\/80 {
    color: color-mix(in srgb, #000 80%, transparent);
    @supports (color: color-mix(in lab, red, red)) {
      color: color-mix(in oklab, var(--color-black) 80%, transparent);
    }
  }
  .text-blue-400 {
    color: var(--color-blue-400);
  }
  .text-blue-500 {
    color: var(--color-blue-500);
  }
  .text-blue-600 {
    color: var(--color-blue-600);
  }
  .text-blue-700 {
    color: var(--color-blue-700);
  }
  .text-current {
    color: currentcolor;
  }
  .text-emerald-700 {
    color: var(--color-emerald-700);
  }
  .text-gray-400 {
    color: var(--color-gray-400);
  }
  .text-gray-500 {
    color: var(--color-gray-500);
  }
  .text-gray-600 {
    color: var(--color-gray-600);
  }
  .text-gray-700 {
    color: var(--color-gray-700);
  }
  .text-gray-800 {
    color: var(--color-gray-800);
  }
  .text-gray-900 {
    color: var(--color-gray-900);
  }
  .text-green-500 {
    color: var(--color-green-500);
  }
  .text-green-600 {
    color: var(--color-green-600);
  }
  .text-green-700 {
    color: var(--color-green-700);
  }
  .text-indigo-700 {
    color: var(--color-indigo-700);
  }
  .text-inherit {
    color: inherit;
  }
  .text-orange-600 {
    color: var(--color-orange-600);
  }
  .text-orange-700 {
    color: var(--color-orange-700);
  }
  .text-purple-600 {
    color: var(--color-purple-600);
  }
  .text-purple-700 {
    color: var(--color-purple-700);
  }
  .text-red-400 {
    color: var(--color-red-400);
  }
  .text-red-500 {
    color: var(--color-red-500);
  }
  .text-red-600 {
    color: var(--color-red-600);
  }
  .text-red-700 {
    color: var(--color-red-700);
  }
  .text-rose-700 {
    color: var(--color-rose-700);
  }
  .text-slate-500 {
    color: var(--color-slate-500);
  }
  .text-slate-700 {
    color: var(--color-slate-700);
  }
  .text-slate-900 {
    color: var(--color-slate-900);
  }
  .text-white {
    color: var(--color-white);
  }
  .text-yellow-500 {
    color: var(--color-yellow-500);
  }
  .text-yellow-600 {
    color: var(--color-yellow-600);
  }
  .text-yellow-700 {
    color: var(--color-yellow-700);
  }
  .text-zinc-900 {
    color: var(--color-zinc-900);
  }
  .capitalize {
    text-transform: capitalize;
  }
  .lowercase {
    text-transform: lowercase;
  }
  .uppercase {
    text-transform: uppercase;
  }
  .underline {
    text-decoration-line: underline;
  }
  .decoration-black\/30 {
    text-decoration-color: color-mix(in srgb, #000 30%, transparent);
    @supports (color: color-mix(in lab, red, red)) {
      text-decoration-color: color-mix(in oklab, var(--color-black) 30%, transparent);
    }
  }
  .underline-offset-4 {
    text-underline-offset: 4px;
  }
  .opacity-0 {
    opacity: 0%;
  }
  .opacity-25 {
    opacity: 25%;
  }
  .opacity-30 {
    opacity: 30%;
  }
  .opacity-40 {
    opacity: 40%;
  }
  .opacity-50 {
    opacity: 50%;
  }
  .opacity-60 {
    opacity: 60%;
  }
  .opacity-70 {
    opacity: 70%;
  }
  .opacity-75 {
    opacity: 75%;
  }
  .opacity-80 {
    opacity: 80%;
  }
  .opacity-90 {
    opacity: 90%;
  }
  .opacity-100 {
    opacity: 100%;
  }
  .shadow {
    --tw-shadow: 0 1px 3px 0 var(--tw-shadow-color, rgb(0 0 0 / 0.1)), 0 1px 2px -1px var(--tw-shadow-color, rgb(0 0 0 / 0.1));
    box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
  }
  .shadow-2xl {
    --tw-shadow: 0 25px 50px -12px var(--tw-shadow-color, rgb(0 0 0 / 0.25));
    box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
  }
  .shadow-\[0px_0px_1px_0px_rgba\(0\,0\,0\,0\.03\)\,0px_1px_2px_0px_rgba\(0\,0\,0\,0\.06\)\] {
    --tw-shadow: 0px 0px 1px 0px var(--tw-shadow-color, rgba(0,0,0,0.03)), 0px 1px 2px 0px var(--tw-shadow-color, rgba(0,0,0,0.06));
    box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
  }
  .shadow-\[inset_0px_0px_0px_1px_rgba\(26\,26\,0\,0\.16\)\] {
    --tw-shadow: inset 0px 0px 0px 1px var(--tw-shadow-color, rgba(26,26,0,0.16));
    box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
  }
  .shadow-lg {
    --tw-shadow: 0 10px 15px -3px var(--tw-shadow-color, rgb(0 0 0 / 0.1)), 0 4px 6px -4px var(--tw-shadow-color, rgb(0 0 0 / 0.1));
    box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
  }
  .shadow-md {
    --tw-shadow: 0 4px 6px -1px var(--tw-shadow-color, rgb(0 0 0 / 0.1)), 0 2px 4px -2px var(--tw-shadow-color, rgb(0 0 0 / 0.1));
    box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
  }
  .shadow-sm {
    --tw-shadow: 0 1px 3px 0 var(--tw-shadow-color, rgb(0 0 0 / 0.1)), 0 1px 2px -1px var(--tw-shadow-color, rgb(0 0 0 / 0.1));
    box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
  }
  .shadow-xl {
    --tw-shadow: 0 20px 25px -5px var(--tw-shadow-color, rgb(0 0 0 / 0.1)), 0 8px 10px -6px var(--tw-shadow-color, rgb(0 0 0 / 0.1));
    box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
  }
  .ring-1 {
    --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);
  }
  .ring-black {
    --tw-ring-color: var(--color-black);
  }
  .ring-blue-500\/50 {
    --tw-ring-color: color-mix(in srgb, oklch(62.3% 0.214 259.815) 50%, transparent);
    @supports (color: color-mix(in lab, red, red)) {
      --tw-ring-color: color-mix(in oklab, var(--color-blue-500) 50%, transparent);
    }
  }
  .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,);
  }
  .backdrop-blur {
    --tw-backdrop-blur: blur(8px);
    backdrop-filter: var(--tw-backdrop-blur,) var(--tw-backdrop-brightness,) var(--tw-backdrop-contrast,) var(--tw-backdrop-grayscale,) var(--tw-backdrop-hue-rotate,) var(--tw-backdrop-invert,) var(--tw-backdrop-opacity,) var(--tw-backdrop-saturate,) var(--tw-backdrop-sepia,);
  }
  .backdrop-blur-md {
    --tw-backdrop-blur: blur(var(--blur-md));
    backdrop-filter: var(--tw-backdrop-blur,) var(--tw-backdrop-brightness,) var(--tw-backdrop-contrast,) var(--tw-backdrop-grayscale,) var(--tw-backdrop-hue-rotate,) var(--tw-backdrop-invert,) var(--tw-backdrop-opacity,) var(--tw-backdrop-saturate,) var(--tw-backdrop-sepia,);
  }
  .backdrop-blur-sm {
    --tw-backdrop-blur: blur(var(--blur-sm));
    backdrop-filter: var(--tw-backdrop-blur,) var(--tw-backdrop-brightness,) var(--tw-backdrop-contrast,) var(--tw-backdrop-grayscale,) var(--tw-backdrop-hue-rotate,) var(--tw-backdrop-invert,) var(--tw-backdrop-opacity,) var(--tw-backdrop-saturate,) var(--tw-backdrop-sepia,);
  }
  .transition {
    transition-property: color, background-color, border-color, outline-color, text-decoration-color, fill, stroke, --tw-gradient-from, --tw-gradient-via, --tw-gradient-to, opacity, box-shadow, transform, translate, scale, rotate, filter, 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));
  }
  .delay-300 {
    transition-delay: 300ms;
  }
  .duration-75 {
    --tw-duration: 75ms;
    transition-duration: 75ms;
  }
  .duration-150 {
    --tw-duration: 150ms;
    transition-duration: 150ms;
  }
  .duration-200 {
    --tw-duration: 200ms;
    transition-duration: 200ms;
  }
  .duration-300 {
    --tw-duration: 300ms;
    transition-duration: 300ms;
  }
  .duration-500 {
    --tw-duration: 500ms;
    transition-duration: 500ms;
  }
  .duration-750 {
    --tw-duration: 750ms;
    transition-duration: 750ms;
  }
  .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);
  }
  .select-none {
    -webkit-user-select: none;
    -moz-user-select: none;
         user-select: none;
  }
  .\[-webkit-overflow-scrolling\:touch\] {
    -webkit-overflow-scrolling: touch;
  }
  .not-has-\[nav\]\:hidden {
    &:not(*:has(*:is(nav))) {
      display: none;
    }
  }
  .group-hover\:opacity-100 {
    &:is(:where(.group):hover *) {
      @media (hover: hover) {
        opacity: 100%;
      }
    }
  }
  .peer-checked\:bg-green-500 {
    &:is(:where(.peer):checked ~ *) {
      background-color: var(--color-green-500);
    }
  }
  .peer-checked\:bg-orange-500 {
    &:is(:where(.peer):checked ~ *) {
      background-color: var(--color-orange-500);
    }
  }
  .peer-focus\:outline-none {
    &:is(:where(.peer):focus ~ *) {
      --tw-outline-style: none;
      outline-style: none;
    }
  }
  .placeholder\:text-black\/30 {
    &::-moz-placeholder {
      color: color-mix(in srgb, #000 30%, transparent);
      @supports (color: color-mix(in lab, red, red)) {
        color: color-mix(in oklab, var(--color-black) 30%, transparent);
      }
    }
    &::placeholder {
      color: color-mix(in srgb, #000 30%, transparent);
      @supports (color: color-mix(in lab, red, red)) {
        color: color-mix(in oklab, var(--color-black) 30%, transparent);
      }
    }
  }
  .before\:absolute {
    &::before {
      content: var(--tw-content);
      position: absolute;
    }
  }
  .before\:top-0 {
    &::before {
      content: var(--tw-content);
      top: calc(var(--spacing) * 0);
    }
  }
  .before\:top-1\/2 {
    &::before {
      content: var(--tw-content);
      top: calc(1/2 * 100%);
    }
  }
  .before\:bottom-0 {
    &::before {
      content: var(--tw-content);
      bottom: calc(var(--spacing) * 0);
    }
  }
  .before\:bottom-1\/2 {
    &::before {
      content: var(--tw-content);
      bottom: calc(1/2 * 100%);
    }
  }
  .before\:left-\[0\.4rem\] {
    &::before {
      content: var(--tw-content);
      left: 0.4rem;
    }
  }
  .before\:border-l {
    &::before {
      content: var(--tw-content);
      border-left-style: var(--tw-border-style);
      border-left-width: 1px;
    }
  }
  .before\:border-\[\#e3e3e0\] {
    &::before {
      content: var(--tw-content);
      border-color: #e3e3e0;
    }
  }
  .after\:absolute {
    &::after {
      content: var(--tw-content);
      position: absolute;
    }
  }
  .after\:top-\[2px\] {
    &::after {
      content: var(--tw-content);
      top: 2px;
    }
  }
  .after\:left-\[2px\] {
    &::after {
      content: var(--tw-content);
      left: 2px;
    }
  }
  .after\:h-4 {
    &::after {
      content: var(--tw-content);
      height: calc(var(--spacing) * 4);
    }
  }
  .after\:w-4 {
    &::after {
      content: var(--tw-content);
      width: calc(var(--spacing) * 4);
    }
  }
  .after\:rounded-full {
    &::after {
      content: var(--tw-content);
      border-radius: calc(infinity * 1px);
    }
  }
  .after\:border {
    &::after {
      content: var(--tw-content);
      border-style: var(--tw-border-style);
      border-width: 1px;
    }
  }
  .after\:border-gray-300 {
    &::after {
      content: var(--tw-content);
      border-color: var(--color-gray-300);
    }
  }
  .after\:bg-white {
    &::after {
      content: var(--tw-content);
      background-color: var(--color-white);
    }
  }
  .after\:transition-all {
    &::after {
      content: var(--tw-content);
      transition-property: all;
      transition-timing-function: var(--tw-ease, var(--default-transition-timing-function));
      transition-duration: var(--tw-duration, var(--default-transition-duration));
    }
  }
  .after\:content-\[\'\'\] {
    &::after {
      --tw-content: '';
      content: var(--tw-content);
    }
  }
  .peer-checked\:after\:translate-x-full {
    &:is(:where(.peer):checked ~ *) {
      &::after {
        content: var(--tw-content);
        --tw-translate-x: 100%;
        translate: var(--tw-translate-x) var(--tw-translate-y);
      }
    }
  }
  .peer-checked\:after\:border-white {
    &:is(:where(.peer):checked ~ *) {
      &::after {
        content: var(--tw-content);
        border-color: var(--color-white);
      }
    }
  }
  .odd\:bg-white {
    &:nth-child(odd) {
      background-color: var(--color-white);
    }
  }
  .even\:bg-black\/\[0\.03\] {
    &:nth-child(even) {
      background-color: color-mix(in srgb, #000 3%, transparent);
      @supports (color: color-mix(in lab, red, red)) {
        background-color: color-mix(in oklab, var(--color-black) 3%, transparent);
      }
    }
  }
  .hover\:border-\[\#1915014a\] {
    &:hover {
      @media (hover: hover) {
        border-color: #1915014a;
      }
    }
  }
  .hover\:border-\[\#19140035\] {
    &:hover {
      @media (hover: hover) {
        border-color: #19140035;
      }
    }
  }
  .hover\:border-black {
    &:hover {
      @media (hover: hover) {
        border-color: var(--color-black);
      }
    }
  }
  .hover\:border-gray-300 {
    &:hover {
      @media (hover: hover) {
        border-color: var(--color-gray-300);
      }
    }
  }
  .hover\:bg-black {
    &:hover {
      @media (hover: hover) {
        background-color: var(--color-black);
      }
    }
  }
  .hover\:bg-black\/5 {
    &:hover {
      @media (hover: hover) {
        background-color: color-mix(in srgb, #000 5%, transparent);
        @supports (color: color-mix(in lab, red, red)) {
          background-color: color-mix(in oklab, var(--color-black) 5%, transparent);
        }
      }
    }
  }
  .hover\:bg-black\/10 {
    &:hover {
      @media (hover: hover) {
        background-color: color-mix(in srgb, #000 10%, transparent);
        @supports (color: color-mix(in lab, red, red)) {
          background-color: color-mix(in oklab, var(--color-black) 10%, transparent);
        }
      }
    }
  }
  .hover\:bg-black\/90 {
    &:hover {
      @media (hover: hover) {
        background-color: color-mix(in srgb, #000 90%, transparent);
        @supports (color: color-mix(in lab, red, red)) {
          background-color: color-mix(in oklab, var(--color-black) 90%, transparent);
        }
      }
    }
  }
  .hover\:bg-gray-50 {
    &:hover {
      @media (hover: hover) {
        background-color: var(--color-gray-50);
      }
    }
  }
  .hover\:bg-gray-100 {
    &:hover {
      @media (hover: hover) {
        background-color: var(--color-gray-100);
      }
    }
  }
  .hover\:bg-gray-700 {
    &:hover {
      @media (hover: hover) {
        background-color: var(--color-gray-700);
      }
    }
  }
  .hover\:bg-red-500 {
    &:hover {
      @media (hover: hover) {
        background-color: var(--color-red-500);
      }
    }
  }
  .hover\:bg-red-500\/10 {
    &:hover {
      @media (hover: hover) {
        background-color: color-mix(in srgb, oklch(63.7% 0.237 25.331) 10%, transparent);
        @supports (color: color-mix(in lab, red, red)) {
          background-color: color-mix(in oklab, var(--color-red-500) 10%, transparent);
        }
      }
    }
  }
  .hover\:bg-white\/80 {
    &:hover {
      @media (hover: hover) {
        background-color: color-mix(in srgb, #fff 80%, transparent);
        @supports (color: color-mix(in lab, red, red)) {
          background-color: color-mix(in oklab, var(--color-white) 80%, transparent);
        }
      }
    }
  }
  .hover\:text-blue-500 {
    &:hover {
      @media (hover: hover) {
        color: var(--color-blue-500);
      }
    }
  }
  .hover\:text-gray-500 {
    &:hover {
      @media (hover: hover) {
        color: var(--color-gray-500);
      }
    }
  }
  .hover\:text-gray-700 {
    &:hover {
      @media (hover: hover) {
        color: var(--color-gray-700);
      }
    }
  }
  .hover\:text-gray-800 {
    &:hover {
      @media (hover: hover) {
        color: var(--color-gray-800);
      }
    }
  }
  .hover\:text-gray-900 {
    &:hover {
      @media (hover: hover) {
        color: var(--color-gray-900);
      }
    }
  }
  .hover\:underline {
    &:hover {
      @media (hover: hover) {
        text-decoration-line: underline;
      }
    }
  }
  .hover\:decoration-black {
    &:hover {
      @media (hover: hover) {
        text-decoration-color: var(--color-black);
      }
    }
  }
  .hover\:opacity-80 {
    &:hover {
      @media (hover: hover) {
        opacity: 80%;
      }
    }
  }
  .hover\:opacity-90 {
    &:hover {
      @media (hover: hover) {
        opacity: 90%;
      }
    }
  }
  .hover\:opacity-100 {
    &:hover {
      @media (hover: hover) {
        opacity: 100%;
      }
    }
  }
  .focus\:border-gray-300 {
    &:focus {
      border-color: var(--color-gray-300);
    }
  }
  .focus\:border-indigo-500 {
    &:focus {
      border-color: var(--color-indigo-500);
    }
  }
  .focus\:border-indigo-700 {
    &:focus {
      border-color: var(--color-indigo-700);
    }
  }
  .focus\:bg-gray-50 {
    &:focus {
      background-color: var(--color-gray-50);
    }
  }
  .focus\:bg-gray-100 {
    &:focus {
      background-color: var(--color-gray-100);
    }
  }
  .focus\:bg-gray-700 {
    &:focus {
      background-color: var(--color-gray-700);
    }
  }
  .focus\:bg-indigo-100 {
    &:focus {
      background-color: var(--color-indigo-100);
    }
  }
  .focus\:text-gray-500 {
    &:focus {
      color: var(--color-gray-500);
    }
  }
  .focus\:text-gray-700 {
    &:focus {
      color: var(--color-gray-700);
    }
  }
  .focus\:text-gray-800 {
    &:focus {
      color: var(--color-gray-800);
    }
  }
  .focus\:text-indigo-800 {
    &:focus {
      color: var(--color-indigo-800);
    }
  }
  .focus\:ring-2 {
    &:focus {
      --tw-ring-shadow: var(--tw-ring-inset,) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color, currentcolor);
      box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
    }
  }
  .focus\:ring-4 {
    &:focus {
      --tw-ring-shadow: var(--tw-ring-inset,) 0 0 0 calc(4px + var(--tw-ring-offset-width)) var(--tw-ring-color, currentcolor);
      box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
    }
  }
  .focus\:ring-black\/10 {
    &:focus {
      --tw-ring-color: color-mix(in srgb, #000 10%, transparent);
      @supports (color: color-mix(in lab, red, red)) {
        --tw-ring-color: color-mix(in oklab, var(--color-black) 10%, transparent);
      }
    }
  }
  .focus\:ring-indigo-500 {
    &:focus {
      --tw-ring-color: var(--color-indigo-500);
    }
  }
  .focus\:ring-red-500 {
    &:focus {
      --tw-ring-color: var(--color-red-500);
    }
  }
  .focus\:ring-offset-2 {
    &:focus {
      --tw-ring-offset-width: 2px;
      --tw-ring-offset-shadow: var(--tw-ring-inset,) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);
    }
  }
  .focus\:outline-none {
    &:focus {
      --tw-outline-style: none;
      outline-style: none;
    }
  }
  .active\:scale-\[0\.99\] {
    &:active {
      scale: 0.99;
    }
  }
  .active\:bg-gray-900 {
    &:active {
      background-color: var(--color-gray-900);
    }
  }
  .active\:bg-red-700 {
    &:active {
      background-color: var(--color-red-700);
    }
  }
  .disabled\:cursor-not-allowed {
    &:disabled {
      cursor: not-allowed;
    }
  }
  .disabled\:opacity-25 {
    &:disabled {
      opacity: 25%;
    }
  }
  .disabled\:opacity-60 {
    &:disabled {
      opacity: 60%;
    }
  }
  .sm\:inset-4 {
    @media (width >= 40rem) {
      inset: calc(var(--spacing) * 4);
    }
  }
  .sm\:mx-auto {
    @media (width >= 40rem) {
      margin-inline: auto;
    }
  }
  .sm\:-my-px {
    @media (width >= 40rem) {
      margin-block: -1px;
    }
  }
  .sm\:ms-6 {
    @media (width >= 40rem) {
      margin-inline-start: calc(var(--spacing) * 6);
    }
  }
  .sm\:ms-10 {
    @media (width >= 40rem) {
      margin-inline-start: calc(var(--spacing) * 10);
    }
  }
  .sm\:flex {
    @media (width >= 40rem) {
      display: flex;
    }
  }
  .sm\:hidden {
    @media (width >= 40rem) {
      display: none;
    }
  }
  .sm\:w-64 {
    @media (width >= 40rem) {
      width: calc(var(--spacing) * 64);
    }
  }
  .sm\:w-auto {
    @media (width >= 40rem) {
      width: auto;
    }
  }
  .sm\:w-full {
    @media (width >= 40rem) {
      width: 100%;
    }
  }
  .sm\:max-w-2xl {
    @media (width >= 40rem) {
      max-width: var(--container-2xl);
    }
  }
  .sm\:max-w-lg {
    @media (width >= 40rem) {
      max-width: var(--container-lg);
    }
  }
  .sm\:max-w-md {
    @media (width >= 40rem) {
      max-width: var(--container-md);
    }
  }
  .sm\:max-w-sm {
    @media (width >= 40rem) {
      max-width: var(--container-sm);
    }
  }
  .sm\:max-w-xl {
    @media (width >= 40rem) {
      max-width: var(--container-xl);
    }
  }
  .sm\:translate-y-0 {
    @media (width >= 40rem) {
      --tw-translate-y: calc(var(--spacing) * 0);
      translate: var(--tw-translate-x) var(--tw-translate-y);
    }
  }
  .sm\:scale-95 {
    @media (width >= 40rem) {
      --tw-scale-x: 95%;
      --tw-scale-y: 95%;
      --tw-scale-z: 95%;
      scale: var(--tw-scale-x) var(--tw-scale-y);
    }
  }
  .sm\:scale-100 {
    @media (width >= 40rem) {
      --tw-scale-x: 100%;
      --tw-scale-y: 100%;
      --tw-scale-z: 100%;
      scale: var(--tw-scale-x) var(--tw-scale-y);
    }
  }
  .sm\:items-center {
    @media (width >= 40rem) {
      align-items: center;
    }
  }
  .sm\:rounded-lg {
    @media (width >= 40rem) {
      border-radius: var(--radius-lg);
    }
  }
  .sm\:p-6 {
    @media (width >= 40rem) {
      padding: calc(var(--spacing) * 6);
    }
  }
  .sm\:p-8 {
    @media (width >= 40rem) {
      padding: calc(var(--spacing) * 8);
    }
  }
  .sm\:px-0 {
    @media (width >= 40rem) {
      padding-inline: calc(var(--spacing) * 0);
    }
  }
  .sm\:px-6 {
    @media (width >= 40rem) {
      padding-inline: calc(var(--spacing) * 6);
    }
  }
  .sm\:py-4 {
    @media (width >= 40rem) {
      padding-block: calc(var(--spacing) * 4);
    }
  }
  .sm\:text-lg {
    @media (width >= 40rem) {
      font-size: var(--text-lg);
      line-height: var(--tw-leading, var(--text-lg--line-height));
    }
  }
  .md\:inset-8 {
    @media (width >= 48rem) {
      inset: calc(var(--spacing) * 8);
    }
  }
  .md\:col-span-2 {
    @media (width >= 48rem) {
      grid-column: span 2 / span 2;
    }
  }
  .md\:col-span-4 {
    @media (width >= 48rem) {
      grid-column: span 4 / span 4;
    }
  }
  .md\:col-span-5 {
    @media (width >= 48rem) {
      grid-column: span 5 / span 5;
    }
  }
  .md\:col-span-7 {
    @media (width >= 48rem) {
      grid-column: span 7 / span 7;
    }
  }
  .md\:w-auto {
    @media (width >= 48rem) {
      width: auto;
    }
  }
  .md\:grid-cols-2 {
    @media (width >= 48rem) {
      grid-template-columns: repeat(2, minmax(0, 1fr));
    }
  }
  .md\:grid-cols-3 {
    @media (width >= 48rem) {
      grid-template-columns: repeat(3, minmax(0, 1fr));
    }
  }
  .md\:grid-cols-4 {
    @media (width >= 48rem) {
      grid-template-columns: repeat(4, minmax(0, 1fr));
    }
  }
  .md\:grid-cols-12 {
    @media (width >= 48rem) {
      grid-template-columns: repeat(12, minmax(0, 1fr));
    }
  }
  .md\:text-4xl {
    @media (width >= 48rem) {
      font-size: var(--text-4xl);
      line-height: var(--tw-leading, var(--text-4xl--line-height));
    }
  }
  .md\:text-xl {
    @media (width >= 48rem) {
      font-size: var(--text-xl);
      line-height: var(--tw-leading, var(--text-xl--line-height));
    }
  }
  .lg\:inset-12 {
    @media (width >= 64rem) {
      inset: calc(var(--spacing) * 12);
    }
  }
  .lg\:-mt-\[6\.6rem\] {
    @media (width >= 64rem) {
      margin-top: calc(6.6rem * -1);
    }
  }
  .lg\:mb-0 {
    @media (width >= 64rem) {
      margin-bottom: calc(var(--spacing) * 0);
    }
  }
  .lg\:mb-6 {
    @media (width >= 64rem) {
      margin-bottom: calc(var(--spacing) * 6);
    }
  }
  .lg\:-ml-px {
    @media (width >= 64rem) {
      margin-left: -1px;
    }
  }
  .lg\:ml-0 {
    @media (width >= 64rem) {
      margin-left: calc(var(--spacing) * 0);
    }
  }
  .lg\:block {
    @media (width >= 64rem) {
      display: block;
    }
  }
  .lg\:aspect-auto {
    @media (width >= 64rem) {
      aspect-ratio: auto;
    }
  }
  .lg\:w-\[438px\] {
    @media (width >= 64rem) {
      width: 438px;
    }
  }
  .lg\:max-w-4xl {
    @media (width >= 64rem) {
      max-width: var(--container-4xl);
    }
  }
  .lg\:grow {
    @media (width >= 64rem) {
      flex-grow: 1;
    }
  }
  .lg\:flex-row {
    @media (width >= 64rem) {
      flex-direction: row;
    }
  }
  .lg\:justify-center {
    @media (width >= 64rem) {
      justify-content: center;
    }
  }
  .lg\:rounded-t-none {
    @media (width >= 64rem) {
      border-top-left-radius: 0;
      border-top-right-radius: 0;
    }
  }
  .lg\:rounded-tl-lg {
    @media (width >= 64rem) {
      border-top-left-radius: var(--radius-lg);
    }
  }
  .lg\:rounded-r-lg {
    @media (width >= 64rem) {
      border-top-right-radius: var(--radius-lg);
      border-bottom-right-radius: var(--radius-lg);
    }
  }
  .lg\:rounded-br-none {
    @media (width >= 64rem) {
      border-bottom-right-radius: 0;
    }
  }
  .lg\:p-8 {
    @media (width >= 64rem) {
      padding: calc(var(--spacing) * 8);
    }
  }
  .lg\:p-20 {
    @media (width >= 64rem) {
      padding: calc(var(--spacing) * 20);
    }
  }
  .lg\:px-8 {
    @media (width >= 64rem) {
      padding-inline: calc(var(--spacing) * 8);
    }
  }
  .ltr\:origin-top-left {
    &:where(:dir(ltr), [dir="ltr"], [dir="ltr"] *) {
      transform-origin: 0 0;
    }
  }
  .ltr\:origin-top-right {
    &:where(:dir(ltr), [dir="ltr"], [dir="ltr"] *) {
      transform-origin: 100% 0;
    }
  }
  .rtl\:origin-top-left {
    &:where(:dir(rtl), [dir="rtl"], [dir="rtl"] *) {
      transform-origin: 0 0;
    }
  }
  .rtl\:origin-top-right {
    &:where(:dir(rtl), [dir="rtl"], [dir="rtl"] *) {
      transform-origin: 100% 0;
    }
  }
  .dark\:block {
    @media (prefers-color-scheme: dark) {
      display: block;
    }
  }
  .dark\:hidden {
    @media (prefers-color-scheme: dark) {
      display: none;
    }
  }
  .dark\:divide-white\/10 {
    @media (prefers-color-scheme: dark) {
      :where(& > :not(:last-child)) {
        border-color: color-mix(in srgb, #fff 10%, transparent);
        @supports (color: color-mix(in lab, red, red)) {
          border-color: color-mix(in oklab, var(--color-white) 10%, transparent);
        }
      }
    }
  }
  .dark\:border-\[\#3E3E3A\] {
    @media (prefers-color-scheme: dark) {
      border-color: #3E3E3A;
    }
  }
  .dark\:border-\[\#eeeeec\] {
    @media (prefers-color-scheme: dark) {
      border-color: #eeeeec;
    }
  }
  .dark\:border-gray-500 {
    @media (prefers-color-scheme: dark) {
      border-color: var(--color-gray-500);
    }
  }
  .dark\:border-gray-600 {
    @media (prefers-color-scheme: dark) {
      border-color: var(--color-gray-600);
    }
  }
  .dark\:border-gray-700 {
    @media (prefers-color-scheme: dark) {
      border-color: var(--color-gray-700);
    }
  }
  .dark\:border-indigo-600 {
    @media (prefers-color-scheme: dark) {
      border-color: var(--color-indigo-600);
    }
  }
  .dark\:border-white\/5 {
    @media (prefers-color-scheme: dark) {
      border-color: color-mix(in srgb, #fff 5%, transparent);
      @supports (color: color-mix(in lab, red, red)) {
        border-color: color-mix(in oklab, var(--color-white) 5%, transparent);
      }
    }
  }
  .dark\:border-white\/10 {
    @media (prefers-color-scheme: dark) {
      border-color: color-mix(in srgb, #fff 10%, transparent);
      @supports (color: color-mix(in lab, red, red)) {
        border-color: color-mix(in oklab, var(--color-white) 10%, transparent);
      }
    }
  }
  .dark\:border-white\/20 {
    @media (prefers-color-scheme: dark) {
      border-color: color-mix(in srgb, #fff 20%, transparent);
      @supports (color: color-mix(in lab, red, red)) {
        border-color: color-mix(in oklab, var(--color-white) 20%, transparent);
      }
    }
  }
  .dark\:bg-\[\#0a0a0a\] {
    @media (prefers-color-scheme: dark) {
      background-color: #0a0a0a;
    }
  }
  .dark\:bg-\[\#1D0002\] {
    @media (prefers-color-scheme: dark) {
      background-color: #1D0002;
    }
  }
  .dark\:bg-\[\#3E3E3A\] {
    @media (prefers-color-scheme: dark) {
      background-color: #3E3E3A;
    }
  }
  .dark\:bg-\[\#3a3a3c\] {
    @media (prefers-color-scheme: dark) {
      background-color: #3a3a3c;
    }
  }
  .dark\:bg-\[\#161615\] {
    @media (prefers-color-scheme: dark) {
      background-color: #161615;
    }
  }
  .dark\:bg-\[\#eeeeec\] {
    @media (prefers-color-scheme: dark) {
      background-color: #eeeeec;
    }
  }
  .dark\:bg-black\/70 {
    @media (prefers-color-scheme: dark) {
      background-color: color-mix(in srgb, #000 70%, transparent);
      @supports (color: color-mix(in lab, red, red)) {
        background-color: color-mix(in oklab, var(--color-black) 70%, transparent);
      }
    }
  }
  .dark\:bg-blue-900 {
    @media (prefers-color-scheme: dark) {
      background-color: var(--color-blue-900);
    }
  }
  .dark\:bg-gray-200 {
    @media (prefers-color-scheme: dark) {
      background-color: var(--color-gray-200);
    }
  }
  .dark\:bg-gray-700 {
    @media (prefers-color-scheme: dark) {
      background-color: var(--color-gray-700);
    }
  }
  .dark\:bg-gray-800 {
    @media (prefers-color-scheme: dark) {
      background-color: var(--color-gray-800);
    }
  }
  .dark\:bg-gray-900 {
    @media (prefers-color-scheme: dark) {
      background-color: var(--color-gray-900);
    }
  }
  .dark\:bg-green-900 {
    @media (prefers-color-scheme: dark) {
      background-color: var(--color-green-900);
    }
  }
  .dark\:bg-indigo-900\/50 {
    @media (prefers-color-scheme: dark) {
      background-color: color-mix(in srgb, oklch(35.9% 0.144 278.697) 50%, transparent);
      @supports (color: color-mix(in lab, red, red)) {
        background-color: color-mix(in oklab, var(--color-indigo-900) 50%, transparent);
      }
    }
  }
  .dark\:bg-neutral-900 {
    @media (prefers-color-scheme: dark) {
      background-color: var(--color-neutral-900);
    }
  }
  .dark\:bg-orange-900 {
    @media (prefers-color-scheme: dark) {
      background-color: var(--color-orange-900);
    }
  }
  .dark\:bg-purple-900 {
    @media (prefers-color-scheme: dark) {
      background-color: var(--color-purple-900);
    }
  }
  .dark\:bg-white\/5 {
    @media (prefers-color-scheme: dark) {
      background-color: color-mix(in srgb, #fff 5%, transparent);
      @supports (color: color-mix(in lab, red, red)) {
        background-color: color-mix(in oklab, var(--color-white) 5%, transparent);
      }
    }
  }
  .dark\:bg-white\/10 {
    @media (prefers-color-scheme: dark) {
      background-color: color-mix(in srgb, #fff 10%, transparent);
      @supports (color: color-mix(in lab, red, red)) {
        background-color: color-mix(in oklab, var(--color-white) 10%, transparent);
      }
    }
  }
  .dark\:bg-white\/20 {
    @media (prefers-color-scheme: dark) {
      background-color: color-mix(in srgb, #fff 20%, transparent);
      @supports (color: color-mix(in lab, red, red)) {
        background-color: color-mix(in oklab, var(--color-white) 20%, transparent);
      }
    }
  }
  .dark\:bg-white\/\[0\.04\] {
    @media (prefers-color-scheme: dark) {
      background-color: color-mix(in srgb, #fff 4%, transparent);
      @supports (color: color-mix(in lab, red, red)) {
        background-color: color-mix(in oklab, var(--color-white) 4%, transparent);
      }
    }
  }
  .dark\:bg-white\/\[0\.05\] {
    @media (prefers-color-scheme: dark) {
      background-color: color-mix(in srgb, #fff 5%, transparent);
      @supports (color: color-mix(in lab, red, red)) {
        background-color: color-mix(in oklab, var(--color-white) 5%, transparent);
      }
    }
  }
  .dark\:bg-white\/\[0\.06\] {
    @media (prefers-color-scheme: dark) {
      background-color: color-mix(in srgb, #fff 6%, transparent);
      @supports (color: color-mix(in lab, red, red)) {
        background-color: color-mix(in oklab, var(--color-white) 6%, transparent);
      }
    }
  }
  .dark\:bg-yellow-900 {
    @media (prefers-color-scheme: dark) {
      background-color: var(--color-yellow-900);
    }
  }
  .dark\:bg-zinc-400 {
    @media (prefers-color-scheme: dark) {
      background-color: var(--color-zinc-400);
    }
  }
  .dark\:bg-zinc-900\/90 {
    @media (prefers-color-scheme: dark) {
      background-color: color-mix(in srgb, oklch(21% 0.006 285.885) 90%, transparent);
      @supports (color: color-mix(in lab, red, red)) {
        background-color: color-mix(in oklab, var(--color-zinc-900) 90%, transparent);
      }
    }
  }
  .dark\:bg-zinc-900\/95 {
    @media (prefers-color-scheme: dark) {
      background-color: color-mix(in srgb, oklch(21% 0.006 285.885) 95%, transparent);
      @supports (color: color-mix(in lab, red, red)) {
        background-color: color-mix(in oklab, var(--color-zinc-900) 95%, transparent);
      }
    }
  }
  .dark\:text-\[\#1C1C1A\] {
    @media (prefers-color-scheme: dark) {
      color: #1C1C1A;
    }
  }
  .dark\:text-\[\#A1A09A\] {
    @media (prefers-color-scheme: dark) {
      color: #A1A09A;
    }
  }
  .dark\:text-\[\#EDEDEC\] {
    @media (prefers-color-scheme: dark) {
      color: #EDEDEC;
    }
  }
  .dark\:text-\[\#F61500\] {
    @media (prefers-color-scheme: dark) {
      color: #F61500;
    }
  }
  .dark\:text-\[\#FF4433\] {
    @media (prefers-color-scheme: dark) {
      color: #FF4433;
    }
  }
  .dark\:text-blue-300 {
    @media (prefers-color-scheme: dark) {
      color: var(--color-blue-300);
    }
  }
  .dark\:text-blue-400 {
    @media (prefers-color-scheme: dark) {
      color: var(--color-blue-400);
    }
  }
  .dark\:text-emerald-300 {
    @media (prefers-color-scheme: dark) {
      color: var(--color-emerald-300);
    }
  }
  .dark\:text-gray-100 {
    @media (prefers-color-scheme: dark) {
      color: var(--color-gray-100);
    }
  }
  .dark\:text-gray-200 {
    @media (prefers-color-scheme: dark) {
      color: var(--color-gray-200);
    }
  }
  .dark\:text-gray-300 {
    @media (prefers-color-scheme: dark) {
      color: var(--color-gray-300);
    }
  }
  .dark\:text-gray-400 {
    @media (prefers-color-scheme: dark) {
      color: var(--color-gray-400);
    }
  }
  .dark\:text-gray-500 {
    @media (prefers-color-scheme: dark) {
      color: var(--color-gray-500);
    }
  }
  .dark\:text-gray-800 {
    @media (prefers-color-scheme: dark) {
      color: var(--color-gray-800);
    }
  }
  .dark\:text-green-300 {
    @media (prefers-color-scheme: dark) {
      color: var(--color-green-300);
    }
  }
  .dark\:text-green-400 {
    @media (prefers-color-scheme: dark) {
      color: var(--color-green-400);
    }
  }
  .dark\:text-indigo-300 {
    @media (prefers-color-scheme: dark) {
      color: var(--color-indigo-300);
    }
  }
  .dark\:text-orange-300 {
    @media (prefers-color-scheme: dark) {
      color: var(--color-orange-300);
    }
  }
  .dark\:text-purple-300 {
    @media (prefers-color-scheme: dark) {
      color: var(--color-purple-300);
    }
  }
  .dark\:text-red-300 {
    @media (prefers-color-scheme: dark) {
      color: var(--color-red-300);
    }
  }
  .dark\:text-red-400 {
    @media (prefers-color-scheme: dark) {
      color: var(--color-red-400);
    }
  }
  .dark\:text-rose-300 {
    @media (prefers-color-scheme: dark) {
      color: var(--color-rose-300);
    }
  }
  .dark\:text-white {
    @media (prefers-color-scheme: dark) {
      color: var(--color-white);
    }
  }
  .dark\:text-white\/60 {
    @media (prefers-color-scheme: dark) {
      color: color-mix(in srgb, #fff 60%, transparent);
      @supports (color: color-mix(in lab, red, red)) {
        color: color-mix(in oklab, var(--color-white) 60%, transparent);
      }
    }
  }
  .dark\:text-white\/70 {
    @media (prefers-color-scheme: dark) {
      color: color-mix(in srgb, #fff 70%, transparent);
      @supports (color: color-mix(in lab, red, red)) {
        color: color-mix(in oklab, var(--color-white) 70%, transparent);
      }
    }
  }
  .dark\:text-white\/80 {
    @media (prefers-color-scheme: dark) {
      color: color-mix(in srgb, #fff 80%, transparent);
      @supports (color: color-mix(in lab, red, red)) {
        color: color-mix(in oklab, var(--color-white) 80%, transparent);
      }
    }
  }
  .dark\:text-yellow-300 {
    @media (prefers-color-scheme: dark) {
      color: var(--color-yellow-300);
    }
  }
  .dark\:text-zinc-100 {
    @media (prefers-color-scheme: dark) {
      color: var(--color-zinc-100);
    }
  }
  .dark\:decoration-white\/30 {
    @media (prefers-color-scheme: dark) {
      text-decoration-color: color-mix(in srgb, #fff 30%, transparent);
      @supports (color: color-mix(in lab, red, red)) {
        text-decoration-color: color-mix(in oklab, var(--color-white) 30%, transparent);
      }
    }
  }
  .dark\:shadow-\[inset_0px_0px_0px_1px_\#fffaed2d\] {
    @media (prefers-color-scheme: dark) {
      --tw-shadow: inset 0px 0px 0px 1px var(--tw-shadow-color, #fffaed2d);
      box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
    }
  }
  .dark\:placeholder\:text-white\/30 {
    @media (prefers-color-scheme: dark) {
      &::-moz-placeholder {
        color: color-mix(in srgb, #fff 30%, transparent);
        @supports (color: color-mix(in lab, red, red)) {
          color: color-mix(in oklab, var(--color-white) 30%, transparent);
        }
      }
      &::placeholder {
        color: color-mix(in srgb, #fff 30%, transparent);
        @supports (color: color-mix(in lab, red, red)) {
          color: color-mix(in oklab, var(--color-white) 30%, transparent);
        }
      }
    }
  }
  .dark\:before\:border-\[\#3E3E3A\] {
    @media (prefers-color-scheme: dark) {
      &::before {
        content: var(--tw-content);
        border-color: #3E3E3A;
      }
    }
  }
  .dark\:odd\:bg-white\/\[0\.04\] {
    @media (prefers-color-scheme: dark) {
      &:nth-child(odd) {
        background-color: color-mix(in srgb, #fff 4%, transparent);
        @supports (color: color-mix(in lab, red, red)) {
          background-color: color-mix(in oklab, var(--color-white) 4%, transparent);
        }
      }
    }
  }
  .dark\:even\:bg-white\/\[0\.08\] {
    @media (prefers-color-scheme: dark) {
      &:nth-child(even) {
        background-color: color-mix(in srgb, #fff 8%, transparent);
        @supports (color: color-mix(in lab, red, red)) {
          background-color: color-mix(in oklab, var(--color-white) 8%, transparent);
        }
      }
    }
  }
  .dark\:hover\:border-\[\#3E3E3A\] {
    @media (prefers-color-scheme: dark) {
      &:hover {
        @media (hover: hover) {
          border-color: #3E3E3A;
        }
      }
    }
  }
  .dark\:hover\:border-\[\#62605b\] {
    @media (prefers-color-scheme: dark) {
      &:hover {
        @media (hover: hover) {
          border-color: #62605b;
        }
      }
    }
  }
  .dark\:hover\:border-gray-600 {
    @media (prefers-color-scheme: dark) {
      &:hover {
        @media (hover: hover) {
          border-color: var(--color-gray-600);
        }
      }
    }
  }
  .dark\:hover\:border-gray-700 {
    @media (prefers-color-scheme: dark) {
      &:hover {
        @media (hover: hover) {
          border-color: var(--color-gray-700);
        }
      }
    }
  }
  .dark\:hover\:border-white {
    @media (prefers-color-scheme: dark) {
      &:hover {
        @media (hover: hover) {
          border-color: var(--color-white);
        }
      }
    }
  }
  .dark\:hover\:bg-gray-700 {
    @media (prefers-color-scheme: dark) {
      &:hover {
        @media (hover: hover) {
          background-color: var(--color-gray-700);
        }
      }
    }
  }
  .dark\:hover\:bg-gray-800 {
    @media (prefers-color-scheme: dark) {
      &:hover {
        @media (hover: hover) {
          background-color: var(--color-gray-800);
        }
      }
    }
  }
  .dark\:hover\:bg-gray-900 {
    @media (prefers-color-scheme: dark) {
      &:hover {
        @media (hover: hover) {
          background-color: var(--color-gray-900);
        }
      }
    }
  }
  .dark\:hover\:bg-white {
    @media (prefers-color-scheme: dark) {
      &:hover {
        @media (hover: hover) {
          background-color: var(--color-white);
        }
      }
    }
  }
  .dark\:hover\:bg-white\/5 {
    @media (prefers-color-scheme: dark) {
      &:hover {
        @media (hover: hover) {
          background-color: color-mix(in srgb, #fff 5%, transparent);
          @supports (color: color-mix(in lab, red, red)) {
            background-color: color-mix(in oklab, var(--color-white) 5%, transparent);
          }
        }
      }
    }
  }
  .dark\:hover\:bg-white\/10 {
    @media (prefers-color-scheme: dark) {
      &:hover {
        @media (hover: hover) {
          background-color: color-mix(in srgb, #fff 10%, transparent);
          @supports (color: color-mix(in lab, red, red)) {
            background-color: color-mix(in oklab, var(--color-white) 10%, transparent);
          }
        }
      }
    }
  }
  .dark\:hover\:bg-white\/\[0\.06\] {
    @media (prefers-color-scheme: dark) {
      &:hover {
        @media (hover: hover) {
          background-color: color-mix(in srgb, #fff 6%, transparent);
          @supports (color: color-mix(in lab, red, red)) {
            background-color: color-mix(in oklab, var(--color-white) 6%, transparent);
          }
        }
      }
    }
  }
  .dark\:hover\:bg-white\/\[0\.08\] {
    @media (prefers-color-scheme: dark) {
      &:hover {
        @media (hover: hover) {
          background-color: color-mix(in srgb, #fff 8%, transparent);
          @supports (color: color-mix(in lab, red, red)) {
            background-color: color-mix(in oklab, var(--color-white) 8%, transparent);
          }
        }
      }
    }
  }
  .dark\:hover\:text-gray-100 {
    @media (prefers-color-scheme: dark) {
      &:hover {
        @media (hover: hover) {
          color: var(--color-gray-100);
        }
      }
    }
  }
  .dark\:hover\:text-gray-200 {
    @media (prefers-color-scheme: dark) {
      &:hover {
        @media (hover: hover) {
          color: var(--color-gray-200);
        }
      }
    }
  }
  .dark\:hover\:text-gray-300 {
    @media (prefers-color-scheme: dark) {
      &:hover {
        @media (hover: hover) {
          color: var(--color-gray-300);
        }
      }
    }
  }
  .dark\:hover\:text-gray-400 {
    @media (prefers-color-scheme: dark) {
      &:hover {
        @media (hover: hover) {
          color: var(--color-gray-400);
        }
      }
    }
  }
  .dark\:hover\:decoration-white {
    @media (prefers-color-scheme: dark) {
      &:hover {
        @media (hover: hover) {
          text-decoration-color: var(--color-white);
        }
      }
    }
  }
  .dark\:focus\:border-gray-600 {
    @media (prefers-color-scheme: dark) {
      &:focus {
        border-color: var(--color-gray-600);
      }
    }
  }
  .dark\:focus\:border-gray-700 {
    @media (prefers-color-scheme: dark) {
      &:focus {
        border-color: var(--color-gray-700);
      }
    }
  }
  .dark\:focus\:border-indigo-300 {
    @media (prefers-color-scheme: dark) {
      &:focus {
        border-color: var(--color-indigo-300);
      }
    }
  }
  .dark\:focus\:border-indigo-600 {
    @media (prefers-color-scheme: dark) {
      &:focus {
        border-color: var(--color-indigo-600);
      }
    }
  }
  .dark\:focus\:bg-gray-700 {
    @media (prefers-color-scheme: dark) {
      &:focus {
        background-color: var(--color-gray-700);
      }
    }
  }
  .dark\:focus\:bg-gray-800 {
    @media (prefers-color-scheme: dark) {
      &:focus {
        background-color: var(--color-gray-800);
      }
    }
  }
  .dark\:focus\:bg-gray-900 {
    @media (prefers-color-scheme: dark) {
      &:focus {
        background-color: var(--color-gray-900);
      }
    }
  }
  .dark\:focus\:bg-indigo-900 {
    @media (prefers-color-scheme: dark) {
      &:focus {
        background-color: var(--color-indigo-900);
      }
    }
  }
  .dark\:focus\:bg-white {
    @media (prefers-color-scheme: dark) {
      &:focus {
        background-color: var(--color-white);
      }
    }
  }
  .dark\:focus\:text-gray-200 {
    @media (prefers-color-scheme: dark) {
      &:focus {
        color: var(--color-gray-200);
      }
    }
  }
  .dark\:focus\:text-gray-300 {
    @media (prefers-color-scheme: dark) {
      &:focus {
        color: var(--color-gray-300);
      }
    }
  }
  .dark\:focus\:text-gray-400 {
    @media (prefers-color-scheme: dark) {
      &:focus {
        color: var(--color-gray-400);
      }
    }
  }
  .dark\:focus\:text-indigo-200 {
    @media (prefers-color-scheme: dark) {
      &:focus {
        color: var(--color-indigo-200);
      }
    }
  }
  .dark\:focus\:ring-indigo-600 {
    @media (prefers-color-scheme: dark) {
      &:focus {
        --tw-ring-color: var(--color-indigo-600);
      }
    }
  }
  .dark\:focus\:ring-white\/10 {
    @media (prefers-color-scheme: dark) {
      &:focus {
        --tw-ring-color: color-mix(in srgb, #fff 10%, transparent);
        @supports (color: color-mix(in lab, red, red)) {
          --tw-ring-color: color-mix(in oklab, var(--color-white) 10%, transparent);
        }
      }
    }
  }
  .dark\:focus\:ring-offset-gray-800 {
    @media (prefers-color-scheme: dark) {
      &:focus {
        --tw-ring-offset-color: var(--color-gray-800);
      }
    }
  }
  .dark\:active\:bg-gray-300 {
    @media (prefers-color-scheme: dark) {
      &:active {
        background-color: var(--color-gray-300);
      }
    }
  }
  .starting\:translate-y-4 {
    @starting-style {
      --tw-translate-y: calc(var(--spacing) * 4);
      translate: var(--tw-translate-x) var(--tw-translate-y);
    }
  }
  .starting\:translate-y-6 {
    @starting-style {
      --tw-translate-y: calc(var(--spacing) * 6);
      translate: var(--tw-translate-x) var(--tw-translate-y);
    }
  }
  .starting\:opacity-0 {
    @starting-style {
      opacity: 0%;
    }
  }
}
:root {
  --color-primary: #0B3C5D;
  --color-primary-hover: #092e47;
  --color-primary-light: #1a5a8a;
  --color-accent: #C6A15B;
  --color-accent-hover: #b8934d;
  --color-accent-light: #d4b574;
  --color-success: #34c759;
  --color-success-bg: rgba(52, 199, 89, 0.1);
  --color-warning: #ff9500;
  --color-warning-bg: rgba(255, 149, 0, 0.1);
  --color-danger: #d92d20;
  --color-danger-hover: #b91c1c;
  --color-danger-bg: rgba(217, 45, 32, 0.1);
  --color-dept-ws: #3b82f6;
  --color-dept-vk: #10b981;
  --color-status-neutral-bg: #f3f4f6;
  --color-status-neutral-text: #6b7280;
  --color-status-pending-bg: #fef3c7;
  --color-status-pending-text: #92400e;
  --color-status-success-bg: #d1fae5;
  --color-status-success-text: #065f46;
  --color-status-danger-bg: #fee2e2;
  --color-status-danger-text: #991b1b;
  --color-status-absent-urlaub-bg: #fef3c7;
  --color-status-absent-urlaub-text: #92400e;
  --color-status-absent-krank-bg: #fee2e2;
  --color-status-absent-krank-text: #991b1b;
  --color-bg: #ffffff;
  --color-bg-secondary: #f5f5f7;
  --color-card: #f5f5f7;
  --color-card-hover: #ebebed;
  --color-border: rgba(0, 0, 0, 0.08);
  --color-border-strong: rgba(0, 0, 0, 0.12);
  --color-text: #1d1d1f;
  --color-text-secondary: #515154;
  --color-text-muted: #86868b;
  --space-1: 4px;
  --space-2: 8px;
  --space-3: 12px;
  --space-4: 16px;
  --space-5: 20px;
  --space-6: 24px;
  --space-8: 32px;
  --space-10: 40px;
  --space-12: 48px;
  --radius-sm: 8px;
  --radius-md: 12px;
  --radius-lg: 16px;
  --radius-xl: 20px;
  --radius-2xl: 24px;
  --radius-full: 9999px;
  --shadow-sm: 0 1px 2px rgba(0, 0, 0, 0.04);
  --shadow-md: 0 4px 12px rgba(0, 0, 0, 0.08);
  --shadow-lg: 0 8px 24px rgba(0, 0, 0, 0.12);
  --shadow-xl: 0 16px 48px rgba(0, 0, 0, 0.16);
  --font-sans: -apple-system, BlinkMacSystemFont, "SF Pro Display", "SF Pro Text", 
               "Helvetica Neue", Helvetica, Arial, sans-serif;
  --font-mono: "SF Mono", ui-monospace, SFMono-Regular, Menlo, Monaco, 
               Consolas, monospace;
  --text-xs: 0.75rem;
  --text-sm: 0.875rem;
  --text-base: 1rem;
  --text-lg: 1.125rem;
  --text-xl: 1.25rem;
  --text-2xl: 1.5rem;
  --text-3xl: 1.875rem;
  --transition-fast: 150ms ease;
  --transition-base: 200ms ease;
  --transition-slow: 300ms ease;
  --z-dropdown: 100;
  --z-sticky: 200;
  --z-modal: 300;
  --z-toast: 400;
}
.dark, [data-theme="dark"] {
  --color-bg: #0b0f14;
  --color-bg-secondary: #161b22;
  --color-card: #161b22;
  --color-card-hover: #1c2128;
  --color-border: rgba(255, 255, 255, 0.08);
  --color-border-strong: rgba(255, 255, 255, 0.12);
  --color-text: #e6edf3;
  --color-text-secondary: #9da7b1;
  --color-text-muted: #6e7681;
  --color-primary-light: #3d7ab3;
  --color-accent-light: #dcc48a;
  --shadow-sm: 0 1px 2px rgba(0, 0, 0, 0.2);
  --shadow-md: 0 4px 12px rgba(0, 0, 0, 0.3);
  --shadow-lg: 0 8px 24px rgba(0, 0, 0, 0.4);
  --shadow-xl: 0 16px 48px rgba(0, 0, 0, 0.5);
  --color-status-neutral-bg: #374151;
  --color-status-neutral-text: #9ca3af;
  --color-status-pending-bg: #78350f;
  --color-status-pending-text: #fcd34d;
  --color-status-success-bg: #064e3b;
  --color-status-success-text: #6ee7b7;
  --color-status-danger-bg: #7f1d1d;
  --color-status-danger-text: #fca5a5;
  --color-status-absent-urlaub-bg: #78350f;
  --color-status-absent-urlaub-text: #fcd34d;
  --color-status-absent-krank-bg: #7f1d1d;
  --color-status-absent-krank-text: #fca5a5;
}
*, *::before, *::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}
html {
  font-size: 16px;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
}
html, body {
  max-width: 100vw;
}
body {
  font-family: var(--font-sans);
  font-size: var(--text-base);
  line-height: 1.5;
  color: var(--color-text);
  background-color: var(--color-bg);
  min-height: 100vh;
  min-height: 100dvh;
}
.page {
  min-height: 100vh;
  min-height: 100dvh;
  display: flex;
  flex-direction: column;
}
header {
  position: sticky;
  top: 0;
  z-index: var(--z-sticky);
  background: var(--color-bg);
  border-bottom: 1px solid var(--color-border);
  padding: var(--space-4);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-4);
  min-height: 64px;
  padding-top: max(var(--space-4), env(safe-area-inset-top));
}
header .header-title {
  flex: 1;
  min-width: 0;
}
header h1 {
  font-size: var(--text-xl);
  font-weight: 600;
  line-height: 1.2;
  color: var(--color-text);
  margin: 0;
}
header h2 {
  font-size: var(--text-sm);
  font-weight: 400;
  line-height: 1.4;
  color: var(--color-text-muted);
  margin: 0;
  margin-top: var(--space-1);
}
header .header-actions {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  flex-shrink: 0;
}
main {
  flex: 1;
  padding: var(--space-4);
  padding-bottom: max(var(--space-6), env(safe-area-inset-bottom));
  width: 100%;
  max-width: 100%;
  margin: 0 auto;
}
@media (min-width: 768px) {
  main {
    padding: var(--space-6);
  }
}
@media (min-width: 1024px) {
  main {
    padding: var(--space-8);
  }
}
h1, h2, h3, h4, h5, h6 {
  font-weight: 600;
  line-height: 1.25;
  color: var(--color-text);
}
h1 {
  font-size: var(--text-2xl);
}
h2 {
  font-size: var(--text-xl);
}
h3 {
  font-size: var(--text-lg);
}
h4 {
  font-size: var(--text-base);
}
p {
  margin: 0 0 var(--space-4) 0;
  color: var(--color-text-secondary);
}
p:last-child {
  margin-bottom: 0;
}
a {
  color: var(--color-primary);
  text-decoration: none;
  transition: color var(--transition-fast);
}
a:hover {
  color: var(--color-primary-hover);
}
.text-xs {
  font-size: var(--text-xs);
}
.text-sm {
  font-size: var(--text-sm);
}
.text-base {
  font-size: var(--text-base);
}
.text-lg {
  font-size: var(--text-lg);
}
.text-xl {
  font-size: var(--text-xl);
}
.text-muted {
  color: var(--color-text-muted);
}
.text-secondary {
  color: var(--color-text-secondary);
}
.font-medium {
  font-weight: 500;
}
.font-semibold {
  font-weight: 600;
}
.font-bold {
  font-weight: 700;
}
.font-mono {
  font-family: var(--font-mono);
}
ul, ol {
  margin: var(--space-2) 0 var(--space-4) var(--space-5);
}
li {
  margin-bottom: var(--space-1);
}
code {
  font-family: var(--font-mono);
  font-size: 0.9em;
  background: var(--color-bg-secondary);
  padding: 2px 6px;
  border-radius: var(--radius-sm);
}
pre {
  font-family: var(--font-mono);
  font-size: var(--text-sm);
  background: var(--color-bg-secondary);
  padding: var(--space-4);
  border-radius: var(--radius-lg);
  overflow-x: auto;
  border: 1px solid var(--color-border);
}
pre code {
  background: none;
  padding: 0;
}
::-moz-selection {
  background: var(--color-primary);
  color: white;
}
::selection {
  background: var(--color-primary);
  color: white;
}
:focus-visible {
  outline: 2px solid var(--color-primary);
  outline-offset: 2px;
}
.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}
.card-grid {
  --card-height: 50vh;
  --card-min-height: 200px;
  --card-max-height: 75vh;
}
.card-grid {
  display: grid;
  gap: var(--space-4);
  width: 100%;
}
.card-grid {
  grid-template-columns: 1fr;
}
@media (min-width: 768px) {
  .card-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: var(--space-5);
  }
}
@media (min-width: 1024px) {
  .card-grid {
    gap: var(--space-6);
    grid-template-columns: repeat(3, 1fr);
  }
  .card-grid[data-cols="1"] {
    grid-template-columns: 1fr;
    max-width: 640px;
  }
  .card-grid[data-cols="2"] {
    grid-template-columns: repeat(2, 1fr);
  }
  .card-grid[data-cols="3"] {
    grid-template-columns: repeat(3, 1fr);
  }
  .card-grid[data-cols="4"] {
    grid-template-columns: repeat(4, 1fr);
  }
}
@media (min-width: 1280px) {
  .card-grid {
    gap: var(--space-6);
  }
}
.card[data-span="full"], .card.span-full {
  grid-column: 1 / -1;
}
@media (min-width: 768px) {
  .card[data-span="2"], .card.span-2 {
    grid-column: span 2;
  }
}
@media (min-width: 768px) {
  .card-grid[data-grid-mode="fixed"] {
    grid-auto-rows: var(--card-height, 50vh);
  }
  .card-grid[data-grid-mode="fixed"] > .card {
    height: 100%;
    overflow: hidden;
  }
  .card-grid[data-grid-mode="fixed"] > .card > .card-inner {
    height: 100%;
    overflow-y: auto;
  }
}
@media (min-width: 768px) {
  .card-grid[data-grid-mode="row-max"] {
    grid-auto-rows: auto;
    align-items: stretch;
  }
  .card-grid[data-grid-mode="row-max"] > .card {
    min-height: var(--card-min-height, 200px);
    height: auto !important;
    overflow: visible;
  }
  .card-grid[data-grid-mode="row-max"] > .card > .card-inner {
    height: auto !important;
    min-height: 0;
    overflow-y: visible;
  }
}
@media (min-width: 768px) {
  .card-grid[data-grid-mode="content"] {
    grid-auto-rows: auto;
    align-items: start;
  }
  .card-grid[data-grid-mode="content"] > .card {
    min-height: var(--card-min-height, 200px);
    height: auto !important;
    overflow: visible;
  }
  .card-grid[data-grid-mode="content"] > .card > .card-inner {
    height: auto !important;
    min-height: 0;
    overflow-y: visible;
  }
}
@media (max-width: 767px) {
  .card-grid > .card {
    height: auto !important;
    max-height: none !important;
  }
  .card-grid > .card > .card-inner {
    height: auto !important;
    max-height: none !important;
    overflow-y: visible !important;
  }
}
.card-inner::-webkit-scrollbar {
  width: 6px;
}
.card-inner::-webkit-scrollbar-track {
  background: transparent;
}
.card-inner::-webkit-scrollbar-thumb {
  background: var(--color-border);
  border-radius: 3px;
}
.card-inner::-webkit-scrollbar-thumb:hover {
  background: var(--color-text-muted);
}
.app-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-4);
}
@media (min-width: 768px) {
  .app-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (min-width: 1024px) {
  .app-grid {
    grid-template-columns: repeat(3, 1fr);
  }
}
.card {
  background: var(--color-card);
  border-radius: var(--radius-xl);
  overflow: hidden;
  overflow-x: hidden;
  transition: background-color var(--transition-base);
}
.card-inner {
  padding: var(--space-5);
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
  height: 100%;
  overflow-x: hidden;
  word-wrap: break-word;
  overflow-wrap: break-word;
}
@media (min-width: 768px) {
  .card-inner {
    padding: var(--space-6);
  }
}
.card-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: var(--space-3);
}
.card-title {
  font-size: var(--text-lg);
  font-weight: 600;
  color: var(--color-text);
  margin: 0;
}
.card-subtitle {
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  margin-top: var(--space-1);
}
.card-body {
  flex: 1;
}
.card-footer {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding-top: var(--space-4);
  border-top: 1px solid var(--color-border);
  margin-top: auto;
}
.bgpt-group {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}
.bgpt-group + .bgpt-group {
  margin-top: var(--space-4);
  padding-top: var(--space-4);
  border-top: 1px solid var(--color-border);
}
.card.card-compact .card-inner {
  padding: var(--space-4);
  gap: var(--space-3);
}
.card.card-interactive {
  cursor: pointer;
  transition: background-color var(--transition-base), transform var(--transition-base);
}
.card.card-interactive:hover {
  background: var(--color-card-hover);
}
.card.card-interactive:active {
  transform: scale(0.98);
}
.card.card-bordered {
  background: var(--color-bg);
  border: 1px solid var(--color-border);
}
.card.card-elevated {
  background: var(--color-bg);
  box-shadow: var(--shadow-md);
}
.card .info-box {
  background: var(--color-bg);
  border-radius: var(--radius-lg);
  padding: var(--space-4);
  border: 1px solid var(--color-border);
}
.dark .card .info-box {
  background: var(--color-bg-secondary);
}
.card .divider {
  height: 1px;
  background: var(--color-border);
  margin: var(--space-4) 0;
}
.card-scroll {
  max-width: 100%;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  border-radius: var(--radius-lg);
  border: 1px solid var(--color-border);
}
.plan-viewer {
  max-height: 240px;
  min-height: 200px;
}
.oauth-card {
  border-radius: var(--radius-lg);
  border: 1px solid var(--color-border);
  background: var(--color-card);
  padding: var(--space-4);
}
.table-scroll {
  max-width: 100%;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  border-radius: var(--radius-lg);
  border: 1px solid var(--color-border);
  background: var(--color-card);
  overflow-y: hidden;
  width: 100%;
  min-width: 0;
}
.knowledge-tabs {
  border-radius: var(--radius-lg);
  border: 1px solid var(--color-border);
  background: var(--color-card);
  overflow: hidden;
}
.chat-container {
  border-radius: var(--radius-lg);
  border: 1px solid var(--color-border);
  background: var(--color-bg-secondary);
  overflow: hidden;
}
.rating-pills {
  display: inline-flex;
  border-radius: var(--radius-lg);
  border: 1px solid var(--color-border);
  background: var(--color-card);
  padding: var(--space-1);
  gap: var(--space-1);
}
.card-empty {
  text-align: center;
  padding: var(--space-8) var(--space-4);
  color: var(--color-text-muted);
}
.card-empty-icon {
  font-size: 2rem;
  margin-bottom: var(--space-3);
  opacity: 0.5;
}
.card-empty-text {
  font-size: var(--text-sm);
}
.card:has(.logo-card-white) {
  background: #ffffff !important;
}
.card:has(.logo-card-black) {
  background: #000000 !important;
}
.card:has(.logo-card-transparent) {
  background: transparent !important;
  box-shadow: none !important;
  border: none !important;
}
.privacy-target.is-blurred {
  filter: blur(12px);
  pointer-events: none;
  -webkit-user-select: none;
     -moz-user-select: none;
          user-select: none;
  transition: filter 0.3s ease;
  margin: calc(-1 * var(--space-5));
  padding: var(--space-5);
}
@media (min-width: 768px) {
  .privacy-target.is-blurred {
    margin: calc(-1 * var(--space-6));
    padding: var(--space-6);
  }
}
.privacy-target {
  transition: filter 0.3s ease;
}
.privacy-toggle {
  position: absolute;
  right: 0;
  top: 0;
  z-index: 20;
  width: 60px;
  height: 28px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 9999px;
  border: 1px solid rgba(255, 255, 255, 0.2);
  background: rgba(255, 255, 255, 0.1);
  backdrop-filter: blur(8px);
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 0.05em;
  color: rgba(255, 255, 255, 0.9);
  cursor: pointer;
  transition: background 0.2s ease, border-color 0.2s ease;
}
.privacy-toggle:hover {
  background: rgba(255, 255, 255, 0.2);
  border-color: rgba(255, 255, 255, 0.3);
}
.privacy-toggle-text {
  display: block;
  text-align: center;
}
:root:not(.dark) .privacy-toggle {
  border-color: rgba(0, 0, 0, 0.15);
  background: rgba(0, 0, 0, 0.05);
  color: rgba(0, 0, 0, 0.7);
}
:root:not(.dark) .privacy-toggle:hover {
  background: rgba(0, 0, 0, 0.1);
}
.card {
  position: relative;
}
.card-expand-btn {
  position: absolute;
  top: var(--space-3);
  right: var(--space-3);
  z-index: 15;
  width: 32px;
  height: 32px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 9999px;
  border: 1px solid var(--color-border);
  background: var(--color-bg);
  color: var(--color-text-muted);
  cursor: pointer;
  transition: background 0.2s ease, border-color 0.2s ease, opacity 0.2s ease;
  opacity: 0;
}
.card:hover .card-expand-btn:not(.hidden) {
  opacity: 1;
}
.card-expand-btn:hover {
  background: var(--color-bg-secondary);
  border-color: var(--color-text-muted);
  color: var(--color-text);
}
.card-expand-btn.hidden {
  display: none !important;
}
.card-expand-btn .expand-icon, .card-expand-btn .collapse-icon {
  display: block;
}
.card-expand-btn .collapse-icon.hidden, .card-expand-btn .expand-icon.hidden {
  display: none;
}
.card.card-expanded {
  grid-column: 1 / -1 !important;
  z-index: 10;
}
.card.card-expanded .card-expand-btn {
  opacity: 1;
}
.card {
  transition: background-color var(--transition-base), grid-column 0.3s ease;
}
@media (max-width: 640px) {
  .card-inner {
    padding: var(--space-4);
    gap: var(--space-3);
  }
  .card-inner .grid, .bgpt-group .grid {
    grid-template-columns: 1fr !important;
    gap: var(--space-3);
  }
  .card-inner *, .bgpt-group * {
    word-wrap: break-word;
    overflow-wrap: break-word;
    max-width: 100%;
  }
  [data-import-step] .grid {
    grid-template-columns: 1fr !important;
  }
  [data-crm-freshness-status] {
    flex-wrap: wrap;
    gap: var(--space-2);
  }
}
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  font-weight: 500;
  line-height: 1;
  text-decoration: none;
  white-space: nowrap;
  padding: var(--space-3) var(--space-5);
  min-height: 44px;
  border-radius: var(--radius-full);
  border: none;
  cursor: pointer;
  transition: all var(--transition-fast);
  background: var(--color-bg-secondary);
  color: var(--color-text);
}
.btn:hover {
  background: var(--color-card-hover);
}
.btn:active {
  transform: scale(0.97);
}
.btn:disabled, .btn[disabled] {
  opacity: 0.5;
  cursor: not-allowed;
  transform: none;
}
.btn-primary {
  background: var(--color-primary);
  color: white;
}
.btn-primary:hover {
  background: var(--color-primary-hover);
}
.btn-secondary {
  background: var(--color-bg-secondary);
  color: var(--color-text);
  border: 1px solid var(--color-border-strong);
}
.btn-secondary:hover {
  background: var(--color-card-hover);
  border-color: var(--color-text-muted);
}
.dark .btn-secondary {
  background: rgba(255, 255, 255, 0.08);
  border-color: rgba(255, 255, 255, 0.15);
}
.dark .btn-secondary:hover {
  background: rgba(255, 255, 255, 0.12);
  border-color: rgba(255, 255, 255, 0.25);
}
.btn-outline {
  background: transparent;
  color: var(--color-primary);
  border: 2px solid var(--color-primary);
  padding: calc(var(--space-3) - 2px) calc(var(--space-5) - 2px);
}
.btn-outline:hover {
  background: var(--color-primary);
  color: white;
}
.btn-ghost {
  background: transparent;
  color: var(--color-text-secondary);
}
.btn-ghost:hover {
  background: var(--color-bg-secondary);
  color: var(--color-text);
}
.btn-danger {
  background: var(--color-danger);
  color: white;
}
.btn-danger:hover {
  background: var(--color-danger-hover);
}
.btn-accent {
  background: var(--color-accent);
  color: white;
}
.btn-accent:hover {
  background: var(--color-accent-hover);
}
.btn-link {
  background: transparent;
  color: var(--color-primary);
  padding: 0;
  min-height: auto;
  border-radius: 0;
}
.btn-link:hover {
  background: transparent;
  text-decoration: underline;
}
.btn-sm {
  font-size: var(--text-xs);
  padding: var(--space-2) var(--space-3);
  min-height: 32px;
}
.btn-lg {
  font-size: var(--text-base);
  padding: var(--space-4) var(--space-6);
  min-height: 52px;
}
.btn-block, .btn.w-full {
  width: 100%;
}
.btn-icon {
  padding: var(--space-3);
  min-width: 44px;
  width: 44px;
}
.btn-icon.btn-sm {
  padding: var(--space-2);
  min-width: 32px;
  width: 32px;
  min-height: 32px;
}
.btn-row {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  align-items: center;
}
@media (max-width: 480px) {
  .btn-row-stack {
    flex-direction: column;
  }
  .btn-row-stack .btn {
    width: 100%;
  }
}
.btn-group {
  display: inline-flex;
}
.btn-group .btn {
  border-radius: 0;
}
.btn-group .btn:first-child {
  border-radius: var(--radius-full) 0 0 var(--radius-full);
}
.btn-group .btn:last-child {
  border-radius: 0 var(--radius-full) var(--radius-full) 0;
}
.btn-group .btn + .btn {
  margin-left: -1px;
}
.btn-loading {
  position: relative;
  color: transparent !important;
  pointer-events: none;
}
.btn-loading::after {
  content: "";
  position: absolute;
  width: 16px;
  height: 16px;
  border: 2px solid currentColor;
  border-right-color: transparent;
  border-radius: 50%;
  animation: btn-spin 0.6s linear infinite;
}
.btn-primary.btn-loading::after, .btn-danger.btn-loading::after, .btn-accent.btn-loading::after {
  border-color: white;
  border-right-color: transparent;
}
@keyframes btn-spin {
  to {
    transform: rotate(360deg);
  }
}
.input, input[type="text"], input[type="email"], input[type="password"], input[type="number"], input[type="search"], input[type="tel"], input[type="url"], input[type="date"], input[type="time"], input[type="datetime-local"], textarea {
  display: block;
  width: 100%;
  font-family: var(--font-sans);
  font-size: var(--text-base);
  line-height: 1.5;
  color: var(--color-text);
  background: var(--color-bg);
  border: 1px solid var(--color-border-strong);
  border-radius: var(--radius-lg);
  padding: var(--space-3) var(--space-4);
  min-height: 48px;
  transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
}
.input:hover, input:hover {
  border-color: var(--color-text-muted);
}
.input:focus, input:focus, textarea:focus {
  outline: none;
  border-color: var(--color-primary);
  box-shadow: 0 0 0 3px rgba(11, 60, 93, 0.15);
}
.input::-moz-placeholder, input::-moz-placeholder, textarea::-moz-placeholder {
  color: var(--color-text-muted);
}
.input::placeholder, input::placeholder, textarea::placeholder {
  color: var(--color-text-muted);
}
.input:disabled, input:disabled, textarea:disabled {
  background: var(--color-bg-secondary);
  color: var(--color-text-muted);
  cursor: not-allowed;
}
textarea {
  min-height: 120px;
  resize: vertical;
}
.select, select {
  display: block;
  width: 100%;
  font-family: var(--font-sans);
  font-size: var(--text-base);
  line-height: 1.5;
  color: var(--color-text);
  background: var(--color-bg);
  border: 1px solid var(--color-border-strong);
  border-radius: var(--radius-lg);
  padding: var(--space-3) var(--space-4);
  padding-right: var(--space-10);
  min-height: 48px;
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%2386868b' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right var(--space-3) center;
  cursor: pointer;
  transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
}
.select:hover, select:hover {
  border-color: var(--color-text-muted);
}
.select:focus, select:focus {
  outline: none;
  border-color: var(--color-primary);
  box-shadow: 0 0 0 3px rgba(11, 60, 93, 0.15);
}
.select:disabled, select:disabled {
  background: var(--color-bg-secondary);
  color: var(--color-text-muted);
  cursor: not-allowed;
}
.checkbox, input[type="checkbox"] {
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  width: 20px;
  height: 20px;
  min-width: 20px;
  border: 2px solid var(--color-border-strong);
  border-radius: var(--radius-sm);
  background: var(--color-bg);
  cursor: pointer;
  transition: all var(--transition-fast);
  position: relative;
}
.checkbox:hover, input[type="checkbox"]:hover {
  border-color: var(--color-primary);
}
.checkbox:checked, input[type="checkbox"]:checked {
  background: var(--color-primary);
  border-color: var(--color-primary);
}
.checkbox:checked::after, input[type="checkbox"]:checked::after {
  content: "";
  position: absolute;
  left: 5px;
  top: 2px;
  width: 6px;
  height: 10px;
  border: solid white;
  border-width: 0 2px 2px 0;
  transform: rotate(45deg);
}
.checkbox:focus, input[type="checkbox"]:focus {
  outline: none;
  box-shadow: 0 0 0 3px rgba(11, 60, 93, 0.15);
}
.radio, input[type="radio"] {
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  width: 20px;
  height: 20px;
  min-width: 20px;
  border: 2px solid var(--color-border-strong);
  border-radius: 50%;
  background: var(--color-bg);
  cursor: pointer;
  transition: all var(--transition-fast);
  position: relative;
}
.radio:hover, input[type="radio"]:hover {
  border-color: var(--color-primary);
}
.radio:checked, input[type="radio"]:checked {
  border-color: var(--color-primary);
}
.radio:checked::after, input[type="radio"]:checked::after {
  content: "";
  position: absolute;
  left: 4px;
  top: 4px;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--color-primary);
}
.radio:focus, input[type="radio"]:focus {
  outline: none;
  box-shadow: 0 0 0 3px rgba(11, 60, 93, 0.15);
}
.field-row {
  display: flex;
  gap: var(--space-3);
  align-items: center;
}
.field-row .input, .field-row input, .field-row .select, .field-row select {
  flex: 1;
}
.form-group {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}
.form-label {
  font-size: var(--text-sm);
  font-weight: 500;
  color: var(--color-text-secondary);
}
.form-hint {
  font-size: var(--text-xs);
  color: var(--color-text-muted);
}
.input-error, .input.is-invalid, input.is-invalid {
  border-color: var(--color-danger);
}
.input-error:focus, .input.is-invalid:focus, input.is-invalid:focus {
  box-shadow: 0 0 0 3px rgba(217, 45, 32, 0.15);
}
.form-error {
  font-size: var(--text-xs);
  color: var(--color-danger);
  margin-top: var(--space-1);
}
.input-success, .input.is-valid, input.is-valid {
  border-color: var(--color-success);
}
.input-wrapper {
  position: relative;
}
.input-wrapper .input, .input-wrapper input {
  padding-left: var(--space-10);
}
.input-wrapper .input-icon {
  position: absolute;
  left: var(--space-3);
  top: 50%;
  transform: translateY(-50%);
  color: var(--color-text-muted);
  pointer-events: none;
}
.dark .input, .dark input, .dark textarea, .dark .select, .dark select, .dark input[type="date"], .dark input[type="time"], .dark input[type="datetime-local"] {
  background: var(--color-bg-secondary);
}
.dark .select, .dark select {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%23a1a1aa' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-size: 16px 16px;
}
@supports (-webkit-touch-callout: none) {
  .select, select {
    -webkit-appearance: none !important;
    background-color: var(--color-bg) !important;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%2386868b' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E") !important;
    background-position: calc(100% - 12px) 50% !important;
    background-size: 16px 16px !important;
    background-repeat: no-repeat !important;
  }
  .dark .select, .dark select {
    background-color: var(--color-bg-secondary) !important;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%23a1a1aa' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E") !important;
  }
}
.file-input-wrapper {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  width: 100%;
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  color: var(--color-text);
  background: var(--color-bg);
  border: 1px solid var(--color-border-strong);
  border-radius: var(--radius-lg);
  padding: var(--space-2) var(--space-3);
  min-height: 44px;
  cursor: pointer;
  transition: border-color var(--transition-fast), box-shadow var(--transition-fast), opacity var(--transition-fast);
}
.file-input-wrapper:hover:not(.disabled) {
  border-color: var(--color-text-muted);
}
.file-input-wrapper:focus-within:not(.disabled) {
  border-color: var(--color-primary);
  box-shadow: 0 0 0 3px rgba(11, 60, 93, 0.15);
}
.file-input-wrapper.disabled {
  background: var(--color-bg-secondary);
  color: var(--color-text-muted);
  cursor: not-allowed;
  opacity: 0.5;
}
.file-input-hidden {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}
.file-input-label {
  flex-shrink: 0;
  padding: var(--space-1) var(--space-3);
  background: var(--color-primary);
  color: white;
  border-radius: var(--radius-md);
  font-size: var(--text-xs);
  font-weight: 500;
  transition: background var(--transition-fast);
}
.file-input-wrapper:hover:not(.disabled) .file-input-label {
  background: var(--color-primary-dark, #084069);
}
.file-input-selected {
  flex: 1;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  color: var(--color-text-secondary);
  font-size: var(--text-xs);
}
.file-input-selected:empty::before {
  content: "Keine Datei ausgewählt";
  color: var(--color-text-muted);
}
.file-input-selected.has-files {
  color: var(--color-success);
  font-weight: 500;
}
.dark .file-input-wrapper {
  background: var(--color-bg-secondary);
}
.dark .file-input-wrapper.disabled {
  background: var(--color-bg);
}
.toggle-switch {
  position: relative;
  display: inline-flex;
  align-items: center;
  width: 60px;
  height: 24px;
  flex-shrink: 0;
  cursor: pointer;
}
.toggle-switch input[type="checkbox"] {
  -moz-appearance: none;
       appearance: none;
  -webkit-appearance: none;
  width: 60px;
  height: 24px;
  min-width: 60px;
  background: var(--color-border-strong);
  border: none;
  border-radius: 12px;
  cursor: pointer;
  transition: background var(--transition-fast);
  position: absolute;
  left: 0;
  top: 0;
  margin: 0;
  padding: 0;
}
.toggle-switch-slider {
  display: block;
  position: absolute;
  left: 2px;
  top: 2px;
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background: white;
  box-shadow: 0 1px 3px rgba(0,0,0,0.2);
  transition: transform var(--transition-fast);
  transform: none;
  pointer-events: none;
  z-index: 1;
}
.toggle-switch input[type="checkbox"]:checked {
  background: var(--color-primary);
}
.toggle-switch input[type="checkbox"]:checked + .toggle-switch-slider {
  transform: translateX(36px);
}
.toggle-switch input[type="checkbox"]:focus {
  outline: none;
  box-shadow: 0 0 0 3px rgba(11, 60, 93, 0.15);
}
.dark .toggle-switch input[type="checkbox"] {
  background: rgba(255, 255, 255, 0.15);
}
.dark .toggle-switch input[type="checkbox"]:checked {
  background: var(--color-primary);
}
.card .toggle-switch input[type="checkbox"], .einstellungen .toggle-switch input[type="checkbox"], .einstellungen-content .toggle-switch input[type="checkbox"] {
  width: 60px;
  height: 24px;
  min-width: 60px;
  min-height: unset;
  background: var(--color-border-strong);
  border: none;
  border-radius: 12px;
  position: absolute;
  left: 0;
  top: 0;
  margin: 0;
  padding: 0;
  display: block;
  align-items: unset;
  justify-content: unset;
}
.card .toggle-switch input[type="checkbox"]:checked, .einstellungen .toggle-switch input[type="checkbox"]:checked, .einstellungen-content .toggle-switch input[type="checkbox"]:checked {
  background: var(--color-primary);
  border-color: var(--color-primary);
}
.card .toggle-switch input[type="checkbox"]:checked::after, .einstellungen .toggle-switch input[type="checkbox"]:checked::after, .einstellungen-content .toggle-switch input[type="checkbox"]:checked::after {
  content: none;
}
.card .toggle-switch input[type="checkbox"]:focus, .einstellungen .toggle-switch input[type="checkbox"]:focus, .einstellungen-content .toggle-switch input[type="checkbox"]:focus {
  box-shadow: 0 0 0 3px rgba(11, 60, 93, 0.15);
}
.dark .card .toggle-switch input[type="checkbox"], .dark .einstellungen .toggle-switch input[type="checkbox"], .dark .einstellungen-content .toggle-switch input[type="checkbox"] {
  background: rgba(255, 255, 255, 0.15);
}
.dark .card .toggle-switch input[type="checkbox"]:checked, .dark .einstellungen .toggle-switch input[type="checkbox"]:checked, .dark .einstellungen-content .toggle-switch input[type="checkbox"]:checked {
  background: var(--color-primary);
}
.pill {
  display: inline-flex;
  align-items: center;
  gap: var(--space-1);
  font-size: var(--text-xs);
  font-weight: 500;
  line-height: 1;
  white-space: nowrap;
  padding: var(--space-1) var(--space-2);
  border-radius: var(--radius-full);
  background: var(--color-bg-secondary);
  color: var(--color-text-secondary);
}
.pill-primary {
  background: var(--color-primary);
  color: white;
}
.pill-success {
  background: var(--color-success-bg);
  color: var(--color-success);
}
.pill-warning, .pill-warn {
  background: var(--color-warning-bg);
  color: var(--color-warning);
}
.pill-danger, .pill-error {
  background: var(--color-danger-bg);
  color: var(--color-danger);
}
.pill-accent {
  background: rgba(198, 161, 91, 0.15);
  color: var(--color-accent);
}
.pill-outline {
  background: transparent;
  border: 2px solid var(--color-primary);
  color: var(--color-primary);
}
.pill-dot::before {
  content: "";
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: currentColor;
}
.badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: var(--text-xs);
  font-weight: 600;
  line-height: 1;
  min-width: 20px;
  height: 20px;
  padding: 0 var(--space-2);
  border-radius: var(--radius-full);
  background: var(--color-danger);
  color: white;
}
.badge-sm {
  min-width: 16px;
  height: 16px;
  font-size: 10px;
  padding: 0 4px;
}
.badge-primary {
  background: var(--color-primary);
}
.badge-accent {
  background: var(--color-accent);
}
.badge-muted {
  background: var(--color-text-muted);
}
.status-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--color-text-muted);
}
.status-dot-success {
  background: var(--color-success);
}
.status-dot-warning {
  background: var(--color-warning);
}
.status-dot-danger {
  background: var(--color-danger);
}
.status-dot-primary {
  background: var(--color-primary);
}
.status-dot-pulse {
  animation: status-pulse 2s ease-in-out infinite;
}
@keyframes status-pulse {
  0%, 100% {
    opacity: 1;
  }
  50% {
    opacity: 0.5;
  }
}
.tag {
  display: inline-flex;
  align-items: center;
  gap: var(--space-1);
  font-size: var(--text-xs);
  font-weight: 500;
  padding: var(--space-1) var(--space-2);
  border-radius: var(--radius-sm);
  background: var(--color-bg-secondary);
  color: var(--color-text-secondary);
}
.tag-remove {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 14px;
  height: 14px;
  border-radius: 50%;
  background: transparent;
  border: none;
  cursor: pointer;
  color: inherit;
  opacity: 0.6;
  transition: opacity var(--transition-fast);
}
.tag-remove:hover {
  opacity: 1;
}
.tag-remove::before {
  content: "×";
  font-size: 12px;
  line-height: 1;
}
.table-container {
  max-width: 100%;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  border-radius: var(--radius-lg);
  border: 1px solid var(--color-border);
  background: var(--color-bg);
}
table {
  width: 100%;
  border-collapse: collapse;
  font-size: var(--text-sm);
}
thead {
  background: var(--color-bg-secondary);
}
th {
  padding: var(--space-3) var(--space-4);
  text-align: left;
  font-weight: 600;
  color: var(--color-text);
  border-bottom: 1px solid var(--color-border);
  white-space: nowrap;
}
td {
  padding: var(--space-3) var(--space-4);
  border-bottom: 1px solid var(--color-border);
  color: var(--color-text-secondary);
}
tbody tr:last-child td {
  border-bottom: none;
}
th:nth-child(even), td:nth-child(even) {
  background: rgba(0, 0, 0, 0.02);
}
.dark th:nth-child(even), .dark td:nth-child(even) {
  background: rgba(255, 255, 255, 0.02);
}
tbody tr {
  transition: background-color var(--transition-fast);
}
tbody tr:hover {
  background: var(--color-bg-secondary);
}
tbody tr:hover td:nth-child(even) {
  background: rgba(0, 0, 0, 0.04);
}
.dark tbody tr:hover td:nth-child(even) {
  background: rgba(255, 255, 255, 0.04);
}
tbody tr.clickable {
  cursor: pointer;
}
.table-compact th, .table-compact td {
  padding: var(--space-2) var(--space-3);
}
.table-fixed {
  table-layout: fixed;
}
th.sortable {
  cursor: pointer;
  -webkit-user-select: none;
     -moz-user-select: none;
          user-select: none;
}
th.sortable:hover {
  background: var(--color-card-hover);
}
th.sortable::after {
  content: "";
  display: inline-block;
  width: 0;
  height: 0;
  margin-left: var(--space-2);
  vertical-align: middle;
  border-left: 4px solid transparent;
  border-right: 4px solid transparent;
  border-top: 4px solid var(--color-text-muted);
  opacity: 0.3;
}
th.sortable.asc::after {
  border-top: none;
  border-bottom: 4px solid var(--color-primary);
  opacity: 1;
}
th.sortable.desc::after {
  border-top: 4px solid var(--color-primary);
  opacity: 1;
}
.table-empty {
  text-align: center;
  padding: var(--space-8) var(--space-4);
  color: var(--color-text-muted);
}
.table-actions {
  display: flex;
  gap: var(--space-2);
  justify-content: flex-end;
}
@media (max-width: 640px) {
  .table-responsive thead {
    display: none;
  }
  .table-responsive tbody tr {
    display: block;
    margin-bottom: var(--space-4);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    overflow: hidden;
  }
  .table-responsive td {
    display: flex;
    justify-content: space-between;
    align-items: center;
    border-bottom: 1px solid var(--color-border);
  }
  .table-responsive td::before {
    content: attr(data-label);
    font-weight: 600;
    color: var(--color-text);
  }
  .table-responsive td:last-child {
    border-bottom: none;
  }
  .table-responsive td:nth-child(even) {
    background: transparent;
  }
}
#fab-root {
  position: relative;
  z-index: var(--z-dropdown);
}
#fab-root.hidden {
  display: none;
}
#fab-root .fab-btn {
  width: 44px;
  height: 44px;
  border-radius: var(--radius-full);
  border: none;
  background: var(--color-primary);
  color: white;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  box-shadow: var(--shadow-lg);
  transition: all var(--transition-fast);
}
#fab-root .fab-btn:hover {
  background: var(--color-primary-hover);
  transform: scale(1.05);
}
#fab-root .fab-btn:active {
  transform: scale(0.95);
}
#fab-root .fab-btn::before {
  content: "+";
  font-size: 24px;
  font-weight: 300;
  line-height: 1;
}
#fab-root .fab-btn[aria-expanded="true"] {
  background: var(--color-primary-hover);
}
#fab-root .fab-btn[aria-expanded="true"]::before {
  content: "×";
}
#fab-root .fab-list {
  position: absolute;
  top: calc(100% + var(--space-2));
  right: 0;
  min-width: 200px;
  background: var(--color-bg);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-xl);
  padding: var(--space-2);
  opacity: 1;
  transform: translateY(0);
  transition: opacity var(--transition-fast), transform var(--transition-fast);
}
#fab-root .fab-list[hidden] {
  display: block;
  opacity: 0;
  transform: translateY(-8px);
  pointer-events: none;
}
#fab-root .fab-item {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-3) var(--space-4);
  border-radius: var(--radius-lg);
  font-size: var(--text-sm);
  font-weight: 500;
  text-decoration: none;
  color: var(--color-text);
  transition: background-color var(--transition-fast);
}
#fab-root .fab-item:hover {
  background: var(--color-bg-secondary);
}
#fab-root .fab-item:active {
  background: var(--color-card-hover);
}
#fab-root .fab-item-icon {
  width: 20px;
  height: 20px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--color-text-muted);
}
#fab-root .fab-divider {
  height: 1px;
  background: var(--color-border);
  margin: var(--space-2) var(--space-3);
}
#fab-root .fab-item-danger {
  color: var(--color-danger);
}
#fab-root .fab-item-danger:hover {
  background: var(--color-danger-bg);
}
.dark #fab-root .fab-list {
  background: var(--color-card);
}
.user-menu {
  position: relative;
  z-index: var(--z-dropdown);
}
.user-menu-trigger {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-2) var(--space-3);
  background: transparent;
  border: none;
  border-radius: var(--radius-full);
  cursor: pointer;
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  font-weight: 500;
  color: var(--color-text);
  transition: background-color var(--transition-fast);
}
.user-menu-trigger:hover {
  background: var(--color-bg-secondary);
}
.user-menu-avatar {
  width: 32px;
  height: 32px;
  border-radius: var(--radius-full);
  background: var(--color-primary);
  color: white;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: var(--text-sm);
  font-weight: 600;
}
.user-menu-name {
  max-width: 120px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
@media (max-width: 640px) {
  .user-menu-name {
    display: none;
  }
}
.user-menu-chevron {
  width: 16px;
  height: 16px;
  color: var(--color-text-muted);
  transition: transform var(--transition-fast);
}
.user-menu[data-open="true"] .user-menu-chevron {
  transform: rotate(180deg);
}
.user-menu-dropdown {
  position: absolute;
  top: calc(100% + var(--space-2));
  right: 0;
  min-width: 220px;
  background: var(--color-bg);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-xl);
  padding: var(--space-2);
  opacity: 1;
  transform: translateY(0);
  transition: opacity var(--transition-fast), transform var(--transition-fast);
}
.user-menu-dropdown[hidden] {
  display: block;
  opacity: 0;
  transform: translateY(-8px);
  pointer-events: none;
}
.user-menu-header {
  padding: var(--space-3) var(--space-4);
  border-bottom: 1px solid var(--color-border);
  margin-bottom: var(--space-2);
}
.user-menu-header-name {
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--color-text);
}
.user-menu-header-email {
  font-size: var(--text-xs);
  color: var(--color-text-muted);
  margin-top: 2px;
}
.user-menu-header-role {
  display: inline-block;
  font-size: 10px;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  color: var(--color-primary);
  background: rgba(11, 60, 93, 0.1);
  padding: 2px 6px;
  border-radius: var(--radius-sm);
  margin-top: var(--space-2);
}
.user-menu-item {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-3) var(--space-4);
  border-radius: var(--radius-lg);
  font-size: var(--text-sm);
  font-weight: 500;
  text-decoration: none;
  color: var(--color-text);
  transition: background-color var(--transition-fast);
}
.user-menu-item:hover {
  background: var(--color-bg-secondary);
}
.user-menu-item:active {
  background: var(--color-card-hover);
}
.user-menu-item-icon {
  width: 20px;
  height: 20px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--color-text-muted);
}
.user-menu-item.active {
  background: var(--color-bg-secondary);
  color: var(--color-primary);
}
.user-menu-item.active .user-menu-item-icon {
  color: var(--color-primary);
}
.user-menu-divider {
  height: 1px;
  background: var(--color-border);
  margin: var(--space-2) var(--space-3);
}
.user-menu-item-logout {
  color: var(--color-danger);
}
.user-menu-item-logout:hover {
  background: var(--color-danger-bg);
}
.user-menu-item-logout .user-menu-item-icon {
  color: var(--color-danger);
}
.user-menu-section-label {
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.8px;
  color: var(--color-text-muted);
  padding: var(--space-2) var(--space-4) var(--space-1);
}
.dark .user-menu-dropdown {
  background: var(--color-card);
}
.dark .user-menu-header-role {
  background: rgba(11, 60, 93, 0.2);
}
[x-cloak] {
  display: none !important;
}
.top-nav {
  position: sticky;
  top: 0;
  z-index: var(--z-sticky);
  background: var(--color-bg);
  border-bottom: 1px solid var(--color-border);
  min-height: 56px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-2);
  padding: 0 var(--space-4);
  padding-top: env(safe-area-inset-top);
}
@media (min-width: 768px) {
  .top-nav {
    padding: 0 var(--space-6);
    min-height: 60px;
  }
}
.top-nav-left {
  display: flex;
  align-items: center;
  gap: var(--space-1);
}
.top-nav-brand {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  text-decoration: none;
  color: var(--color-text);
  font-weight: 700;
  font-size: var(--text-lg);
  padding: var(--space-2) var(--space-3);
  border-radius: var(--radius-lg);
  transition: background-color var(--transition-fast);
  white-space: nowrap;
  margin-right: var(--space-2);
}
.top-nav-brand:hover {
  background: var(--color-bg-secondary);
  color: var(--color-text);
}
.top-nav-brand-icon {
  width: 28px;
  height: 28px;
  flex-shrink: 0;
  border-radius: 6px;
  -o-object-fit: contain;
     object-fit: contain;
}
.top-nav-brand-logo {
  height: 32px;
  width: auto;
  max-width: 120px;
  -o-object-fit: contain;
     object-fit: contain;
  flex-shrink: 0;
}
.top-nav-brand-text {
  color: var(--color-primary);
}
@media (max-width: 767px) {
  .top-nav-brand-text {
    display: none;
  }
}
.top-nav-links {
  display: none;
  align-items: center;
  gap: var(--space-1);
  list-style: none;
  margin: 0;
  padding: 0;
}
@media (min-width: 768px) {
  .top-nav-links {
    display: flex;
  }
}
.top-nav-link {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-2) var(--space-3);
  border-radius: var(--radius-lg);
  font-size: var(--text-sm);
  font-weight: 500;
  text-decoration: none;
  color: var(--color-text-secondary);
  white-space: nowrap;
  transition: background-color var(--transition-fast), color var(--transition-fast);
}
.top-nav-link:hover {
  background: var(--color-bg-secondary);
  color: var(--color-text);
}
.top-nav-link.active {
  background: var(--color-bg-secondary);
  color: var(--color-primary);
  font-weight: 600;
}
.top-nav-link-icon {
  width: 18px;
  height: 18px;
  flex-shrink: 0;
}
.top-nav-mehr {
  position: relative;
  display: none;
}
@media (max-width: 768px) {
  .top-nav-mehr {
    display: list-item;
  }
}
.top-nav-mehr > button {
  font-family: var(--font-sans);
}
.top-nav-mehr-dropdown {
  position: absolute;
  top: calc(100% + var(--space-1));
  left: 0;
  min-width: 180px;
  background: var(--color-bg);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-lg);
  padding: var(--space-1) 0;
  z-index: var(--z-dropdown);
}
.top-nav-mehr-item {
  display: block;
  padding: var(--space-2) var(--space-4);
  font-size: var(--text-sm);
  font-weight: 500;
  color: var(--color-text-secondary);
  text-decoration: none;
  transition: background-color var(--transition-fast), color var(--transition-fast);
}
.top-nav-mehr-item:hover {
  background: var(--color-bg-secondary);
  color: var(--color-text);
}
.top-nav-mehr-divider {
  height: 1px;
  background: var(--color-border);
  margin: var(--space-1) 0;
}
.ki-panel-trigger {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-2) var(--space-3);
  border: none;
  background: var(--color-accent);
  border-radius: var(--radius-full);
  color: #000;
  font-size: var(--text-sm);
  font-weight: 600;
  cursor: pointer;
  transition: opacity var(--transition-fast), transform var(--transition-fast);
  -webkit-tap-highlight-color: transparent;
  white-space: nowrap;
  flex-shrink: 0;
}
.ki-panel-trigger:hover {
  opacity: 0.88;
}
.ki-panel-trigger:active {
  transform: scale(0.97);
}
.ki-panel-trigger .ki-panel-trigger-text {
  display: none;
}
@media (min-width: 768px) {
  .ki-panel-trigger .ki-panel-trigger-text {
    display: inline;
  }
}
.top-nav-right {
  display: flex;
  align-items: center;
  gap: var(--space-2);
}
.top-nav-search {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-2) var(--space-3);
  background: var(--color-bg-secondary);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-full);
  cursor: pointer;
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
}
.top-nav-search:hover {
  border-color: var(--color-border-strong);
}
.top-nav-search:focus-visible {
  border-color: var(--color-primary);
  box-shadow: 0 0 0 3px rgba(11, 60, 93, 0.15);
  outline: none;
}
.top-nav-search-icon {
  width: 16px;
  height: 16px;
  flex-shrink: 0;
  color: var(--color-text-muted);
}
.top-nav-search-text {
  display: none;
}
@media (min-width: 768px) {
  .top-nav-search {
    min-width: 200px;
  }
  .top-nav-search-text {
    display: inline;
  }
}
@media (min-width: 1024px) {
  .top-nav-search {
    min-width: 260px;
  }
}
.top-nav-search-kbd {
  display: none;
  font-family: var(--font-sans);
  font-size: 11px;
  color: var(--color-text-muted);
  background: var(--color-bg);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
  padding: 1px 5px;
  margin-left: auto;
}
@media (min-width: 768px) {
  .top-nav-search-kbd {
    display: inline;
  }
}
.bottom-nav {
  display: flex;
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: var(--z-sticky);
  background: var(--color-bg);
  border-top: 1px solid var(--color-border);
  padding-bottom: env(safe-area-inset-bottom);
}
@media (min-width: 768px) {
  .bottom-nav {
    display: none;
  }
}
.bottom-nav-item {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 2px;
  padding: 8px 0 4px;
  font-size: 10px;
  font-weight: 500;
  text-decoration: none;
  color: var(--color-text-muted);
  transition: color var(--transition-fast);
  -webkit-tap-highlight-color: transparent;
}
.bottom-nav-item svg {
  width: 22px;
  height: 22px;
  flex-shrink: 0;
}
.bottom-nav-item.active {
  color: var(--color-primary);
}
.bottom-nav-item:active {
  opacity: 0.7;
}
.dark .top-nav-search {
  background: var(--color-bg-secondary);
}
.dark .top-nav-search-kbd {
  background: var(--color-bg-secondary);
}
.top-nav-main {
  flex: 1;
  padding: var(--space-4);
  padding-bottom: calc(72px + env(safe-area-inset-bottom));
  width: 100%;
  max-width: 100%;
  margin: 0 auto;
}
@media (min-width: 768px) {
  .top-nav-main {
    padding: var(--space-6);
    padding-bottom: var(--space-6);
  }
}
@media (min-width: 1024px) {
  .top-nav-main {
    padding: var(--space-8);
  }
}
.tool-page-header {
  padding: var(--space-4) var(--space-4) 0;
}
@media (min-width: 768px) {
  .tool-page-header {
    padding: var(--space-6) var(--space-6) 0;
  }
}
@media (min-width: 1024px) {
  .tool-page-header {
    padding: var(--space-8) var(--space-8) 0;
  }
}
.tool-page-title {
  font-size: var(--text-xl);
  font-weight: 600;
  color: var(--color-text);
  margin: 0;
}
.tool-page-subtitle {
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  margin: var(--space-1) 0 0 0;
}
@media (max-width: 767px) {
  main {
    padding-bottom: calc(72px + env(safe-area-inset-bottom)) !important;
  }
}
.modal-backdrop {
  position: fixed;
  inset: 0;
  z-index: var(--z-modal);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--space-4);
  background: rgba(0, 0, 0, 0.5);
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
  opacity: 1;
  transition: opacity var(--transition-base);
}
.modal-backdrop[hidden], .modal-backdrop.hidden {
  display: none;
  opacity: 0;
  pointer-events: none;
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
}
.modal-panel {
  width: 100%;
  max-width: 480px;
  max-height: calc(100vh - var(--space-8));
  max-height: calc(100dvh - var(--space-8));
  background: var(--color-bg);
  border-radius: var(--radius-2xl);
  box-shadow: var(--shadow-xl);
  display: flex;
  flex-direction: column;
  overflow: hidden;
  transform: scale(1) translateY(0);
  transition: transform var(--transition-base);
}
.modal-backdrop[hidden] .modal-panel, .modal-backdrop.hidden .modal-panel {
  transform: scale(0.95) translateY(8px);
}
.modal-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: var(--space-4);
  padding: var(--space-5);
  border-bottom: 1px solid var(--color-border);
}
.modal-title {
  font-size: var(--text-lg);
  font-weight: 600;
  color: var(--color-text);
  margin: 0;
}
.modal-subtitle {
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  margin-top: var(--space-1);
}
.modal-close {
  flex-shrink: 0;
  width: 36px;
  height: 36px;
  border-radius: var(--radius-full);
  border: none;
  background: var(--color-primary);
  color: white;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all var(--transition-fast);
}
.modal-close:hover {
  background: var(--color-primary-hover);
  color: white;
  transform: scale(1.05);
}
.modal-close:empty::before {
  content: "";
  width: 18px;
  height: 18px;
  background: currentColor;
  mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke='currentColor' stroke-width='2.5'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' d='M6 18L18 6M6 6l12 12'/%3E%3C/svg%3E");
  mask-size: contain;
  mask-repeat: no-repeat;
  mask-position: center;
  -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke='currentColor' stroke-width='2.5'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' d='M6 18L18 6M6 6l12 12'/%3E%3C/svg%3E");
  -webkit-mask-size: contain;
  -webkit-mask-repeat: no-repeat;
  -webkit-mask-position: center;
}
.modal-body {
  flex: 1;
  padding: var(--space-5);
  overflow-y: auto;
}
.modal-footer {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: var(--space-3);
  padding: var(--space-4) var(--space-5);
  border-top: 1px solid var(--color-border);
}
.modal-sm .modal-panel {
  max-width: 360px;
}
.modal-lg .modal-panel {
  max-width: 640px;
}
.modal-xl .modal-panel {
  max-width: 800px;
}
.modal-full .modal-panel {
  max-width: calc(100vw - var(--space-8));
  max-height: calc(100vh - var(--space-8));
  max-height: calc(100dvh - var(--space-8));
}
.dark .modal-panel {
  background: var(--color-card);
}
.dark .modal-backdrop {
  background: rgba(0, 0, 0, 0.7);
}
@media (max-width: 640px) {
  .modal-backdrop {
    padding: var(--space-4);
    align-items: center;
    justify-content: center;
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
  }
  .modal-panel {
    max-width: 100%;
    max-height: calc(100vh - var(--space-8));
    max-height: calc(100dvh - var(--space-8));
    border-radius: var(--radius-2xl);
    margin: auto;
  }
  .modal-header {
    padding: var(--space-4);
  }
  .modal-body {
    padding: var(--space-4);
  }
  .modal-footer {
    padding: var(--space-3) var(--space-4);
  }
  .modal-body .grid {
    grid-template-columns: 1fr !important;
  }
  .modal-body * {
    word-wrap: break-word;
    overflow-wrap: break-word;
  }
  .modal-body input, .modal-body select, .modal-body textarea {
    max-width: 100%;
    box-sizing: border-box;
  }
  .modal-body .einstellungen-form-grid {
    grid-template-columns: 1fr !important;
  }
  .modal-body .bgpt-group, .modal-body [class*="card"] {
    width: 100%;
  }
}
.modal-wide .modal-panel {
  max-width: 90vw;
  width: 90vw;
}
@media (max-width: 640px) {
  .modal-wide .modal-panel {
    max-width: 100%;
    width: 100%;
  }
}
.toast-container {
  position: fixed;
  bottom: var(--space-6);
  left: 50%;
  transform: translateX(-50%);
  z-index: var(--z-toast);
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  align-items: center;
  padding-bottom: env(safe-area-inset-bottom);
  pointer-events: none;
}
.toast {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-3) var(--space-4);
  min-width: 200px;
  max-width: 400px;
  background: var(--color-text);
  color: var(--color-bg);
  border-radius: var(--radius-full);
  box-shadow: var(--shadow-lg);
  font-size: var(--text-sm);
  font-weight: 500;
  pointer-events: auto;
  animation: toast-in 0.3s ease forwards;
}
.toast.toast-out {
  animation: toast-out 0.2s ease forwards;
}
@keyframes toast-in {
  from {
    opacity: 0;
    transform: translateY(16px) scale(0.95);
  }
  to {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}
@keyframes toast-out {
  from {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
  to {
    opacity: 0;
    transform: translateY(-8px) scale(0.95);
  }
}
.toast-success {
  background: var(--color-success);
  color: white;
}
.toast-warning {
  background: var(--color-warning);
  color: white;
}
.toast-danger, .toast-error {
  background: var(--color-danger);
  color: white;
}
.toast-info {
  background: var(--color-primary);
  color: white;
}
.toast-icon {
  flex-shrink: 0;
  width: 20px;
  height: 20px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.toast-close {
  flex-shrink: 0;
  width: 20px;
  height: 20px;
  border-radius: var(--radius-full);
  border: none;
  background: rgba(255, 255, 255, 0.2);
  color: inherit;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 14px;
  line-height: 1;
  opacity: 0.7;
  transition: opacity var(--transition-fast);
}
.toast-close:hover {
  opacity: 1;
}
.toast-close::before {
  content: "×";
}
.dark .toast {
  background: var(--color-bg);
  color: var(--color-text);
  border: 1px solid var(--color-border);
}
body.login-page {
  min-height: 100vh;
  min-height: 100dvh;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--space-4);
  background: var(--color-bg);
}
.login-container {
  width: 100%;
  min-height: 100vh;
  min-height: 100dvh;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--space-4);
  padding-top: max(var(--space-4), env(safe-area-inset-top));
  padding-bottom: max(var(--space-4), env(safe-area-inset-bottom));
}
.login-wrapper {
  width: 100%;
  max-width: 400px;
}
.login-logo {
  display: flex;
  justify-content: center;
  margin-bottom: var(--space-8);
}
.login-logo img {
  width: 100%;
  max-width: 280px;
  height: auto;
  -o-object-fit: contain;
     object-fit: contain;
}
.login-logo-light {
  display: block;
}
.login-logo-dark {
  display: none;
}
.dark .login-logo-light {
  display: none;
}
.dark .login-logo-dark {
  display: block;
}
.login-card {
  background: var(--color-card);
  border-radius: var(--radius-2xl);
  padding: var(--space-6);
  box-shadow: var(--shadow-lg);
}
.dark .login-card {
  background: var(--color-card);
  border: 1px solid var(--color-border);
}
.login-card form {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}
.login-card .form-group {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}
.login-card .form-label {
  font-size: var(--text-sm);
  font-weight: 500;
  color: var(--color-text-secondary);
}
.login-card .input, .login-card input[type="email"], .login-card input[type="password"], .login-card input[type="text"] {
  height: 48px;
  font-size: var(--text-base);
}
.login-remember {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-3);
  flex-wrap: wrap;
}
.login-remember label {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--text-sm);
  color: var(--color-text-secondary);
  cursor: pointer;
}
.login-remember a {
  font-size: var(--text-sm);
  color: var(--color-primary);
}
.login-remember a:hover {
  text-decoration: underline;
}
.login-card .btn-primary {
  height: 48px;
  font-size: var(--text-base);
  margin-top: var(--space-2);
}
.login-alert {
  padding: var(--space-3) var(--space-4);
  border-radius: var(--radius-lg);
  font-size: var(--text-sm);
  margin-bottom: var(--space-4);
}
.login-alert-success {
  background: var(--color-success-bg);
  color: var(--color-success);
  border: 1px solid rgba(52, 199, 89, 0.2);
}
.login-alert-error {
  background: var(--color-danger-bg);
  color: var(--color-danger);
  border: 1px solid rgba(217, 45, 32, 0.2);
}
.login-alert-error ul {
  margin: var(--space-2) 0 0 var(--space-4);
  padding: 0;
}
.login-alert-error li {
  margin-bottom: var(--space-1);
}
@media (max-width: 480px) {
  .login-card {
    padding: var(--space-5);
  }
  .login-logo {
    margin-bottom: var(--space-6);
  }
  .login-logo img {
    max-width: 220px;
  }
}
.einstellungen-header {
  margin-bottom: var(--space-6);
}
.einstellungen-header h1 {
  font-size: var(--text-2xl);
  font-weight: 600;
}
.einstellungen-layout {
  display: flex;
  gap: var(--space-6);
  align-items: flex-start;
}
.einstellungen-sidebar {
  width: 200px;
  flex-shrink: 0;
  position: sticky;
  top: 80px;
}
.einstellungen-sidebar-group {
  margin-bottom: var(--space-4);
}
.einstellungen-sidebar-label {
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.8px;
  color: var(--color-text-muted);
  padding: 0 var(--space-3);
  margin-bottom: var(--space-1);
}
.einstellungen-sidebar-item {
  display: block;
  padding: var(--space-2) var(--space-3);
  border-radius: var(--radius-md);
  color: var(--color-text-secondary);
  text-decoration: none;
  font-size: var(--text-sm);
  font-weight: 500;
  transition: background-color var(--transition-fast), color var(--transition-fast);
}
.einstellungen-sidebar-item:hover {
  background: var(--color-bg-secondary);
  color: var(--color-text);
}
.einstellungen-sidebar-item.active {
  background: var(--color-primary);
  color: #fff;
}
.einstellungen-content {
  flex: 1;
  min-width: 0;
}
.einstellungen-content .card {
  margin-bottom: 0;
}
.einstellungen-form-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-4);
}
@media (min-width: 768px) {
  .einstellungen-form-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}
.einstellungen-field {
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
}
.einstellungen-label {
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--color-text);
}
.einstellungen-hint {
  font-size: var(--text-xs, 0.75rem);
  color: var(--color-text-muted, #6b7280);
  font-weight: 400;
}
.dark .einstellungen-hint {
  color: var(--color-text-muted, #9ca3af);
}
.einstellungen-logo-section {
  display: flex;
  align-items: center;
  gap: var(--space-4);
  padding: var(--space-4) 0;
}
.einstellungen-logo-preview {
  width: 80px;
  height: 80px;
  border-radius: var(--radius-lg);
  border: 1px solid var(--color-border);
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--color-bg-secondary);
  flex-shrink: 0;
}
.einstellungen-logo-img {
  width: 100%;
  height: 100%;
  -o-object-fit: contain;
     object-fit: contain;
}
.einstellungen-logo-placeholder {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-1);
  color: var(--color-text-muted);
  font-size: 10px;
}
.einstellungen-theme-buttons {
  display: flex;
  gap: var(--space-2);
}
@media (max-width: 767px) {
  .einstellungen-layout {
    flex-direction: column;
  }
  .einstellungen-sidebar {
    width: 100%;
    position: static;
    display: flex;
    gap: var(--space-2);
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    padding-bottom: var(--space-2);
    border-bottom: 1px solid var(--color-border);
    margin-bottom: var(--space-4);
  }
  .einstellungen-sidebar-group {
    display: flex;
    gap: var(--space-1);
    margin-bottom: 0;
  }
  .einstellungen-sidebar-label {
    display: none;
  }
  .einstellungen-sidebar-item {
    white-space: nowrap;
    padding: var(--space-2) var(--space-3);
    font-size: 12px;
  }
}
.einstellungen-section {
  padding: var(--space-4) 0;
  border-bottom: 1px solid var(--color-border);
}
.einstellungen-section:last-of-type {
  border-bottom: none;
}
.einstellungen-section-title {
  font-size: var(--text-base);
  font-weight: 600;
  color: var(--color-text);
  margin-bottom: var(--space-3);
}
.einstellungen-subsection-title {
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--color-text);
  margin: var(--space-4) 0 var(--space-2) 0;
}
.accordion-section {
  border-bottom: 1px solid var(--color-border);
}
.accordion-section:last-child {
  border-bottom: none;
}
.accordion-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--space-4) 0;
  cursor: pointer;
  -webkit-user-select: none;
     -moz-user-select: none;
          user-select: none;
  transition: opacity var(--transition-fast);
}
.accordion-header:hover {
  opacity: 0.8;
}
.accordion-header-left {
  display: flex;
  align-items: center;
  gap: var(--space-3);
}
.accordion-icon {
  width: 36px !important;
  height: 36px !important;
  min-width: 36px;
  min-height: 36px;
  max-width: 36px;
  max-height: 36px;
  border-radius: var(--radius-md);
  background: var(--color-bg-secondary);
  display: flex !important;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  overflow: hidden;
}
.accordion-icon svg {
  width: 18px !important;
  height: 18px !important;
  min-width: 18px;
  min-height: 18px;
  max-width: 18px;
  max-height: 18px;
  flex-shrink: 0;
  color: var(--color-primary);
}
.accordion-title {
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--color-text);
  line-height: 1.3;
}
.accordion-subtitle {
  font-size: var(--text-xs);
  color: var(--color-text-muted);
  margin-top: 1px;
}
.accordion-chevron {
  width: 18px !important;
  height: 18px !important;
  flex-shrink: 0;
  color: var(--color-text-muted);
  transition: transform var(--transition-base);
}
.accordion-chevron.open {
  transform: rotate(180deg);
}
.accordion-body {
  padding-bottom: var(--space-4);
}
.input-with-suffix {
  display: flex;
  align-items: center;
  gap: 0;
}
.input-with-suffix .input {
  border-top-right-radius: 0;
  border-bottom-right-radius: 0;
  flex: 1;
}
.input-suffix {
  background: var(--color-bg-secondary);
  border: 1px solid var(--color-border);
  border-left: none;
  padding: var(--space-2) var(--space-3);
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  border-radius: 0 var(--radius-md) var(--radius-md) 0;
  white-space: nowrap;
  line-height: 1.5;
}
.einstellungen-hours-tab-bar {
  display: flex;
  gap: var(--space-1);
  margin-bottom: var(--space-3);
  flex-wrap: wrap;
}
.einstellungen-hours-tab {
  padding: var(--space-1) var(--space-3);
  border-radius: var(--radius-md);
  font-size: var(--text-sm);
  font-weight: 500;
  color: var(--color-text-secondary);
  background: none;
  border: 1px solid var(--color-border);
  cursor: pointer;
  transition: all var(--transition-fast);
}
.einstellungen-hours-tab:hover {
  background: var(--color-bg-secondary);
}
.einstellungen-hours-tab.active {
  background: var(--color-primary);
  color: #fff;
  border-color: var(--color-primary);
}
.einstellungen-hours-grid {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}
.einstellungen-hours-row {
  display: flex;
  align-items: center;
  gap: var(--space-2);
}
.einstellungen-hours-day {
  width: 100px;
  font-size: var(--text-sm);
  font-weight: 500;
  color: var(--color-text);
  flex-shrink: 0;
}
.einstellungen-hours-input {
  width: 80px;
  text-align: center;
  font-size: var(--text-sm);
}
.einstellungen-hours-sep {
  color: var(--color-text-muted);
  font-size: var(--text-sm);
}
.einstellungen-services-list {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}
.einstellungen-service-item {
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  background: var(--color-bg);
  overflow: hidden;
}
.einstellungen-service-item.inactive {
  opacity: 0.6;
}
.einstellungen-service-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-2);
  padding: var(--space-3);
  cursor: pointer;
  -webkit-user-select: none;
     -moz-user-select: none;
          user-select: none;
}
.einstellungen-service-header:hover {
  background: var(--color-bg-secondary);
}
.einstellungen-service-toggle {
  flex-shrink: 0;
  display: flex;
  align-items: center;
}
.einstellungen-service-detail {
  padding: 0 var(--space-3) var(--space-3);
  border-top: 1px solid var(--color-border);
}
.svc-aw-grid {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}
.svc-aw-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-2);
}
.svc-aw-label {
  font-size: var(--text-sm);
  color: var(--color-text);
  min-width: 100px;
  flex: 1;
}
.svc-aw-input-group {
  max-width: 120px;
  flex-shrink: 0;
}
.svc-aw-input-group .input {
  width: 70px;
  text-align: center;
}
.beratung-service-row {
  display: flex;
  align-items: center;
  gap: 8px;
}
.beratung-service-info {
  display: flex;
  align-items: center;
  gap: 8px;
  flex: 1;
  min-width: 0;
}
.beratung-service-reorder {
  display: flex;
  flex-direction: column;
  gap: 2px;
  flex-shrink: 0;
}
.beratung-service-actions {
  display: flex;
  align-items: center;
  gap: 4px;
  flex-shrink: 0;
}
@media (max-width: 480px) {
  .beratung-service-row {
    flex-wrap: wrap;
  }
  .beratung-service-actions {
    width: 100%;
    justify-content: flex-end;
    padding-top: 4px;
  }
}
.einstellungen-empty {
  text-align: center;
  padding: var(--space-8) var(--space-4);
  color: var(--color-text-muted);
}
.einstellungen-empty svg {
  width: 48px !important;
  height: 48px !important;
  margin: 0 auto var(--space-3);
  opacity: 0.4;
}
.einstellungen-empty p {
  margin-bottom: var(--space-2);
}
.einstellungen-empty .btn {
  margin-top: var(--space-3);
}
.team-members-list {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}
.team-member-card {
  background: var(--color-bg);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: var(--space-3);
  transition: box-shadow var(--transition-fast);
}
.team-member-card:hover {
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.06);
}
.team-member-header {
  display: flex;
  align-items: center;
  gap: var(--space-3);
}
.team-avatar {
  width: 36px !important;
  height: 36px !important;
  min-width: 36px;
  min-height: 36px;
  max-width: 36px;
  max-height: 36px;
  border-radius: 50%;
  display: flex !important;
  align-items: center;
  justify-content: center;
  font-size: 12px;
  font-weight: 700;
  color: #fff;
  flex-shrink: 0;
  letter-spacing: 0.5px;
  overflow: hidden;
  background: var(--avatar-bg, var(--color-primary));
}
.team-avatar-sm {
  width: 24px;
  height: 24px;
  min-width: 24px;
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 9px;
  font-weight: 700;
  color: #fff;
  flex-shrink: 0;
  background: var(--avatar-bg, var(--color-primary));
}
.pill-dept {
  color: #fff;
}
.pill-dept[style*="--pill-color"] {
  background-color: var(--pill-color);
}
.team-member-info {
  flex: 1;
  min-width: 0;
}
.team-member-info strong {
  font-size: var(--text-sm);
  display: block;
  line-height: 1.3;
}
.team-member-badges {
  display: flex;
  align-items: center;
  gap: var(--space-1);
  flex-wrap: wrap;
  margin-top: 2px;
}
.team-schedule-grid {
  display: grid !important;
  grid-template-columns: repeat(7, 1fr);
  gap: 4px;
  margin-top: var(--space-2);
  padding-top: var(--space-2);
  border-top: 1px solid var(--color-border);
}
.team-schedule-grid .einstellungen-team-day {
  text-align: center;
  padding: 4px 2px;
  border-radius: var(--radius-sm);
  font-size: 11px;
  flex: unset;
}
.einstellungen-team-day {
  flex: 1;
  text-align: center;
  padding: var(--space-1);
  border-radius: var(--radius-sm);
  font-size: 11px;
}
.einstellungen-team-day.active {
  background: var(--color-success);
  @supports (color: color-mix(in lab, red, red)) {
    background: color-mix(in srgb, var(--color-success) 15%, transparent);
  }
  color: var(--color-success);
}
.einstellungen-team-day.off {
  background: var(--color-bg-secondary);
  color: var(--color-text-muted);
  opacity: 0.6;
}
.einstellungen-team-day-name {
  display: block;
  font-weight: 600;
  font-size: 10px;
  text-transform: uppercase;
}
.einstellungen-team-day-aw {
  display: block;
  font-weight: 700;
}
.einstellungen-team-day-role {
  display: block;
  font-size: 9px;
  font-weight: 700;
  color: var(--color-primary);
}
.team-schedule-grid-sales {
  grid-template-columns: repeat(6, 1fr) auto;
}
.rot-week-rows {
  display: flex;
  flex-direction: column;
  gap: 1px;
  margin-top: 2px;
}
.rot-week-row {
  height: 11px;
  border-radius: 2px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-bottom: 1px solid var(--color-border);
  @supports (color: color-mix(in lab, red, red)) {
    border-bottom: 1px solid color-mix(in srgb, var(--color-border) 50%, transparent);
  }
}
.rot-week-row:last-child {
  border-bottom: none;
}
.rot-week-row.rot-on {
  background: var(--color-success);
  @supports (color: color-mix(in lab, red, red)) {
    background: color-mix(in srgb, var(--color-success) 25%, transparent);
  }
}
.rot-week-row.rot-off {
  background: var(--color-border);
  opacity: 0.4;
}
.rot-x {
  font-size: 7px;
  font-weight: 700;
  line-height: 1;
  color: var(--color-success);
}
.einstellungen-team-day-rotation {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: flex-start;
  gap: 2px;
  padding: 4px 6px;
  color: var(--color-text-muted);
  background: var(--color-bg-secondary);
}
.einstellungen-team-day-rotation svg {
  flex-shrink: 0;
}
.rot-week-label {
  font-size: 8px;
  font-weight: 600;
  line-height: 12px;
  text-align: center;
  color: var(--color-text-muted);
}
.rotation-table {
  border-collapse: collapse;
}
.rotation-table th, .rotation-table td {
  border-bottom: 1px solid var(--color-border);
}
.rotation-table th:nth-child(even), .rotation-table td:nth-child(even) {
  background: transparent;
}
.rotation-table .rot-week-border {
  border-left: 1.5px solid var(--color-text-muted);
}
.rotation-table .rot-cell-active {
  background: var(--color-success-bg, rgba(16, 185, 129, 0.1));
  color: var(--color-success);
}
.einstellungen-team-edit {
  margin-top: var(--space-3);
  padding-top: var(--space-3);
  border-top: 1px solid var(--color-border);
}
.einstellungen-schedule-grid {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}
.einstellungen-schedule-row {
  display: flex;
  align-items: center;
  gap: var(--space-3);
}
.einstellungen-schedule-day {
  width: 30px;
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--color-text);
  flex-shrink: 0;
}
.einstellungen-schedule-row .einstellungen-field {
  width: 80px;
  flex-shrink: 0;
}
.einstellungen-checkbox {
  display: flex;
  align-items: center;
  gap: var(--space-1);
  cursor: pointer;
  white-space: nowrap;
}
.einstellungen-checkbox input[type="checkbox"] {
  width: 22px;
  height: 22px;
  min-width: 22px;
  min-height: 22px;
  accent-color: var(--color-primary);
  border-radius: 50%;
  -webkit-appearance: none;
  -moz-appearance: none;
       appearance: none;
  border: 2px solid var(--color-border);
  background: var(--color-bg);
  cursor: pointer;
  position: relative;
  flex-shrink: 0;
}
.einstellungen-checkbox input[type="checkbox"]:checked {
  background: var(--color-primary);
  border-color: var(--color-primary);
}
.einstellungen-checkbox input[type="checkbox"]:checked::after {
  content: '';
  position: absolute;
  top: 2px;
  left: 5px;
  width: 6px;
  height: 10px;
  border: solid #fff;
  border-width: 0 2px 2px 0;
  transform: rotate(45deg);
}
.einstellungen-team-list {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}
.einstellungen-team-card {
  background: var(--color-bg-secondary);
  border-radius: var(--radius-lg);
  padding: var(--space-3);
}
.einstellungen-team-header {
  display: flex;
  align-items: center;
  gap: var(--space-3);
}
.einstellungen-team-avatar {
  width: 36px;
  height: 36px;
  border-radius: 50%;
  background: var(--color-primary);
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 12px;
  font-weight: 700;
  flex-shrink: 0;
}
.einstellungen-team-info {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.einstellungen-team-info strong {
  font-size: var(--text-sm);
}
.einstellungen-team-status {
  flex-shrink: 0;
}
.einstellungen-team-schedule {
  display: flex;
  gap: var(--space-1);
  margin-top: var(--space-2);
  padding-top: var(--space-2);
  border-top: 1px solid var(--color-border);
}
.badge {
  display: inline-block;
  padding: 2px 8px;
  border-radius: var(--radius-full, 9999px);
  font-size: 11px;
  font-weight: 600;
  line-height: 1.4;
}
.badge-success {
  background: var(--color-success);
  @supports (color: color-mix(in lab, red, red)) {
    background: color-mix(in srgb, var(--color-success) 15%, transparent);
  }
  color: var(--color-success);
}
.badge-muted {
  background: var(--color-bg);
  color: var(--color-text-muted);
}
.input-sm {
  padding: var(--space-1) var(--space-2);
  font-size: var(--text-sm);
}
.flex {
  display: flex;
}
.gap-2 {
  gap: var(--space-2);
}
.mt-3 {
  margin-top: var(--space-3);
}
.mt-4 {
  margin-top: var(--space-4);
}
.mt-1 {
  margin-top: var(--space-1);
}
.mt-2 {
  margin-top: var(--space-2);
}
.mb-2 {
  margin-bottom: var(--space-2);
}
.mb-3 {
  margin-bottom: var(--space-3);
}
@media (max-width: 767px) {
  .einstellungen-team-schedule {
    flex-wrap: wrap;
  }
  .einstellungen-schedule-row {
    flex-wrap: wrap;
    gap: var(--space-2);
  }
  .einstellungen-hours-day {
    width: 70px;
  }
  .einstellungen-hours-input {
    width: 65px;
  }
}
.einstellungen-biketype-row {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-1) 0;
  border-bottom: 1px solid var(--color-border);
}
.einstellungen-biketype-row:last-child {
  border-bottom: none;
}
.einstellungen-biketype-check {
  display: flex;
  align-items: center;
  flex-shrink: 0;
}
.einstellungen-biketype-check input[type="checkbox"] {
  width: 16px;
  height: 16px;
  accent-color: var(--color-primary);
}
.einstellungen-biketype-label {
  flex: 1;
  min-width: 100px;
}
.einstellungen-holidays {
  padding: var(--space-2) 0;
}
.einstellungen-holidays-list {
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
  max-height: 300px;
  overflow-y: auto;
}
.einstellungen-holiday-item {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-1) var(--space-2);
  font-size: var(--text-sm);
  border-radius: var(--radius-sm);
}
.einstellungen-holiday-item:nth-child(odd) {
  background: var(--color-bg-secondary);
}
.einstellungen-holiday-date {
  font-weight: 600;
  min-width: 80px;
  color: var(--color-primary);
  font-size: 12px;
}
.einstellungen-brands-grid {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-1);
  max-height: 250px;
  overflow-y: auto;
  padding: var(--space-2);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  background: var(--color-bg);
}
.einstellungen-brand-item {
  display: flex;
  align-items: center;
  gap: var(--space-1);
  padding: var(--space-1) var(--space-2);
  border-radius: var(--radius-sm);
  font-size: var(--text-sm);
  cursor: pointer;
  transition: background-color var(--transition-fast);
  border: 1px solid transparent;
}
.einstellungen-brand-item:hover {
  background: var(--color-bg-secondary);
}
.einstellungen-brand-item.active {
  background: var(--color-primary);
  @supports (color: color-mix(in lab, red, red)) {
    background: color-mix(in srgb, var(--color-primary) 12%, transparent);
  }
  border-color: var(--color-primary);
  font-weight: 600;
}
.einstellungen-brand-item input[type="checkbox"] {
  width: 14px;
  height: 14px;
  accent-color: var(--color-primary);
}
.einstellungen-search-results {
  position: absolute;
  top: 100%;
  left: 0;
  right: 0;
  background: var(--color-bg);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-lg);
  z-index: 50;
  max-height: 200px;
  overflow-y: auto;
}
.einstellungen-search-item {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-2) var(--space-3);
  cursor: pointer;
  font-size: var(--text-sm);
  transition: background-color var(--transition-fast);
}
.einstellungen-search-item:hover {
  background: var(--color-bg-secondary);
}
.user-menu-section-label {
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.8px;
  color: var(--color-text-muted);
  padding: var(--space-2) var(--space-4) var(--space-1);
}
.dark .accordion-icon {
  background: rgba(255, 255, 255, 0.06);
}
.dark .accordion-icon svg {
  color: var(--color-accent);
}
.dark .team-member-card {
  border-color: rgba(255, 255, 255, 0.08);
}
.nachrichten-filter {
  display: flex;
  gap: var(--space-2);
  margin-bottom: var(--space-4);
}
.nachrichten-filter-btn {
  padding: var(--space-1) var(--space-3);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  background: var(--color-bg-secondary);
  color: var(--color-text-secondary);
  cursor: pointer;
  font-size: var(--text-sm);
  transition: all var(--transition-fast);
}
.nachrichten-filter-btn.active {
  background: var(--color-primary);
  color: #fff;
  border-color: var(--color-primary);
}
.nachrichten-loading {
  padding: var(--space-6);
  text-align: center;
  color: var(--color-text-muted);
}
.nachrichten-category {
  margin-bottom: var(--space-6);
}
.nachrichten-category-title {
  font-size: var(--text-base);
  font-weight: 600;
  color: var(--color-text);
  margin: 0 0 var(--space-3);
  padding-bottom: var(--space-2);
  border-bottom: 1px solid var(--color-border);
}
.nachrichten-item {
  background: var(--color-bg);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: var(--space-4);
  margin-bottom: var(--space-3);
}
.nachrichten-item-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: var(--space-2);
}
.nachrichten-item-title {
  display: flex;
  align-items: center;
  gap: var(--space-2);
}
.nachrichten-item-title strong {
  font-size: var(--text-sm);
  color: var(--color-text);
}
.nachrichten-item-actions {
  display: flex;
  gap: var(--space-1);
}
.nachrichten-badge {
  font-size: 11px;
  padding: 2px 8px;
  border-radius: var(--radius-sm);
  font-weight: 600;
  text-transform: uppercase;
}
.badge-email {
  background: #dbeafe;
  color: #1e40af;
}
.badge-sms {
  background: #dcfce7;
  color: #166534;
}
.dark .badge-email {
  background: #1e3a5f;
  color: #93c5fd;
}
.dark .badge-sms {
  background: #14532d;
  color: #86efac;
}
.nachrichten-placeholders {
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
  margin-top: var(--space-2);
}
.nachrichten-placeholder-tag {
  font-size: 11px;
  background: var(--color-bg-secondary);
  padding: 1px 6px;
  border-radius: 3px;
  color: var(--color-text-secondary);
}
.nachrichten-placeholder-clickable {
  cursor: pointer;
  border: 1px solid var(--color-border);
  padding: 3px 8px;
  border-radius: var(--radius-sm);
  background: var(--color-bg);
  color: var(--color-text);
}
.nachrichten-placeholder-clickable:hover {
  background: var(--color-bg-secondary);
}
.nachrichten-toggle {
  margin-top: var(--space-2);
}
.nachrichten-placeholders-ref {
  margin-top: var(--space-4);
  padding: var(--space-3);
  background: var(--color-bg-secondary);
  border-radius: var(--radius-md);
}
.nachrichten-modal-backdrop {
  position: fixed;
  inset: 0;
  z-index: 1000;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(0, 0, 0, 0.5);
}
.nachrichten-modal {
  background: var(--color-bg);
  border-radius: var(--radius-lg);
  width: 90%;
  max-width: 700px;
  max-height: 90vh;
  overflow-y: auto;
  padding: var(--space-6);
  box-shadow: 0 20px 60px rgba(0, 0, 0, 0.3);
}
.nachrichten-modal--sm {
  max-width: 600px;
}
.nachrichten-modal-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: var(--space-4);
}
.nachrichten-modal-header h3 {
  margin: 0;
  font-size: var(--text-lg);
  color: var(--color-text);
}
.nachrichten-modal-close {
  background: none;
  border: none;
  font-size: 20px;
  cursor: pointer;
  color: var(--color-text-muted);
  padding: var(--space-1) var(--space-2);
}
.nachrichten-textarea {
  font-family: monospace;
  font-size: var(--text-sm);
  line-height: 1.5;
  resize: vertical;
}
.nachrichten-modal-actions {
  display: flex;
  gap: var(--space-2);
  justify-content: space-between;
}
.nachrichten-modal-actions-right {
  display: flex;
  gap: var(--space-2);
}
.nachrichten-preview-subject {
  font-size: var(--text-sm);
  color: var(--color-text);
  font-weight: 600;
}
.nachrichten-preview-body {
  background: var(--color-bg-secondary);
  padding: var(--space-4);
  border-radius: var(--radius-lg);
  font-size: var(--text-sm);
  line-height: 1.6;
  white-space: pre-wrap;
  color: var(--color-text);
  font-family: monospace;
  margin-top: var(--space-3);
}
.einstellungen input[type="checkbox"], .einstellungen-content input[type="checkbox"], .card input[type="checkbox"] {
  width: 22px;
  height: 22px;
  min-width: 22px;
  min-height: 22px;
  accent-color: var(--color-primary);
  border-radius: 50%;
  -webkit-appearance: none;
  -moz-appearance: none;
       appearance: none;
  border: 2px solid var(--color-border);
  background: var(--color-bg);
  cursor: pointer;
  position: relative;
  flex-shrink: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.einstellungen input[type="checkbox"]:checked, .einstellungen-content input[type="checkbox"]:checked, .card input[type="checkbox"]:checked {
  background: var(--color-primary);
  border-color: var(--color-primary);
}
.einstellungen input[type="checkbox"]:checked::after, .einstellungen-content input[type="checkbox"]:checked::after, .card input[type="checkbox"]:checked::after {
  content: '';
  position: absolute;
  top: 2px;
  left: 5px;
  width: 6px;
  height: 10px;
  border: solid #fff;
  border-width: 0 2px 2px 0;
  transform: rotate(45deg);
}
.einstellungen-integration-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-3);
  padding: var(--space-3) 0;
  border-bottom: 1px solid var(--color-border);
}
.einstellungen-integration-row:last-of-type {
  border-bottom: none;
}
.einstellungen-integration-info {
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
  min-width: 0;
  flex: 1;
}
.einstellungen-integration-name {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  font-weight: 600;
  font-size: var(--text-sm);
  color: var(--color-text);
}
.einstellungen-integration-name svg {
  flex-shrink: 0;
  color: var(--color-text-muted);
}
.einstellungen-integration-status {
  font-size: var(--text-xs);
  color: var(--color-text-muted);
}
.einstellungen-integration-status--connected {
  color: var(--color-success);
}
.einstellungen-integration-actions {
  flex-shrink: 0;
}
@media (max-width: 640px) {
  .einstellungen-integration-row {
    flex-direction: column;
    align-items: flex-start;
  }
  .einstellungen-integration-actions {
    width: 100%;
  }
  .einstellungen-integration-actions .btn {
    width: 100%;
  }
}
.embed-link-row {
  display: flex;
  align-items: flex-start;
  gap: 8px;
}
.embed-link-row .input {
  flex: 1;
}
.embed-copy-btn {
  flex-shrink: 0;
  white-space: nowrap;
}
[x-cloak] {
  display: none !important;
}
.wk-empty-hint {
  padding: var(--space-3) 0;
}
.wk-slot-header-info {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  flex: 1;
}
.wk-options-row {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-3);
  margin-top: var(--space-3);
}
.wk-slots-row {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
}
.wk-subsection {
  margin-top: var(--space-4);
}
.wk-subsection-sm {
  margin-top: var(--space-3);
}
.svc-aw-row--separator {
  border-top: 1px solid var(--color-border);
  padding-top: var(--space-1);
  margin-top: var(--space-1);
}
.svc-defect-list {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}
.svc-defect-row {
  display: flex;
  align-items: center;
  gap: var(--space-2);
}
.svc-defect-row .input {
  flex: 1;
}
.svc-defect-pos {
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.svc-defect-move {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 22px;
  height: 16px;
  padding: 0;
  border: 1px solid var(--color-border);
  border-radius: 3px;
  background: var(--color-bg-secondary);
  color: var(--color-text-muted);
  cursor: pointer;
  transition: background 0.15s, color 0.15s;
}
.svc-defect-move:hover:not(:disabled) {
  background: var(--color-bg-hover);
  color: var(--color-text);
}
.svc-defect-move:disabled {
  opacity: 0.3;
  cursor: not-allowed;
}
.wk-add-row {
  display: flex;
  gap: var(--space-2);
  align-items: center;
  margin-top: var(--space-3);
}
.wk-defect-add-row {
  display: flex;
  gap: var(--space-2);
  align-items: center;
  margin-top: var(--space-1);
}
.wk-save-row {
  display: flex;
  gap: var(--space-2);
  margin-top: var(--space-3);
}
.wk-cost-section {
  margin-top: var(--space-4);
}
.wk-cost-descs {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}
.einstellungen-field--full {
  grid-column: 1 / -1;
}
.einstellungen-checkbox-inline {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  cursor: pointer;
  font-size: var(--text-sm);
}
.wk-photo-gallery {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-3);
  margin-bottom: var(--space-3);
}
.wk-photo-item {
  position: relative;
  width: 120px;
}
.wk-photo-img {
  width: 120px;
  height: 90px;
  -o-object-fit: cover;
     object-fit: cover;
  border-radius: var(--radius-sm);
  border: 1px solid var(--color-border);
  cursor: pointer;
  display: block;
}
.wk-photo-label {
  margin-top: var(--space-1);
  text-align: center;
}
.wk-photo-delete {
  position: absolute;
  top: -6px;
  right: -6px;
  background: var(--color-bg);
  border-radius: var(--radius-full);
  width: 22px;
  height: 22px;
  padding: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: var(--shadow-md);
}
.wk-photo-upload {
  margin-bottom: var(--space-3);
}
.wk-photo-upload-grid {
  max-width: 400px;
}
.wk-photo-upload-btn-row {
  margin-top: var(--space-2);
}
.wk-photo-upload-label {
  cursor: pointer;
}
.wk-photo-file-input {
  display: none;
}
.wk-preview-modal {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.8);
  z-index: var(--z-modal);
  display: flex;
  align-items: center;
  justify-content: center;
}
.wk-preview-inner {
  position: relative;
  max-width: 90vw;
  max-height: 90vh;
}
.wk-preview-img {
  max-width: 90vw;
  max-height: 80vh;
  -o-object-fit: contain;
     object-fit: contain;
  border-radius: var(--radius-sm);
  display: block;
}
.wk-preview-caption {
  text-align: center;
  color: white;
  margin-top: var(--space-2);
  font-size: var(--text-sm);
}
.wk-preview-close {
  position: absolute;
  top: -12px;
  right: -12px;
  background: var(--color-bg);
  border: none;
  border-radius: var(--radius-full);
  width: 32px;
  height: 32px;
  font-size: 18px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: var(--shadow-lg);
}
.wk-preview-prev {
  position: absolute;
  left: -40px;
  top: 50%;
  transform: translateY(-50%);
  background: var(--color-bg);
  border: none;
  border-radius: var(--radius-full);
  width: 36px;
  height: 36px;
  font-size: 20px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: var(--shadow-lg);
}
.wk-preview-next {
  position: absolute;
  right: -40px;
  top: 50%;
  transform: translateY(-50%);
  background: var(--color-bg);
  border: none;
  border-radius: var(--radius-full);
  width: 36px;
  height: 36px;
  font-size: 20px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: var(--shadow-lg);
}
.dark .wk-photo-delete {
  background: var(--color-bg-secondary);
  box-shadow: 0 1px 4px rgba(0, 0, 0, 0.5);
}
.dark .wk-preview-close, .dark .wk-preview-prev, .dark .wk-preview-next {
  background: var(--color-bg-secondary);
}
.wk-input-name {
  max-width: 160px;
}
.wk-input-limit {
  max-width: 130px;
}
.wk-biketype-id {
  min-width: 60px;
}
.wk-input-new-service {
  max-width: 300px;
}
.wk-input-new-defect {
  max-width: 250px;
}
.einstellungen-threshold-row {
  display: flex;
  gap: var(--space-2);
  align-items: center;
  margin-bottom: var(--space-1);
}
.wk-threshold-input {
  max-width: 140px;
}
.wk-brand-search-wrap {
  position: relative;
  margin-bottom: var(--space-2);
}
.wk-brand-new-btn {
  margin-top: var(--space-1);
}
.team-section-divider {
  margin-top: 1.5rem;
  padding-top: 1rem;
  border-top: 1px solid var(--color-border);
}
.team-section-divider-sm {
  margin-top: 1rem;
  padding-top: 1rem;
  border-top: 1px solid var(--color-border);
}
.team-subsection-title {
  margin-bottom: 0.5rem;
}
.team-th-center {
  text-align: center;
}
.team-td-center {
  text-align: center;
}
.team-summary-row {
  border-top: 2px solid var(--color-border);
  font-weight: 700;
}
.team-rot-th {
  text-align: center;
  min-width: 36px;
}
.team-rot-td {
  text-align: center;
  cursor: pointer;
  min-width: 36px;
}
.team-color-picker {
  height: 38px;
  width: 60px;
  padding: 2px;
}
.team-color-row {
  align-items: center;
}
.team-vacation-overview {
  margin-bottom: 1.5rem;
}
.team-btn-delete {
  margin-left: auto;
}
.team-action-btn {
  margin-top: 0.5rem;
}
.team-rot-overflow {
  overflow-x: auto;
}
.nachrichten-loading-state {
  padding: var(--space-6);
  text-align: center;
}
.nachrichten-edit-form {
  margin-top: var(--space-3);
  padding-top: var(--space-3);
  border-top: 1px solid var(--color-border);
}
.nachrichten-edit-actions {
  margin-top: var(--space-3);
  display: flex;
  gap: var(--space-2);
}
.nachrichten-email-card {
  background: var(--color-bg-secondary);
  border-radius: var(--radius-sm);
  padding: var(--space-4);
  margin-bottom: var(--space-4);
}
.dark .nachrichten-email-card {
  background: rgba(255, 255, 255, 0.04);
}
.nachrichten-email-card-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: var(--space-3);
}
.nachrichten-email-card-title {
  font-size: var(--text-sm);
  font-weight: 600;
}
.nachrichten-input-narrow {
  max-width: 120px;
}
.nachrichten-overview-title {
  font-size: var(--text-sm);
  font-weight: 600;
  display: block;
  margin-bottom: var(--space-3);
}
.nachrichten-overview-table {
  width: 100%;
  font-size: var(--text-sm);
  border-collapse: collapse;
}
.nachrichten-overview-table tr {
  border-bottom: 1px solid var(--color-border);
}
.nachrichten-overview-table tr:last-child {
  border-bottom: none;
}
.nachrichten-overview-table td {
  padding: var(--space-2) var(--space-1);
}
.nachrichten-overview-td-name {
  font-weight: 500;
}
.nachrichten-overview-td-desc {
  color: var(--color-text-muted);
}
.dark .nachrichten-overview-td-desc {
  color: var(--color-text-muted);
}
.nachrichten-overview-td-status {
  text-align: right;
}
.pill-xs {
  font-size: 11px;
}
.nachrichten-textarea-sm {
  font-size: var(--text-sm);
}
.beratung-buchen-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--space-5);
}
.beratung-buchen-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-6);
}
@media (max-width: 768px) {
  .beratung-buchen-grid {
    grid-template-columns: 1fr;
  }
}
.beratung-card-inner {
  padding: var(--space-5);
}
.beratung-section-heading {
  margin-bottom: var(--space-3);
}
.beratung-search-wrap {
  position: relative;
  margin-bottom: var(--space-3);
}
.beratung-crm-badge-row {
  margin-top: var(--space-2);
  display: flex;
  align-items: center;
  gap: var(--space-2);
}
.beratung-crm-pill {
  background: var(--color-success);
  color: #fff;
  font-size: 11px;
  padding: 2px 8px;
}
.dark .beratung-crm-pill {
  background: #22c55e;
}
.beratung-change-link {
  text-decoration: underline;
  cursor: pointer;
  background: none;
  border: none;
  color: var(--color-text-secondary);
  font-size: var(--text-xs);
}
.beratung-customer-dropdown {
  position: absolute;
  top: 100%;
  left: 0;
  right: 0;
  z-index: 50;
  background: var(--color-bg);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
  max-height: 240px;
  overflow-y: auto;
  margin-top: var(--space-1);
}
.dark .beratung-customer-dropdown {
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.4);
}
.beratung-customer-item {
  display: block;
  width: 100%;
  text-align: left;
  padding: 10px 14px;
  border: none;
  background: none;
  cursor: pointer;
  border-bottom: 1px solid var(--color-border);
}
.beratung-customer-item:hover {
  background: var(--color-bg-secondary);
}
.beratung-customer-item:last-child {
  border-bottom: none;
}
.beratung-fields-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
  margin-bottom: var(--space-4);
}
.beratung-service-select {
  margin-bottom: var(--space-4);
}
.beratung-duration-info {
  background: var(--color-bg-secondary);
  border-radius: var(--radius-sm);
  padding: var(--space-3);
  margin-bottom: var(--space-4);
  display: flex;
  align-items: center;
  gap: var(--space-2);
}
.beratung-staff-pills {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-bottom: var(--space-4);
}
.beratung-staff-pill {
  padding: 4px 10px;
  font-size: 11px;
}
.beratung-staff-pill--active {
  background: var(--pill-color, var(--color-primary));
  color: #fff;
}
.beratung-staff-pill--outline {
  border: 1px solid var(--pill-color, var(--color-primary));
  color: var(--pill-color, var(--color-primary));
}
.beratung-notes-wrap {
  margin-bottom: var(--space-4);
}
.beratung-month-nav {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--space-3);
}
.beratung-cal-grid {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 4px;
  text-align: center;
}
.beratung-cal-day-header {
  padding: var(--space-1);
}
.beratung-slots-full {
  color: var(--color-danger);
}
.beratung-slots-low {
  color: var(--color-warning);
}
.beratung-slots-ok {
  color: var(--color-success);
}
.dark .beratung-slots-full {
  color: #f87171;
}
.dark .beratung-slots-low {
  color: #fbbf24;
}
.dark .beratung-slots-ok {
  color: #4ade80;
}
.beratung-cal-day--disabled {
  opacity: 0.3;
  cursor: not-allowed;
}
.beratung-cal-day--unavailable {
  opacity: 0.4;
  cursor: not-allowed;
}
.beratung-selected-date-wrap {
  margin-top: var(--space-4);
}
.beratung-selected-date-info {
  background: var(--color-bg-secondary);
  border-radius: var(--radius-sm);
  padding: var(--space-3);
  margin-bottom: var(--space-3);
}
.beratung-slots-loading {
  padding: var(--space-2);
}
.beratung-time-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 6px;
  margin-top: var(--space-2);
}
@media (max-width: 768px) {
  .beratung-time-grid {
    grid-template-columns: repeat(3, 1fr);
  }
}
.beratung-time-slot--disabled {
  opacity: 0.3;
  cursor: not-allowed;
  text-decoration: line-through;
}
.beratung-submit-area {
  margin-top: var(--space-6);
}
.beratung-submit-btn {
  width: 100%;
  padding: var(--space-4);
  font-size: var(--text-base);
}
.beratung-success-banner {
  background: rgba(34, 197, 94, 0.08);
  border: 1px solid rgba(34, 197, 94, 0.25);
  border-radius: var(--radius-sm);
  padding: var(--space-4);
  margin-top: var(--space-4);
  text-align: center;
}
.dark .beratung-success-banner {
  background: rgba(74, 222, 128, 0.08);
  border-color: rgba(74, 222, 128, 0.25);
}
.beratung-success-text {
  color: var(--color-success);
}
.dark .beratung-success-text {
  color: #4ade80;
}
.beratung-success-actions {
  display: flex;
  gap: var(--space-2);
  justify-content: center;
  margin-top: var(--space-3);
}
.beratung-manual-pill {
  background: var(--color-success);
  color: #fff;
  font-size: 10px;
  padding: 1px 6px;
}
.dark .beratung-manual-pill {
  background: #22c55e;
}
.beratung-error-banner {
  background: rgba(220, 38, 38, 0.05);
  border: 1px solid rgba(220, 38, 38, 0.25);
  border-radius: var(--radius-sm);
  padding: var(--space-3);
  margin-top: var(--space-3);
}
.dark .beratung-error-banner {
  background: rgba(248, 113, 113, 0.08);
  border-color: rgba(248, 113, 113, 0.25);
}
.beratung-error-text {
  color: var(--color-danger);
}
.dark .beratung-error-text {
  color: #f87171;
}
.beratung-cal-day {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 6px 2px;
  border: 1px solid var(--color-border);
  border-radius: 6px;
  background: var(--color-bg);
  cursor: pointer;
  transition: all 0.15s;
  min-height: 48px;
}
.beratung-cal-day:hover:not(:disabled) {
  background: var(--color-bg-secondary);
}
.beratung-cal-day--selected {
  background: var(--color-primary) !important;
  color: #fff !important;
  border-color: var(--color-primary) !important;
}
.beratung-cal-day--selected .beratung-cal-day-slots {
  color: rgba(255, 255, 255, 0.8) !important;
}
.beratung-cal-day-num {
  font-size: 13px;
  font-weight: 600;
  line-height: 1.2;
}
.beratung-cal-day-slots {
  font-size: 9px;
  line-height: 1;
}
.beratung-time-slot {
  padding: 8px 4px;
  font-size: 12px;
  font-weight: 500;
  text-align: center;
  border: 1px solid var(--color-border);
  border-radius: 6px;
  background: var(--color-bg);
  cursor: pointer;
  transition: all 0.15s;
}
.beratung-time-slot:hover:not(:disabled) {
  background: var(--color-bg-secondary);
  border-color: var(--color-primary);
}
.beratung-time-slot--selected {
  background: var(--color-primary) !important;
  color: #fff !important;
  border-color: var(--color-primary) !important;
}
.dark .beratung-cal-day {
  background: var(--color-bg-secondary);
}
.dark .beratung-time-slot {
  background: var(--color-bg-secondary);
}
.oh-new-section {
  margin-top: 1rem;
  padding-top: 1rem;
  border-top: 1px solid var(--color-border);
}
.beratung-svc-card {
  margin-bottom: 12px;
}
.beratung-svc-card--colored {
  border-left: 4px solid var(--svc-color);
}
.beratung-svc-avatar {
  width: 28px !important;
  height: 28px !important;
  min-width: 28px !important;
  min-height: 28px !important;
  max-width: 28px !important;
  max-height: 28px !important;
  font-size: 11px !important;
  background: var(--avatar-bg, #666);
}
.btn-icon-danger {
  color: var(--color-danger, #ef4444);
}
.dark .btn-icon-danger {
  color: var(--color-danger, #f87171);
}
.beratung-svc-desc {
  margin-top: 4px;
  padding-left: 34px;
}
.beratung-edit-grid {
  margin-bottom: 8px;
}
.beratung-color-row {
  display: flex;
  align-items: center;
  gap: 8px;
}
.beratung-color-swatch {
  width: 40px;
  height: 34px;
  padding: 2px;
  border: 1px solid var(--color-border);
  border-radius: 6px;
  cursor: pointer;
}
.dark .beratung-color-swatch {
  border-color: rgba(255, 255, 255, 0.15);
}
.beratung-color-text {
  width: 100px;
}
.beratung-edit-actions {
  display: flex;
  gap: 8px;
}
.beratung-hinweis {
  padding: 12px 16px;
}
.icon-arrow-right {
  margin-left: 4px;
}
.text-muted-light {
  color: var(--color-text-muted);
  opacity: 0.7;
}
.dark .text-muted-light {
  opacity: 0.6;
}
.einstellungen-loading-pad {
  padding: var(--space-6);
}
.marken-new-section {
  margin-top: var(--space-4);
}
.marken-models-list {
  margin-bottom: var(--space-4);
}
.marken-model-row {
  padding: var(--space-2) 0;
  border-bottom: 1px solid var(--color-border);
}
.marken-model-row:last-child {
  border-bottom: none;
}
.marken-model-display {
  display: flex;
  align-items: center;
  gap: var(--space-3);
}
.marken-model-display--hidden {
  opacity: 0.45;
}
.marken-model-visibility-btn {
  padding: 2px !important;
  flex-shrink: 0;
}
.marken-model-name {
  font-weight: 500;
  color: var(--color-text);
  min-width: 120px;
  display: flex;
  align-items: center;
  gap: var(--space-2);
}
.marken-model-meta {
  flex: 1;
  display: flex;
  gap: var(--space-1);
  flex-wrap: wrap;
}
.marken-model-actions {
  display: flex;
  gap: var(--space-1);
  flex-shrink: 0;
}
.marken-model-edit {
  padding: var(--space-2) 0;
}
.marken-model-edit-fields {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
  gap: var(--space-2);
  margin-bottom: var(--space-2);
}
.marken-model-edit-actions {
  display: flex;
  gap: var(--space-2);
}
.marken-model-add {
  margin-top: var(--space-4);
  padding-top: var(--space-4);
  border-top: 1px solid var(--color-border);
}
.marken-model-add-fields {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
  gap: var(--space-2);
  margin-bottom: var(--space-3);
}
@media (max-width: 640px) {
  .marken-model-display {
    flex-wrap: wrap;
  }
  .marken-model-edit-fields, .marken-model-add-fields {
    grid-template-columns: 1fr;
  }
}
.settings-guarantee-days {
  display: flex;
  gap: var(--space-2);
}
.settings-guarantee-day {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-1);
  padding: var(--space-2) var(--space-1);
  border-radius: var(--radius-md);
  border: 1px solid var(--color-border);
  background: var(--color-bg-subtle);
  transition: all 0.2s;
  cursor: pointer;
  -webkit-user-select: none;
     -moz-user-select: none;
          user-select: none;
}
.settings-guarantee-day:hover {
  transform: scale(1.05);
  box-shadow: 0 2px 8px rgba(0,0,0,0.1);
}
.settings-guarantee-day--intern {
  background: rgba(34, 197, 94, 0.1);
  border-color: rgba(34, 197, 94, 0.3);
}
.settings-guarantee-day--extern {
  background: rgba(59, 130, 246, 0.1);
  border-color: rgba(59, 130, 246, 0.3);
}
.settings-guarantee-day--frei {
  background: var(--color-bg-subtle);
  border-color: var(--color-border);
  opacity: 0.6;
}
.settings-guarantee-day-label {
  font-size: 11px;
  font-weight: 600;
  color: var(--color-text-secondary);
}
.settings-guarantee-day-type {
  font-size: 10px;
  font-weight: 500;
}
.settings-guarantee-day--intern .settings-guarantee-day-type {
  color: #16a34a;
}
.settings-guarantee-day--extern .settings-guarantee-day-type {
  color: #2563eb;
}
.settings-guarantee-day--frei .settings-guarantee-day-type {
  color: var(--color-text-muted);
}
.dark .settings-guarantee-day--intern, [data-theme="dark"] .settings-guarantee-day--intern {
  background: rgba(34, 197, 94, 0.15);
  border-color: rgba(34, 197, 94, 0.25);
}
.dark .settings-guarantee-day--extern, [data-theme="dark"] .settings-guarantee-day--extern {
  background: rgba(59, 130, 246, 0.15);
  border-color: rgba(59, 130, 246, 0.25);
}
.dark .settings-guarantee-day--intern .settings-guarantee-day-type, [data-theme="dark"] .settings-guarantee-day--intern .settings-guarantee-day-type {
  color: #4ade80;
}
.dark .settings-guarantee-day--extern .settings-guarantee-day-type, [data-theme="dark"] .settings-guarantee-day--extern .settings-guarantee-day-type {
  color: #60a5fa;
}
@media (max-width: 480px) {
  .settings-guarantee-days {
    gap: var(--space-1);
  }
  .settings-guarantee-day {
    padding: var(--space-1);
  }
}
.wb-capacity-blocks-list {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}
.wb-capacity-block-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-3);
  padding: var(--space-2) var(--space-3);
  background: var(--color-bg-secondary);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md, 8px);
}
.wb-capacity-block-info {
  display: flex;
  flex-direction: column;
  gap: 4px;
  min-width: 0;
}
.wb-capacity-block-dates {
  display: flex;
  align-items: center;
  gap: 6px;
  color: var(--color-text);
}
.wb-capacity-block-dates svg {
  flex-shrink: 0;
  color: var(--color-text-secondary);
}
.wb-capacity-block-detail {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}
.wb-capacity-block-form {
  margin-top: var(--space-4);
  padding-top: var(--space-4);
  border-top: 1px solid var(--color-border);
}
.wb-slot-checkboxes {
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.wb-checkbox-label {
  display: flex;
  align-items: center;
  gap: 8px;
  cursor: pointer;
}
.wb-mt-2 {
  margin-top: 2px;
}
.wb-mt-4 {
  margin-top: 4px;
}
.wb-mt-8 {
  margin-top: 8px;
}
.dark .wb-capacity-block-item, [data-theme="dark"] .wb-capacity-block-item {
  background: var(--color-bg-tertiary, #1f2937);
  border-color: var(--color-border);
}
.einstellungen-readonly input, .einstellungen-readonly textarea, .einstellungen-readonly select, .einstellungen-readonly .form-input, .einstellungen-readonly .form-select, .einstellungen-readonly .input {
  pointer-events: none;
  opacity: 0.7;
  background: var(--color-bg-secondary);
}
.einstellungen-readonly input[type="checkbox"], .einstellungen-readonly input[type="radio"], .einstellungen-readonly input[type="color"] {
  pointer-events: none;
  opacity: 0.5;
}
.einstellungen-readonly .btn-primary, .einstellungen-readonly .btn-save, .einstellungen-readonly .btn-danger, .einstellungen-readonly [data-admin-only] {
  display: none !important;
}
.einstellungen-readonly .einstellungen-readonly-badge {
  display: inline-flex;
}
.einstellungen-readonly-badge {
  display: none;
  font-size: 11px;
  padding: 2px 8px;
  border-radius: var(--radius-full, 9999px);
  background: var(--color-bg-secondary);
  color: var(--color-text-muted);
  margin-left: var(--space-2);
  align-items: center;
}
.dark .einstellungen-readonly input, .dark .einstellungen-readonly textarea, .dark .einstellungen-readonly select, .dark .einstellungen-readonly .form-input, .dark .einstellungen-readonly .form-select, .dark .einstellungen-readonly .input, [data-theme="dark"] .einstellungen-readonly input, [data-theme="dark"] .einstellungen-readonly textarea, [data-theme="dark"] .einstellungen-readonly select, [data-theme="dark"] .einstellungen-readonly .form-input, [data-theme="dark"] .einstellungen-readonly .form-select, [data-theme="dark"] .einstellungen-readonly .input {
  background: var(--color-bg-tertiary, #1f2937);
}
.dark .einstellungen-readonly-badge, [data-theme="dark"] .einstellungen-readonly-badge {
  background: var(--color-bg-tertiary, #1f2937);
  color: var(--color-text-muted);
}
.bgpt-debug-panel {
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  height: 240px;
  z-index: 9999;
  background: #1a1a2e;
  border-top: 2px solid #16213e;
  font-family: 'Menlo', 'Monaco', 'Courier New', monospace;
  font-size: 12px;
  color: #a8d8ea;
  display: flex;
  flex-direction: column;
}
.bgpt-debug-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 6px 12px;
  background: #16213e;
  border-bottom: 1px solid #0f3460;
  flex-shrink: 0;
}
.bgpt-debug-title {
  font-weight: 600;
  color: #e2e8f0;
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}
.bgpt-debug-clear {
  background: transparent;
  border: 1px solid #334155;
  color: #94a3b8;
  padding: 2px 8px;
  border-radius: 4px;
  font-size: 11px;
  cursor: pointer;
}
.bgpt-debug-clear:hover {
  background: #334155;
  color: #e2e8f0;
}
.bgpt-debug-output {
  flex: 1;
  overflow-y: auto;
  padding: 8px 12px;
}
.bgpt-debug-line {
  padding: 2px 0;
  border-bottom: 1px solid rgba(255,255,255,0.03);
  white-space: pre-wrap;
  word-break: break-all;
}
.bgpt-debug-line--info {
  color: #a8d8ea;
}
.bgpt-debug-line--success {
  color: #6ee7b7;
}
.bgpt-debug-line--warn {
  color: #fbbf24;
}
.bgpt-debug-line--error {
  color: #f87171;
}
.bgpt-debug-line--time {
  color: #64748b;
  margin-right: 8px;
}
.schreibtisch-greeting {
  margin-bottom: var(--space-6);
}
.schreibtisch-greeting h1 {
  font-size: var(--text-2xl);
  font-weight: 600;
}
.quick-actions {
  display: flex;
  gap: var(--space-3);
  margin-bottom: var(--space-8);
  flex-wrap: wrap;
}
.quick-action {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-3) var(--space-4);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  background: var(--color-bg);
  color: var(--color-text);
  font-size: var(--text-sm);
  font-weight: 500;
  text-decoration: none;
  white-space: nowrap;
  transition: background-color var(--transition-fast), border-color var(--transition-fast);
  -webkit-tap-highlight-color: transparent;
}
.quick-action:hover {
  background: var(--color-bg-secondary);
  border-color: var(--color-border-strong);
}
.quick-action--primary {
  background: var(--color-primary);
  border-color: var(--color-primary);
  color: #fff;
}
.quick-action--primary:hover {
  opacity: 0.9;
  color: #fff;
}
.quick-action--disabled {
  opacity: 0.6;
  cursor: default;
  position: relative;
}
.quick-action--disabled:hover {
  background: var(--color-bg);
}
.quick-action-icon {
  width: 16px;
  height: 16px;
  flex-shrink: 0;
}
.quick-action-label {
  display: inline;
}
.quick-action-soon {
  font-size: 10px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  color: var(--color-accent);
  margin-left: var(--space-1);
}
@media (max-width: 640px) {
  .quick-action-label {
    display: none;
  }
  .quick-action-soon {
    display: none;
  }
  .quick-action {
    padding: var(--space-3);
  }
  .quick-action-icon {
    width: 20px;
    height: 20px;
  }
}
.widget-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-4);
}
@media (min-width: 768px) {
  .widget-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}
.widget-day-controls {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--space-2) var(--space-4);
}
.widget-heute-btn {
  display: inline-flex;
  align-items: center;
  padding: 3px 10px;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
  background: var(--color-bg);
  color: var(--color-text-muted);
  font-size: var(--text-sm);
  font-weight: 500;
  cursor: pointer;
  transition: all var(--transition-fast);
}
.widget-heute-btn:hover {
  border-color: var(--color-primary);
  color: var(--color-primary);
}
.widget-heute-btn--active {
  background: var(--color-primary);
  border-color: var(--color-primary);
  color: #fff;
  font-weight: 700;
}
.widget-heute-btn--active:hover {
  opacity: 0.9;
  color: #fff;
}
.widget-day-nav {
  display: flex;
  align-items: center;
  gap: var(--space-2);
}
.widget-day-nav-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
  border: none;
  background: transparent;
  color: var(--color-text-muted);
  cursor: pointer;
  border-radius: var(--radius-sm);
  transition: background-color var(--transition-fast), color var(--transition-fast);
}
.widget-day-nav-btn:hover {
  background: var(--color-bg-secondary);
  color: var(--color-text);
}
.widget-day-nav-label {
  display: flex;
  align-items: center;
  gap: var(--space-1);
  color: var(--color-text);
  font-size: var(--text-sm);
  font-weight: 600;
  padding: var(--space-1) var(--space-2);
}
.widget-list-item--clickable {
  text-decoration: none;
  color: inherit;
  cursor: pointer;
}
.widget-list-item--clickable:hover {
  background: var(--color-bg-secondary);
}
.widget-list-item--clickable:hover .widget-list-name {
  color: var(--color-primary);
}
.widget-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 22px;
  height: 22px;
  padding: 0 6px;
  border-radius: var(--radius-full);
  background: var(--color-primary);
  color: #fff;
  font-size: 11px;
  font-weight: 600;
}
.widget-badge--sm {
  min-width: 18px;
  height: 18px;
  padding: 0 5px;
  font-size: 10px;
}
.widget-body {
  max-height: 360px;
  overflow-y: auto;
}
.widget-body--auto {
  max-height: none !important;
  overflow-y: visible !important;
  overflow: visible !important;
}
.widget-empty {
  padding: var(--space-4);
  text-align: center;
  color: var(--color-text-muted);
  font-size: var(--text-sm);
}
.widget-list-item {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-2) var(--space-4);
  transition: background-color var(--transition-fast);
}
.widget-list-item:hover {
  background: var(--color-bg-secondary);
}
a.widget-list-item--link {
  text-decoration: none;
  color: inherit;
  cursor: pointer;
}
a.widget-list-item--link:hover {
  background: var(--color-bg-secondary);
}
.widget-list-time {
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--color-text);
  min-width: 42px;
  flex-shrink: 0;
}
.widget-list-content {
  flex: 1;
  min-width: 0;
}
.widget-list-name {
  display: block;
  font-size: var(--text-sm);
  font-weight: 500;
  color: var(--color-text);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.widget-list-detail {
  display: block;
  font-size: 11px;
  color: var(--color-text-muted);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.widget-list-item--dept-accent {
  border-left: 3px solid var(--dept-accent-color, var(--color-primary));
  padding-left: calc(var(--space-4) - 3px);
}
.card--dept-accent {
  border-top: 3px solid var(--dept-accent-color, var(--color-primary));
}
.widget-status {
  display: inline-block;
  font-size: 10px;
  font-weight: 600;
  padding: 2px 6px;
  border-radius: var(--radius-sm);
  text-transform: uppercase;
  letter-spacing: 0.5px;
  white-space: nowrap;
}
.widget-status--booked {
  background: var(--color-status-neutral-bg);
  color: var(--color-status-neutral-text);
}
.widget-status--confirmed {
  background: var(--color-status-pending-bg);
  color: var(--color-status-pending-text);
}
.widget-status--in_progress {
  background: var(--color-status-pending-bg);
  color: var(--color-status-pending-text);
}
.widget-status--completed {
  background: var(--color-status-success-bg);
  color: var(--color-status-success-text);
}
.widget-status--cancelled {
  background: var(--color-status-danger-bg);
  color: var(--color-status-danger-text);
}
.widget-status--noshow {
  background: var(--color-status-danger-bg);
  color: var(--color-status-danger-text);
}
.widget-status--active {
  background: var(--color-status-success-bg);
  color: var(--color-status-success-text);
}
.widget-stat-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--space-3);
  padding: var(--space-3) var(--space-4);
}
.widget-stat-grid--3 {
  grid-template-columns: repeat(3, 1fr);
}
.widget-stat {
  text-align: center;
}
.widget-stat-value {
  display: block;
  font-size: var(--text-2xl);
  font-weight: 700;
  color: var(--color-text);
  line-height: 1.2;
}
.widget-stat-warn {
  color: var(--color-danger);
}
.widget-stat-label {
  display: block;
  font-size: 11px;
  color: var(--color-text-muted);
  margin-top: 2px;
}
.widget-team-initials {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
  border-radius: var(--radius-full);
  background: var(--color-primary);
  color: #fff;
  font-size: 11px;
  font-weight: 700;
  flex-shrink: 0;
  letter-spacing: 0.5px;
}
.widget-team-dept-header {
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.8px;
  color: var(--color-text-muted);
  padding: var(--space-2) 0 var(--space-1) 0;
  margin-top: var(--space-1);
}
.widget-team-dept-header:first-child {
  margin-top: 0;
}
.widget-filter-bar {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-2) var(--space-4);
  border-bottom: 1px solid var(--color-border);
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}
.widget-filter-chip {
  display: inline-flex;
  align-items: center;
  padding: 3px 10px;
  border-radius: var(--radius-full);
  border: 1px solid var(--color-border);
  background: var(--color-bg);
  color: var(--color-text-secondary, var(--color-text-muted));
  font-size: 11px;
  font-weight: 500;
  white-space: nowrap;
  cursor: pointer;
  transition: all var(--transition-fast);
}
.widget-filter-chip:hover {
  border-color: var(--color-primary);
  color: var(--color-primary);
}
.widget-filter-chip--active {
  background: var(--color-primary);
  border-color: var(--color-primary);
  color: #fff;
}
.widget-filter-chip--active:hover {
  opacity: 0.9;
  color: #fff;
}
.tn-member-pill {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 4px 8px;
  border-radius: 999px;
  border: 1.5px solid var(--pill-color, #0B3C5D);
  background: var(--color-bg);
  color: var(--pill-color, #0B3C5D);
  font-size: 12px;
  font-weight: 600;
  white-space: nowrap;
  cursor: pointer;
  transition: all var(--transition-fast);
  line-height: 1;
  height: 28px;
  box-sizing: border-box;
}
.tn-member-pill:hover {
  background: var(--pill-color, #0B3C5D);
  @supports (color: color-mix(in lab, red, red)) {
    background: color-mix(in srgb, var(--pill-color, #0B3C5D) 10%, transparent);
  }
}
.tn-member-pill--active, .tn-member-pill--active:hover {
  background: var(--pill-color, #0B3C5D);
  border-color: var(--pill-color, #0B3C5D);
  color: #fff;
  opacity: 1;
}
.tn-member-pill-initials {
  letter-spacing: 0.3px;
}
.tn-member-pill-count {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 18px;
  height: 18px;
  padding: 0 4px;
  border-radius: 999px;
  background: var(--pill-color, var(--color-primary));
  color: #fff;
  font-size: 10px;
  font-weight: 700;
  line-height: 1;
}
.tn-member-pill--active .tn-member-pill-count {
  background: rgba(255, 255, 255, 0.25);
}
.dark .tn-member-pill {
  border-color: var(--pill-color, #0B3C5D);
  color: var(--pill-color, #94a3b8);
}
.dark .tn-member-pill--active {
  background: var(--pill-color, #0B3C5D);
  border-color: var(--pill-color, #0B3C5D);
  color: #fff;
}
.tn-member-pill--both, .tj-member-pill--both {
  position: relative;
  border: none !important;
  background: var(--color-bg, #fff) !important;
  color: var(--pill-sales-color, #8B5CF6) !important;
}
.tn-member-pill--both::before, .tj-member-pill--both::before {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: inherit;
  padding: 1.5px;
  background: linear-gradient(90deg, var(--pill-sales-color, #8B5CF6) 50%, var(--pill-ws-color, #EF4444) 50%);
  -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  -webkit-mask-composite: xor;
  mask-composite: exclude;
  pointer-events: none;
}
.tn-member-pill--both:hover, .tj-member-pill--both:hover {
  background: var(--pill-sales-color, #8B5CF6) !important;
  @supports (color: color-mix(in lab, red, red)) {
    background: color-mix(in srgb, var(--pill-sales-color, #8B5CF6) 8%, var(--color-bg, #fff)) !important;
  }
}
.tn-member-pill--both.tn-member-pill--active, .tj-member-pill--both.tj-member-pill--active, .tn-member-pill--both.tn-member-pill--active:hover, .tj-member-pill--both.tj-member-pill--active:hover {
  background: linear-gradient(90deg, var(--pill-sales-color, #8B5CF6) 50%, var(--pill-ws-color, #EF4444) 50%) !important;
  color: #fff !important;
  opacity: 1;
}
.dark .tn-member-pill--both, .dark .tj-member-pill--both {
  background: var(--color-bg, #1e293b) !important;
  color: var(--pill-sales-color, #94a3b8) !important;
}
.dark .tn-member-pill--both.tn-member-pill--active, .dark .tj-member-pill--both.tj-member-pill--active {
  background: linear-gradient(90deg, var(--pill-sales-color, #8B5CF6) 50%, var(--pill-ws-color, #EF4444) 50%) !important;
  color: #fff !important;
}
.widget-team-absent {
  border-top: 1px solid var(--color-border);
  margin-top: var(--space-1);
}
.widget-list-item--absent {
  opacity: 0.65;
}
.widget-team-initials--absent {
  opacity: 0.5;
}
.widget-list-name--muted {
  color: var(--color-text-muted);
}
.widget-absence-badge {
  display: inline-block;
  font-size: 10px;
  font-weight: 600;
  padding: 2px 6px;
  border-radius: var(--radius-sm);
  text-transform: uppercase;
  letter-spacing: 0.5px;
  white-space: nowrap;
}
.widget-absence-badge--urlaub {
  background: var(--color-status-absent-urlaub-bg);
  color: var(--color-status-absent-urlaub-text);
}
.widget-absence-badge--krank {
  background: var(--color-status-absent-krank-bg);
  color: var(--color-status-absent-krank-text);
}
.widget-team-free {
  padding: var(--space-2) var(--space-4);
  border-top: 1px solid var(--color-border);
  margin-top: var(--space-1);
  font-size: 11px;
  color: var(--color-text-muted);
}
.widget-coming-soon {
  text-align: center;
  padding: var(--space-6) var(--space-4);
}
.widget-coming-soon-emoji {
  font-size: 2rem;
  display: block;
  margin-bottom: var(--space-3);
}
.widget-coming-soon p {
  color: var(--color-text-muted);
  font-size: var(--text-sm);
  margin: 0 0 var(--space-2);
}
.schreibtisch-tools {
  margin-top: var(--space-8);
  padding-top: var(--space-6);
  border-top: 1px solid var(--color-border);
}
.schreibtisch-tools h2 {
  font-size: var(--text-lg);
  font-weight: 600;
  margin-bottom: var(--space-4);
}
.tool-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--space-3);
}
@media (min-width: 768px) {
  .tool-grid {
    grid-template-columns: repeat(3, 1fr);
  }
}
.tool-card .card-inner {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  flex-direction: row;
}
.tool-card-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  border-radius: var(--radius-lg);
  background: var(--color-bg-secondary);
  flex-shrink: 0;
  color: var(--color-primary);
}
.tool-card-icon svg {
  width: 20px;
  height: 20px;
}
.tool-card-title {
  font-size: var(--text-sm);
  font-weight: 600;
  margin: 0;
}
.tool-card-desc {
  font-size: 11px;
  color: var(--color-text-muted);
  margin: 2px 0 0;
}
@media (max-width: 640px) {
  .tool-grid {
    grid-template-columns: 1fr;
  }
}
.quick-action-count {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 20px;
  height: 20px;
  padding: 0 5px;
  border-radius: var(--radius-full);
  background: var(--color-primary);
  color: #fff;
  font-size: 10px;
  font-weight: 600;
  margin-left: 4px;
}
.quick-favorites {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  margin-bottom: var(--space-4);
  flex-wrap: wrap;
}
.quick-favorites-label {
  font-size: var(--text-xs);
  color: var(--color-text-muted);
  font-weight: 500;
}
.quick-favorite-chip {
  display: inline-flex;
  align-items: center;
  padding: 3px 10px;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-full, 9999px);
  background: var(--color-bg);
  color: var(--color-text);
  font-size: 12px;
  font-weight: 500;
  text-decoration: none;
  transition: all var(--transition-fast);
}
.quick-favorite-chip:hover {
  border-color: var(--color-primary);
  color: var(--color-primary);
}
.widget-settings-toggle {
  display: flex;
  justify-content: flex-end;
  margin-bottom: var(--space-2);
}
.widget-settings-panel {
  padding: var(--space-3) var(--space-4);
  margin-bottom: var(--space-4);
  background: var(--color-bg-secondary);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
}
.widget-settings-grid {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-3) var(--space-6);
}
.widget-settings-item {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--text-sm);
  color: var(--color-text);
  cursor: pointer;
}
.widget-settings-item input[type="checkbox"] {
  accent-color: var(--color-primary);
}
.widget-grid .card-footer {
  border-top: none;
  padding-top: var(--space-2);
}
.widget-grid .widget-day-controls {
  border-bottom: none;
}
.widget-badge--ws {
  background: var(--color-dept-ws);
}
.widget-badge--warning {
  background: var(--color-warning);
}
.widget-ws-stats {
  display: flex;
  gap: 1px;
  background: var(--color-border);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-xl);
  overflow: hidden;
}
.widget-ws-stat {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 2px;
  padding: var(--space-3) var(--space-2);
  background: var(--color-bg);
}
.widget-ws-stats--6 {
  flex-wrap: wrap;
}
.widget-ws-stats--6 .widget-ws-stat {
  flex: 0 0 calc(33.333% - 1px);
}
.widget-ws-stat-value {
  font-size: var(--text-lg);
  font-weight: 700;
  color: var(--color-text);
}
.widget-ws-stat-label {
  font-size: 10px;
  color: var(--color-text-muted);
  font-weight: 500;
}
.widget-utilization-bar {
  height: 6px;
  background: var(--color-bg-secondary);
  border-radius: 3px;
  margin: var(--space-3) var(--space-4) 0;
  overflow: hidden;
}
.widget-utilization-fill {
  height: 100%;
  border-radius: 3px;
  transition: width 0.5s ease;
  width: var(--util-width, 0%);
  background: var(--util-color, var(--color-primary));
}
.widget-utilization-label {
  font-size: 11px;
  color: var(--color-text-muted);
  text-align: center;
  margin: var(--space-2) 0;
}
.spotlight-overlay {
  position: fixed;
  inset: 0;
  z-index: 9999;
  background: rgba(0, 0, 0, 0.4);
  display: flex;
  align-items: flex-start;
  justify-content: center;
  padding-top: 15vh;
  cursor: pointer;
}
.spotlight-transition-enter {
  transition: opacity 150ms ease-out;
}
.spotlight-transition-enter-start {
  opacity: 0;
}
.spotlight-transition-enter-end {
  opacity: 1;
}
.spotlight-transition-leave {
  transition: opacity 100ms ease-in;
}
.spotlight-transition-leave-start {
  opacity: 1;
}
.spotlight-transition-leave-end {
  opacity: 0;
}
@media (max-width: 767px) {
  .spotlight-overlay {
    padding-top: var(--space-4);
    align-items: flex-start;
  }
}
.spotlight-panel {
  cursor: default;
  width: 100%;
  max-width: 560px;
  margin: 0 var(--space-4);
  background: var(--color-bg);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-xl, 16px);
  box-shadow: 0 20px 60px rgba(0, 0, 0, 0.3);
  overflow: hidden;
}
.spotlight-input-wrap {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-3) var(--space-4);
  border-bottom: 1px solid var(--color-border);
}
.spotlight-input-wrap svg {
  color: var(--color-text-muted);
  flex-shrink: 0;
}
.spotlight-input {
  flex: 1;
  border: none;
  background: transparent;
  font-size: var(--text-base);
  color: var(--color-text);
  outline: none;
}
.spotlight-input::-moz-placeholder {
  color: var(--color-text-muted);
}
.spotlight-input::placeholder {
  color: var(--color-text-muted);
}
.spotlight-close-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
  flex-shrink: 0;
  border: none;
  background: transparent;
  color: var(--color-text-muted);
  border-radius: var(--radius-md, 8px);
  cursor: pointer;
  transition: background-color var(--transition-fast), color var(--transition-fast);
  -webkit-tap-highlight-color: transparent;
}
.spotlight-close-btn:hover {
  background: var(--color-bg-secondary);
  color: var(--color-text);
}
.spotlight-close-btn:active {
  background: var(--color-border);
}
.spotlight-filters {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  padding: var(--space-2) var(--space-4);
  border-bottom: 1px solid var(--color-border);
}
.spotlight-filter-chip {
  display: inline-flex;
  align-items: center;
  padding: 4px 10px;
  font-size: 12px;
  font-weight: 500;
  color: var(--color-text-muted);
  background: var(--color-bg-secondary);
  border: 1px solid var(--color-border);
  border-radius: 999px;
  cursor: pointer;
  transition: background-color var(--transition-fast), color var(--transition-fast), border-color var(--transition-fast);
  -webkit-tap-highlight-color: transparent;
}
.spotlight-filter-chip:hover {
  background: var(--color-border);
  color: var(--color-text);
}
.spotlight-filter-chip--active {
  background: var(--color-primary, #2563eb);
  color: #fff;
  border-color: var(--color-primary, #2563eb);
}
.spotlight-filter-chip--active:hover {
  background: var(--color-primary-hover, #1d4ed8);
  border-color: var(--color-primary-hover, #1d4ed8);
}
.spotlight-loading {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  padding: var(--space-3) var(--space-4);
  color: var(--color-text-muted);
  font-size: var(--text-sm);
}
.spotlight-loading-dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--color-text-muted);
  animation: spotlight-pulse 1s ease-in-out infinite;
}
.spotlight-loading-dot:nth-child(2) {
  animation-delay: 0.15s;
}
.spotlight-loading-dot:nth-child(3) {
  animation-delay: 0.3s;
}
@keyframes spotlight-pulse {
  0%, 100% {
    opacity: 0.3;
  }
  50% {
    opacity: 1;
  }
}
.spotlight-error {
  padding: var(--space-3) var(--space-4);
  text-align: center;
  color: #ef4444;
  font-size: var(--text-sm);
  font-weight: 500;
  background: rgba(239, 68, 68, 0.1);
  border-top: 1px solid rgba(239, 68, 68, 0.2);
}
.dark .spotlight-error {
  color: #fca5a5;
  background: rgba(239, 68, 68, 0.15);
}
.spotlight-results {
  max-height: 360px;
  overflow-y: auto;
  padding: var(--space-2) 0;
}
.spotlight-result {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-2) var(--space-4);
  text-decoration: none;
  color: var(--color-text);
  cursor: pointer;
  transition: background-color var(--transition-fast);
}
.spotlight-result:hover, .spotlight-result--active {
  background: var(--color-bg-secondary);
}
.spotlight-result-icon {
  font-size: 16px;
  flex-shrink: 0;
  width: 24px;
  text-align: center;
}
.spotlight-result-text {
  flex: 1;
  min-width: 0;
}
.spotlight-result-title {
  display: block;
  font-size: var(--text-sm);
  font-weight: 500;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.spotlight-result-sub {
  display: block;
  font-size: 12px;
  color: var(--color-text-muted);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.spotlight-result-type {
  font-size: 10px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  color: var(--color-text-muted);
  flex-shrink: 0;
}
.spotlight-empty {
  padding: var(--space-4);
  text-align: center;
  color: var(--color-text-muted);
  font-size: var(--text-sm);
}
.spotlight-footer {
  display: flex;
  gap: var(--space-4);
  padding: var(--space-2) var(--space-4);
  border-top: 1px solid var(--color-border);
  font-size: 11px;
  color: var(--color-text-muted);
}
.spotlight-footer kbd {
  display: inline-block;
  padding: 1px 4px;
  background: var(--color-bg-secondary);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
  font-family: var(--font-sans);
  font-size: 10px;
  margin-right: 2px;
}
@media (max-width: 767px) {
  .spotlight-footer {
    display: none;
  }
}
.spotlight-section-label {
  padding: var(--space-1) var(--space-4);
  font-size: 10px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  color: var(--color-text-muted);
}
.spotlight-actions {
  padding: var(--space-1) 0;
  border-bottom: 1px solid var(--color-border);
}
.spotlight-result--action .spotlight-result-type {
  color: var(--color-success, #22c55e);
  font-weight: 700;
}
.spotlight-ai {
  border-top: 1px solid var(--color-border);
  padding: var(--space-1) 0 var(--space-2);
}
.spotlight-ai-content {
  padding: var(--space-2) var(--space-4);
  font-size: var(--text-sm);
  color: var(--color-text);
  line-height: 1.5;
  max-height: 200px;
  overflow-y: auto;
}
.spotlight-ai-content strong {
  font-weight: 600;
}
.spotlight-ai-loading {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  padding: var(--space-2) var(--space-4);
  color: var(--color-primary, #2563eb);
  font-size: var(--text-sm);
  border-top: 1px solid var(--color-border);
}
.spotlight-ai-loading .spotlight-loading-dot {
  background: var(--color-primary, #2563eb);
}
.termine-header {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  margin-bottom: var(--space-4);
}
@media (min-width: 768px) {
  .termine-header {
    flex-direction: row;
    align-items: flex-start;
    justify-content: space-between;
  }
}
.termine-nav {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--space-3);
}
.termine-filter-chips {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  align-items: center;
}
.termine-filter-chip {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  padding: 0 16px;
  height: 34px;
  box-sizing: border-box;
  font-size: 13px;
  font-weight: 500;
  border: 1.5px solid var(--color-border, #d1d5db);
  border-radius: var(--radius-full, 9999px);
  background: var(--color-bg, #fff);
  color: var(--color-text-secondary, #6b7280);
  cursor: pointer;
  transition: all 0.18s ease;
  -webkit-tap-highlight-color: transparent;
  white-space: nowrap;
  -webkit-user-select: none;
     -moz-user-select: none;
          user-select: none;
  letter-spacing: 0.01em;
}
.termine-filter-chip:hover {
  border-color: var(--color-text-secondary, #9ca3af);
  color: var(--color-text, #1d1d1f);
  background: var(--color-bg-secondary, #f5f5f7);
}
.termine-filter-chip:active {
  transform: scale(0.96);
}
.termine-filter-chip--active {
  font-weight: 600;
}
.termine-filter-chip--active.termine-filter-chip--alle {
  background: var(--color-text, #1d1d1f);
  border-color: var(--color-text, #1d1d1f);
  color: white;
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.12);
}
.termine-filter-chip--active.termine-filter-chip--alle:hover {
  background: #333;
  border-color: #333;
}
.termine-filter-chip--ws.termine-filter-chip--active {
  background: var(--color-dept-ws);
  border-color: var(--color-dept-ws);
  color: white;
  box-shadow: 0 1px 4px rgba(0, 0, 0, 0.15);
}
.termine-filter-chip--ws.termine-filter-chip--active .termine-filter-dot {
  background: white;
}
.termine-filter-chip--vk.termine-filter-chip--active {
  background: var(--color-dept-vk);
  border-color: var(--color-dept-vk);
  color: white;
  box-shadow: 0 1px 4px rgba(0, 0, 0, 0.15);
}
.termine-filter-chip--vk.termine-filter-chip--active .termine-filter-dot {
  background: white;
}
.termine-filter-chip--ws:not(.termine-filter-chip--active) .termine-filter-dot {
  background: var(--color-dept-ws);
}
.termine-filter-chip--vk:not(.termine-filter-chip--active) .termine-filter-dot {
  background: var(--color-dept-vk);
}
.termine-filter-dot {
  display: inline-block;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  flex-shrink: 0;
}
.termine-dept-dot--ws {
  background: var(--color-dept-ws);
}
.termine-dept-dot--vk {
  background: var(--color-dept-vk);
}
.termine-type-pill--ws {
  background: var(--color-dept-ws);
  color: white;
}
.termine-type-pill--vk {
  background: var(--color-dept-vk);
  color: white;
}
.termine-type-pill--pf {
  background: #8B5CF6;
  color: white;
}
.termine-type-pill--notiz-vk {
  background: var(--color-dept-vk);
  color: white;
}
.termine-type-pill--notiz-ws {
  background: var(--color-dept-ws);
  color: white;
}
.termine-note-staff-pill {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 26px;
  height: 20px;
  padding: 0 5px;
  border-radius: 10px;
  font-size: 0.65rem;
  font-weight: 700;
  letter-spacing: 0.02em;
  color: white;
  background: var(--pill-color, var(--color-dept-vk));
  flex-shrink: 0;
  line-height: 1;
}
.termine-note-staff-pill--both {
  background: linear-gradient(135deg, var(--pill-color) 50%, var(--pill-color-2) 50%);
}
.termine-note-staff-pill--sm {
  min-width: 20px;
  height: 16px;
  padding: 0 4px;
  font-size: 0.58rem;
}
.termine-week-badge--ws {
  background: var(--color-dept-ws);
  @supports (color: color-mix(in lab, red, red)) {
    background: color-mix(in srgb, var(--color-dept-ws) 12%, transparent);
  }
  color: var(--color-dept-ws);
}
.termine-week-badge--vk {
  background: var(--color-dept-vk);
  @supports (color: color-mix(in lab, red, red)) {
    background: color-mix(in srgb, var(--color-dept-vk) 12%, transparent);
  }
  color: var(--color-dept-vk);
}
.termine-week-dot--ws {
  background: var(--color-dept-ws);
}
.termine-week-dot--vk {
  background: var(--color-dept-vk);
}
.termine-week-dot--pf {
  background: #8B5CF6;
}
.termine-tabs {
  display: flex;
  background: var(--color-bg-secondary);
  border-radius: var(--radius-lg);
  padding: 2px;
}
.termine-tab {
  padding: var(--space-2) var(--space-3);
  border: none;
  background: transparent;
  border-radius: var(--radius-md);
  font-size: var(--text-sm);
  font-weight: 500;
  color: var(--color-text-secondary);
  cursor: pointer;
  transition: all var(--transition-fast);
}
.termine-tab.active {
  background: var(--color-bg);
  color: var(--color-text);
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
}
.termine-date-nav {
  display: flex;
  align-items: center;
  gap: var(--space-2);
}
.termine-nav-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  min-height: 36px;
  border: 1px solid var(--color-border);
  background: var(--color-bg);
  border-radius: var(--radius-md);
  cursor: pointer;
  color: var(--color-text);
  transition: background-color var(--transition-fast);
  -webkit-appearance: none;
}
.termine-nav-btn:hover {
  background: var(--color-bg-secondary);
}
.termine-nav-btn:disabled {
  opacity: 0.4;
  cursor: default;
}
.termine-today-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 36px;
  min-height: 36px;
  padding: 0 var(--space-3);
  border: 1px solid var(--color-border);
  background: var(--color-bg);
  border-radius: var(--radius-md);
  font-size: var(--text-sm);
  font-weight: 500;
  cursor: pointer;
  color: var(--color-text);
  transition: background-color var(--transition-fast);
  -webkit-appearance: none;
}
.termine-today-btn:hover {
  background: var(--color-bg-secondary);
}
.termine-datepicker-wrap {
  position: relative;
  display: flex;
  align-items: center;
  height: 36px;
  min-height: 36px;
  padding: 0 var(--space-3);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  background: var(--color-bg);
  cursor: pointer;
  -webkit-appearance: none;
}
.termine-datepicker-label {
  font-size: var(--text-sm);
  font-weight: 500;
  color: var(--color-text);
  white-space: nowrap;
  pointer-events: none;
}
.termine-datepicker-input {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  opacity: 0;
  cursor: pointer;
  z-index: 1;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  border: 0;
  padding: 0;
  margin: 0;
  font-size: 16px;
}
.termine-datepicker-wrap:hover {
  background: var(--color-bg-secondary);
}
.termine-compact-stats {
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin-bottom: 12px;
}
.termine-compact-stats-row {
  border: 1px solid var(--color-border, #e5e7eb);
  border-radius: var(--radius-xl, 16px);
  background: var(--color-bg, #fff);
  overflow: hidden;
  box-shadow: 0 1px 3px rgba(0,0,0,0.04);
}
.termine-compact-stats-header {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 8px 14px;
  border-bottom: 1px solid var(--color-border, #e5e7eb);
}
.termine-compact-stats-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  flex-shrink: 0;
}
.termine-compact-stats-label {
  font-size: 12px;
  font-weight: 600;
  color: var(--color-text, #1d1d1f);
}
.termine-compact-stats-next {
  margin-left: auto;
  font-size: 11px;
  font-weight: 500;
  color: var(--color-text-secondary, #6b7280);
}
.termine-compact-stats-grid {
  display: flex;
  align-items: stretch;
}
.termine-compact-stat {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 10px 6px;
  text-align: center;
  border-right: 1px solid var(--color-border, #e5e7eb);
}
.termine-compact-stat:last-child {
  border-right: none;
}
.termine-compact-stat-value {
  font-size: 16px;
  font-weight: 700;
  color: var(--color-text, #1d1d1f);
  line-height: 1.2;
}
.termine-compact-stat-label {
  font-size: 10px;
  font-weight: 500;
  color: var(--color-text-secondary, #6b7280);
  margin-top: 2px;
  white-space: nowrap;
}
.termine-team-bar {
  padding: 12px 0;
  margin-bottom: var(--space-3);
  border-bottom: 1px solid var(--color-border, #e5e7eb);
}
.termine-team-bar-header {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 8px;
}
.termine-team-bar-title {
  font-size: 11px;
  font-weight: 600;
  color: var(--color-text-secondary);
  text-transform: uppercase;
  letter-spacing: 0.5px;
}
.termine-team-bar-dept {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 6px;
}
.termine-team-bar-dept:last-child {
  margin-bottom: 0;
}
.termine-team-bar-dept-label {
  font-size: 11px;
  font-weight: 600;
  color: var(--color-text-secondary);
  text-transform: uppercase;
  letter-spacing: 0.3px;
  min-width: 72px;
  flex-shrink: 0;
}
.termine-team-pills-row {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  align-items: center;
}
.termine-team-pill {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
  padding: 0;
  border-radius: var(--radius-full, 9999px);
  color: white;
  font-size: 11px;
  font-weight: 700;
  cursor: default;
  transition: transform 0.1s ease;
  -webkit-tap-highlight-color: transparent;
  border: none;
  box-sizing: border-box;
  flex-shrink: 0;
  overflow: hidden;
}
.termine-team-pill:hover {
  transform: scale(1.05);
}
.termine-team-pill--lg {
  width: 36px;
  height: 36px;
  font-size: 12px;
  padding: 0;
}
.termine-team-pill--absent {
  background: transparent !important;
  border: 2px solid;
  opacity: 0.8;
  width: auto;
  min-width: 32px;
  height: auto;
  min-height: 32px;
  padding: 4px 10px;
  border-radius: 16px;
  gap: 4px;
  overflow: visible;
}
.termine-team-absent-range-day {
  font-size: 10px;
  font-weight: 400;
  opacity: 0.7;
  white-space: nowrap;
}
.termine-team-pill-initials {
  line-height: 1;
}
.termine-loading, .termine-empty {
  padding: var(--space-8);
  text-align: center;
  color: var(--color-text-muted);
  font-size: var(--text-sm);
}
.termine-list {
  display: flex;
  flex-direction: column;
  gap: 1px;
  background: var(--color-border);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-xl, 16px);
  overflow: hidden;
}
.termine-item {
  display: flex;
  align-items: flex-start;
  gap: var(--space-3);
  padding: var(--space-3) var(--space-4);
  background: var(--color-bg);
  transition: background-color var(--transition-fast);
  cursor: pointer;
}
.termine-item:hover {
  background: var(--color-bg-secondary);
}
.termine-item-time {
  font-size: var(--text-sm);
  font-weight: 700;
  color: var(--color-primary);
  min-width: 48px;
  flex-shrink: 0;
  padding-top: 2px;
}
.termine-item-content {
  flex: 1;
  min-width: 0;
}
.termine-item-name {
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--color-text);
}
.termine-item-detail {
  font-size: 12px;
  color: var(--color-text-muted);
  margin-top: 2px;
}
.termine-item-notes {
  font-size: 11px;
  color: var(--color-text-muted);
  margin-top: 4px;
  font-style: italic;
}
.termine-item-meta {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 4px;
  flex-shrink: 0;
}
.termine-item-aw {
  font-size: 11px;
  color: var(--color-text-muted);
  font-weight: 500;
}
.termine-type-pill {
  font-size: 10px;
  padding: 1px 6px;
  font-weight: 700;
  border-radius: var(--radius-full, 9999px);
}
.termine-action-btn--confirm {
  color: #059669;
}
.termine-action-btn--confirm:hover {
  background: #d1fae5;
}
.termine-action-btn--complete {
  color: #2563eb;
}
.termine-action-btn--complete:hover {
  background: #dbeafe;
}
.termine-action-btn--cancel {
  color: #dc2626;
}
.termine-action-btn--cancel:hover {
  background: #fee2e2;
}
.termine-action-btn--noshow {
  color: #9333ea;
}
.termine-action-btn--noshow:hover {
  background: #f3e8ff;
}
.termine-action-btn--edit {
  color: #6366f1;
}
.termine-action-btn--edit:hover {
  background: #e0e7ff;
}
.termine-edit-date-range {
  display: flex;
  align-items: center;
  gap: 8px;
}
.termine-edit-date-range .input {
  flex: 1;
}
.termine-week {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 1px;
  background: var(--color-border);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-xl, 16px);
  overflow: hidden;
}
@media (max-width: 767px) {
  .termine-week {
    grid-template-columns: 1fr;
  }
}
.termine-week-day {
  background: var(--color-bg);
  min-height: 120px;
  display: flex;
  flex-direction: column;
}
.termine-week-day--today {
  background: var(--color-bg-secondary);
}
.termine-week-day-header {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-2) var(--space-3);
  border-bottom: 1px solid var(--color-border);
  font-size: var(--text-sm);
}
.termine-week-day-name {
  font-weight: 600;
  color: var(--color-text);
}
.termine-week-day-date {
  color: var(--color-text-muted);
  font-size: 12px;
}
.termine-week-day-count {
  margin-left: auto;
  background: var(--color-primary);
  color: #fff;
  font-size: 10px;
  font-weight: 600;
  padding: 1px 5px;
  border-radius: var(--radius-full);
}
.termine-week-type-badge {
  font-size: 9px;
  font-weight: 600;
  padding: 1px 5px;
  border-radius: var(--radius-full, 9999px);
  margin-left: auto;
}
.termine-week-type-badge + .termine-week-type-badge {
  margin-left: 0;
}
.termine-week-day-body {
  padding: var(--space-2);
  flex: 1;
  display: flex;
  flex-direction: column;
}
.termine-week-item {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  padding: 3px var(--space-2);
  border-radius: var(--radius-sm);
  font-size: 11px;
  margin-bottom: 2px;
  cursor: pointer;
}
.termine-week-item:hover {
  background: var(--color-bg-secondary);
}
.termine-week-type-dot {
  display: inline-block;
  width: 6px;
  height: 6px;
  border-radius: 50%;
  flex-shrink: 0;
}
.termine-week-item-time {
  font-weight: 600;
  color: var(--color-primary);
  min-width: 32px;
}
.termine-week-item-name {
  color: var(--color-text);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.termine-week-empty {
  text-align: center;
  color: var(--color-text-muted);
  font-size: 11px;
  padding: var(--space-2);
  flex: 1;
}
.termine-item-wrap {
  background: var(--color-bg);
}
.termine-item-chevron {
  flex-shrink: 0;
  color: var(--color-text-muted);
  transition: transform var(--transition-fast);
  align-self: center;
}
.termine-item-chevron--open {
  transform: rotate(180deg);
}
.termine-detail-enter {
  transition: all 0.2s ease-out;
}
.termine-detail-enter-start {
  opacity: 0;
  max-height: 0;
  overflow: hidden;
}
.termine-detail-enter-end {
  opacity: 1;
  max-height: 500px;
}
.termine-detail-leave {
  transition: all 0.15s ease-in;
}
.termine-detail-leave-start {
  opacity: 1;
  max-height: 500px;
}
.termine-detail-leave-end {
  opacity: 0;
  max-height: 0;
  overflow: hidden;
}
.termine-detail {
  padding: 0 var(--space-4) var(--space-4);
  background: var(--color-bg-secondary);
  border-top: 1px solid var(--color-border);
}
.termine-detail-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
  gap: var(--space-3);
  padding-top: var(--space-3);
}
.termine-detail-field {
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.termine-detail-label {
  font-size: 11px;
  font-weight: 500;
  color: var(--color-text-muted);
  text-transform: uppercase;
  letter-spacing: 0.5px;
}
.termine-detail-value {
  font-size: var(--text-sm);
  color: var(--color-text);
}
.termine-detail-link {
  color: var(--color-primary);
  text-decoration: none;
  font-weight: 500;
}
.termine-detail-link:hover {
  text-decoration: underline;
}
.termine-detail-notes {
  margin-top: var(--space-3);
  padding: var(--space-3);
  background: var(--color-bg);
  border-radius: var(--radius-md);
  font-size: var(--text-sm);
}
.termine-detail-notes p {
  margin: var(--space-1) 0 0;
  color: var(--color-text);
  font-style: italic;
}
.termine-detail-actions {
  display: flex;
  gap: var(--space-2);
  margin-top: var(--space-3);
  flex-wrap: wrap;
}
.termine-action-btn {
  display: inline-flex;
  align-items: center;
  gap: var(--space-1);
  padding: var(--space-2) var(--space-3);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  background: var(--color-bg);
  color: var(--color-text);
  font-size: var(--text-xs);
  font-weight: 500;
  cursor: pointer;
  text-decoration: none;
  transition: all var(--transition-fast);
}
.termine-action-btn:hover {
  border-color: var(--color-primary);
  color: var(--color-primary);
  background: rgba(11, 60, 93, 0.04);
}
.termine-action-btn svg {
  width: 14px;
  height: 14px;
  flex-shrink: 0;
}
.widget-status--sm {
  font-size: 9px;
  padding: 1px 4px;
  margin-left: auto;
}
.termine-completion-pills {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.termine-completion-pill {
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
  min-width: 40px;
  height: 40px;
  padding: 0 12px;
  border: 2px solid #6B7280;
  border-radius: var(--radius-full, 9999px) !important;
  background: transparent;
  font-size: 13px;
  font-weight: 700;
  cursor: pointer;
  transition: all 0.15s ease;
  -webkit-tap-highlight-color: transparent;
  -webkit-user-select: none;
     -moz-user-select: none;
          user-select: none;
  box-sizing: border-box;
  line-height: 1;
}
.termine-completion-pill:hover {
  transform: scale(1.05);
  opacity: 1;
}
.termine-completion-pill:active {
  transform: scale(0.95);
}
.termine-completion-pill--active {
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.2);
}
.termine-team-pill[style*="--pill-color"] {
  background: var(--pill-color);
}
.termine-team-pill--absent[style*="--pill-color"] {
  border-color: var(--pill-color);
  color: var(--pill-color);
}
.termine-completion-pill--active[style*="--pill-color"] {
  background: var(--pill-color);
  border-color: var(--pill-color);
  color: white;
}
.termine-completion-pill:not(.termine-completion-pill--active)[style*="--pill-color"] {
  border-color: var(--pill-color);
  color: var(--pill-color);
}
.termine-week-team-pill[style*="--pill-color"] {
  background: var(--pill-color);
}
.termine-week-team-pill-absent-wide[style*="--pill-color"] {
  border-color: var(--pill-color);
  color: var(--pill-color);
  background: var(--pill-color);
  @supports (color: color-mix(in lab, red, red)) {
    background: color-mix(in srgb, var(--pill-color) 12%, transparent);
  }
}
.termine-outcome-pills {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-top: var(--space-2);
}
.termine-outcome-pill {
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
  padding: 0 16px;
  height: 44px;
  font-size: 13px;
  font-weight: 500;
  border: 1.5px solid var(--color-border, #d1d5db);
  border-radius: var(--radius-full, 9999px) !important;
  background: var(--color-bg-secondary, #f5f5f7);
  color: var(--color-text-secondary, #6b7280);
  cursor: pointer;
  transition: all 0.15s ease;
  -webkit-tap-highlight-color: transparent;
  -webkit-user-select: none;
     -moz-user-select: none;
          user-select: none;
  box-sizing: border-box;
  line-height: 1;
}
.termine-outcome-pill:hover {
  border-color: var(--color-text-secondary);
  color: var(--color-text);
}
.termine-outcome-pill--selected {
  background: var(--color-primary, #0b3c5d) !important;
  border-color: var(--color-primary, #0b3c5d) !important;
  color: white !important;
}
.termine-outcome-pill--selected:hover {
  background: var(--color-primary-hover, var(--color-primary, #0b3c5d)) !important;
  border-color: var(--color-primary-hover, var(--color-primary, #0b3c5d)) !important;
  color: white !important;
}
.termine-outcome-badge {
  font-size: 11px;
  font-weight: 600;
}
.termine-outcome-badge--angebot {
  background: rgba(59, 130, 246, 0.15);
  color: #3B82F6;
}
.termine-outcome-badge--auftragsbestaetigung {
  background: rgba(16, 185, 129, 0.15);
  color: #10B981;
}
.termine-outcome-badge--kommt_wieder {
  background: rgba(245, 158, 11, 0.15);
  color: #F59E0B;
}
.termine-outcome-badge--keine_aktion {
  background: rgba(107, 114, 128, 0.15);
  color: #6B7280;
}
.termine-week-team {
  display: flex;
  flex-wrap: wrap;
  gap: 3px;
  padding: 12px var(--space-2) 4px;
  border-top: 1px solid var(--color-border, #e5e7eb);
  margin-top: auto;
}
.termine-week-team-absent {
  display: flex;
  flex-wrap: wrap;
  gap: 3px;
  padding: 2px var(--space-2) 2px;
}
.termine-week-team-pill {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 22px;
  height: 22px;
  border-radius: 50%;
  color: white;
  font-size: 8px;
  font-weight: 700;
  flex-shrink: 0;
  line-height: 1;
}
.termine-week-team-pill--absent {
  background: transparent !important;
  border: 1.5px solid;
  opacity: 0.7;
}
.termine-week-team-pill-absent-wide {
  display: inline-flex;
  align-items: center;
  gap: 3px;
  padding: 2px 6px;
  border-radius: 10px;
  border: 1.5px solid;
  background: transparent;
  font-size: 10px;
  font-weight: 600;
  opacity: 0.9;
  white-space: nowrap;
  line-height: 1.3;
  height: auto;
}
.termine-week-absent-range {
  font-size: 9px;
  font-weight: 400;
  opacity: 0.7;
}
@media (max-width: 767px) {
  .termine-week-team-pill-absent-wide {
    font-size: 10px;
    padding: 2px 6px;
  }
}
.termine-week-closure-item {
  display: flex;
  align-items: center;
  gap: 4px;
  padding: 3px var(--space-2);
  font-size: 10px;
  font-weight: 600;
  color: var(--color-text-secondary, #6b7280);
  background: rgba(239, 68, 68, 0.06);
  border-radius: var(--radius-sm);
  margin-bottom: 2px;
}
.termine-week-closure-title {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.termine-week-day--closed {
  background: var(--color-bg-secondary, #f5f5f7);
}
.termine-closure-banner {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 10px 16px;
  margin-bottom: var(--space-3);
  background: rgba(239, 68, 68, 0.06);
  border: 1px solid rgba(239, 68, 68, 0.15);
  border-radius: var(--radius-xl, 16px);
  font-size: 13px;
  font-weight: 600;
  color: var(--color-text, #1d1d1f);
}
.termine-filter-chip svg {
  flex-shrink: 0;
}
.termine-transfer-section {
  margin-top: var(--space-6);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-xl);
  background: var(--color-bg);
  overflow: visible;
}
.termine-transfer-toggle {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  padding: 14px 20px;
  background: none;
  border: none;
  cursor: pointer;
  font-size: 14px;
  font-weight: 600;
  color: var(--color-text);
}
.termine-transfer-toggle:hover {
  background: var(--color-bg-secondary);
}
.termine-transfer-toggle-inner {
  display: flex;
  align-items: center;
  gap: 8px;
}
.termine-transfer-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 20px;
  height: 20px;
  padding: 0 6px;
  border-radius: 10px;
  background: #ef4444;
  color: #fff;
  font-size: 11px;
  font-weight: 700;
}
.termine-transfer-chevron {
  transition: transform 0.2s ease;
  flex-shrink: 0;
}
.termine-transfer-chevron--open {
  transform: rotate(180deg);
}
.termine-transfer-body {
  border-top: 1px solid var(--color-border);
  padding: 16px 20px;
}
.termine-search-bar {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 12px;
  flex-wrap: wrap;
}
.termine-search-wrap {
  display: flex;
  align-items: center;
  gap: 8px;
  flex: 1;
  min-width: 140px;
  max-width: 320px;
  padding: 5px 12px;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md, 6px);
  background: var(--color-bg);
  transition: border-color 0.15s;
}
.termine-search-wrap:focus-within {
  border-color: var(--color-primary, #3b82f6);
}
.termine-search-wrap svg {
  flex-shrink: 0;
  opacity: 0.4;
}
.termine-search-input, .termine-search-input[type="text"] {
  flex: 1;
  border: none !important;
  outline: none !important;
  box-shadow: none !important;
  -webkit-appearance: none;
  background: transparent !important;
  font-size: 13px;
  color: var(--color-text);
  min-width: 0;
  min-height: unset;
  padding: 2px 0;
  border-radius: 0;
  width: auto;
  display: inline;
}
.termine-search-input::-moz-placeholder {
  color: var(--color-text-muted, #9ca3af);
}
.termine-search-input::placeholder {
  color: var(--color-text-muted, #9ca3af);
}
.termine-search-clear {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 2px;
  border: none;
  background: none;
  cursor: pointer;
  color: var(--color-text-muted);
  border-radius: 50%;
}
.termine-search-clear:hover {
  color: var(--color-text);
  background: var(--color-bg-secondary);
}
.termine-search-count {
  font-size: 12px;
  color: var(--color-text-muted);
  white-space: nowrap;
}
.termine-datepicker-wrap--compact {
  position: relative;
  cursor: pointer;
}
.termine-datepicker-wrap--compact .termine-datepicker-label {
  font-size: 0.85rem;
  font-weight: 500;
  color: var(--color-text);
  margin-left: 6px;
  white-space: nowrap;
}
.termine-datepicker-wrap--compact .termine-datepicker-input {
  position: absolute;
  inset: 0;
  opacity: 0;
  cursor: pointer;
  width: 100%;
}
.termine-transfer-date-filter {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 12px;
}
.termine-date-nav--compact {
  display: flex;
  align-items: center;
  gap: 4px;
}
.termine-transfer-date-label {
  font-size: 0.85rem;
  font-weight: 500;
  color: var(--color-text);
  margin-left: 6px;
  white-space: nowrap;
}
.termine-transfer-controls {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 12px;
  flex-wrap: wrap;
}
.termine-transfer-search-wrap {
  display: flex;
  align-items: center;
  gap: 8px;
  flex: 1;
  min-width: 180px;
  padding: 6px 12px;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  background: var(--color-bg);
}
.termine-transfer-search-wrap svg {
  flex-shrink: 0;
  opacity: 0.4;
}
.termine-transfer-search {
  flex: 1;
  border: none;
  outline: none;
  background: transparent;
  font-size: 13px;
  color: var(--color-text);
}
.termine-transfer-toggle-label {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 12px;
  color: var(--color-text-muted);
  cursor: pointer;
  white-space: nowrap;
}
.termine-transfer-refresh {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  background: none;
  cursor: pointer;
  color: var(--color-text-muted);
}
.termine-transfer-refresh:hover {
  background: var(--color-bg-secondary);
}
.termine-transfer-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-top: 12px;
  padding-top: 12px;
  border-top: 1px solid var(--color-border);
}
.termine-pill--vortag {
  background: var(--color-warning);
  color: white;
  font-size: 10px;
  padding: 1px 6px;
}
.termine-pill--vortag-ok {
  background: var(--color-success);
  color: white;
  font-size: 10px;
  padding: 1px 6px;
}
.termine-pill--manuell {
  background: #8b5cf6;
  color: white;
  font-size: 10px;
  padding: 1px 6px;
}
.termine-pill--override {
  background: var(--color-error, #dc2626);
  color: white;
  font-size: 10px;
  padding: 1px 6px;
  display: inline-flex;
  align-items: center;
  gap: 3px;
  cursor: help;
}
.termine-pill--override svg {
  flex-shrink: 0;
}
.dark .termine-pill--override, [data-theme="dark"] .termine-pill--override {
  background: #991b1b;
  color: #fecaca;
}
.termine-crm-pill {
  font-size: 10px;
  font-weight: 600;
  padding: 1px 6px;
  border-radius: var(--radius-full);
  color: #fff;
}
.termine-crm-pill--vorhanden {
  background: #22c55e;
}
.termine-crm-pill--neu {
  background: #dc2626;
}
.termine-crm-pill--veloport {
  background: #3b82f6;
  font-size: 9px;
}
.dark .termine-crm-pill--vorhanden, [data-theme="dark"] .termine-crm-pill--vorhanden {
  background: #16a34a;
}
.dark .termine-crm-pill--neu, [data-theme="dark"] .termine-crm-pill--neu {
  background: #b91c1c;
}
.dark .termine-crm-pill--veloport, [data-theme="dark"] .termine-crm-pill--veloport {
  background: #2563eb;
}
.termine-pill--kundennotiz {
  background: var(--color-error, #ef4444);
  color: white;
  font-size: 10px;
  font-weight: 700;
  padding: 1px 5px;
  border-radius: 9999px;
  flex-shrink: 0;
}
.dark .termine-pill--kundennotiz, [data-theme="dark"] .termine-pill--kundennotiz {
  background: var(--color-error, #dc2626);
  color: white;
}
.termine-pill--vortag-sm {
  background: var(--color-warning);
  color: white;
  font-size: 8px;
  padding: 0 4px;
  flex-shrink: 0;
}
.termine-pill--vortag-ok-sm {
  background: var(--color-success);
  color: white;
  font-size: 8px;
  padding: 0 4px;
  flex-shrink: 0;
}
.termine-week-item-inner {
  display: flex;
  align-items: center;
  gap: 4px;
  flex: 1;
  min-width: 0;
}
.termine-week-closure-emoji {
  font-size: 11px;
  line-height: 1;
}
.wp-transfer-td--flash {
  animation: cell-flash 0.4s ease;
}
@keyframes cell-flash {
  0% {
    background: var(--color-primary, #d4a574);
    color: #fff;
  }
  100% {
    background: inherit;
    color: inherit;
  }
}
.termine-item-name-row {
  display: flex;
  align-items: center;
  gap: 6px;
}
.termine-detail-photos-grid {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  margin-top: 6px;
}
.termine-detail-photo-thumb {
  width: 56px;
  height: 56px;
  border-radius: 8px;
  overflow: hidden;
  border: 1px solid var(--color-border);
  display: block;
  flex-shrink: 0;
  cursor: pointer;
}
.termine-detail-photo-img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.termine-detail-field--mt2 {
  margin-top: var(--space-2);
}
.termine-detail-field--mt3 {
  margin-top: var(--space-3);
}
.termine-detail-value--flex {
  display: flex;
  align-items: center;
  gap: 6px;
}
.termine-completion-pill--readonly {
  pointer-events: none;
}
.termine-text-secondary {
  color: var(--color-text-secondary);
}
.dark .termine-text-secondary {
  color: var(--color-text-muted);
}
.termine-modal-intro {
  margin-bottom: var(--space-4);
}
.termine-outcome-error {
  margin-top: 4px;
  color: #ef4444;
}
.dark .termine-outcome-error {
  color: #f87171;
}
.termine-capacity-block {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 10px 14px;
  background: #fef2f2;
  border: 1px solid #fecaca;
  border-radius: var(--radius-md, 8px);
  margin-bottom: 4px;
  flex-wrap: nowrap;
  white-space: nowrap;
}
.termine-capacity-block-icon {
  flex-shrink: 0;
  color: var(--color-error, #dc2626);
}
.termine-capacity-block-label {
  font-weight: 600;
  font-size: 14px;
  color: var(--color-error, #dc2626);
}
.termine-capacity-block-value {
  font-size: 14px;
  color: var(--color-error, #dc2626);
}
.termine-capacity-block-note {
  font-size: 12px;
  color: var(--color-text-secondary, #666);
}
.dark .termine-capacity-block, [data-theme="dark"] .termine-capacity-block {
  background: #451a1a;
  border-color: #7f1d1d;
}
.dark .termine-capacity-block-label, .dark .termine-capacity-block-value, [data-theme="dark"] .termine-capacity-block-label, [data-theme="dark"] .termine-capacity-block-value {
  color: #fca5a5;
}
.dark .termine-capacity-block-icon, [data-theme="dark"] .termine-capacity-block-icon {
  color: #f87171;
}
.termine-week-block-item {
  display: flex;
  align-items: center;
  gap: 4px;
  padding: 3px 6px;
  background: #fef2f2;
  border-radius: 4px;
  color: var(--color-error, #dc2626);
  font-size: 11px;
  font-weight: 600;
  white-space: nowrap;
}
.dark .termine-week-block-item, [data-theme="dark"] .termine-week-block-item {
  background: #451a1a;
  color: #f87171;
}
.kunden-search-bar {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-2) 0;
  background: transparent;
  border: none;
  border-radius: 0;
  margin-bottom: var(--space-3);
}
.kunden-search-bar:focus-within {
  border-color: transparent;
  box-shadow: none;
}
.kunden-search-bar svg {
  color: var(--color-text-muted);
  flex-shrink: 0;
}
.kunden-search-input {
  flex: 1;
  border: none;
  background: transparent;
  font-size: var(--text-base);
  color: var(--color-text);
  outline: none;
}
.kunden-search-input::-moz-placeholder {
  color: var(--color-text-muted);
}
.kunden-search-input::placeholder {
  color: var(--color-text-muted);
}
.kunden-search-count {
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  white-space: nowrap;
}
.kunden-list {
  display: flex;
  flex-direction: column;
  gap: 0;
  background: transparent;
  border: none;
  border-radius: 0;
  overflow: visible;
}
.kunden-card {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-3) var(--space-4);
  background: var(--color-bg);
  text-decoration: none;
  color: var(--color-text);
  transition: background-color var(--transition-fast);
  border-bottom: 1px solid var(--color-border);
}
.kunden-card:last-child {
  border-bottom: none;
}
.kunden-card:hover {
  background: var(--color-bg-secondary);
}
.kunden-card-avatar {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  border-radius: var(--radius-full);
  background: var(--color-primary);
  color: #fff;
  font-size: var(--text-sm);
  font-weight: 700;
  flex-shrink: 0;
}
.kunden-card-avatar--lg {
  width: 48px;
  height: 48px;
  font-size: var(--text-lg);
}
.kunden-card-content {
  flex: 1;
  min-width: 0;
}
.kunden-card-name {
  display: flex;
  align-items: center;
  gap: var(--space-1);
  font-size: var(--text-sm);
  font-weight: 600;
}
.kunden-card-star {
  color: #f59e0b;
  flex-shrink: 0;
}
.kunden-card-meta {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  font-size: 12px;
  color: var(--color-text-muted);
  margin-top: 2px;
}
.kunden-card-meta span:not(:last-child)::after {
  content: '·';
  margin-left: var(--space-2);
}
.kunden-card-chevron {
  color: var(--color-text-muted);
  flex-shrink: 0;
}
.kunden-pagination {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-3);
  margin-top: var(--space-4);
  padding: var(--space-3);
}
.kunden-detail-header {
  margin-bottom: var(--space-4);
}
.kunden-back-btn {
  display: inline-flex;
  align-items: center;
  gap: var(--space-1);
  font-size: var(--text-sm);
  color: var(--color-text-secondary);
  text-decoration: none;
  margin-bottom: var(--space-3);
  transition: color var(--transition-fast);
}
.kunden-back-btn:hover {
  color: var(--color-primary);
}
.kunden-detail-title {
  display: flex;
  align-items: center;
  gap: var(--space-3);
}
.kunden-detail-info {
  flex: 1;
  min-width: 0;
}
.kunden-tabs {
  display: flex;
  gap: 0;
  border-bottom: 1px solid var(--color-border);
  margin-bottom: var(--space-4);
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}
.kunden-tab {
  padding: var(--space-2) var(--space-3);
  border: none;
  background: transparent;
  font-size: var(--text-sm);
  font-weight: 500;
  color: var(--color-text-secondary);
  cursor: pointer;
  white-space: nowrap;
  border-bottom: 2px solid transparent;
  transition: all var(--transition-fast);
}
.kunden-tab.active {
  color: var(--color-primary);
  border-bottom-color: var(--color-primary);
}
.kunden-tab-count {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 18px;
  height: 18px;
  padding: 0 4px;
  border-radius: var(--radius-full);
  background: var(--color-bg-secondary);
  font-size: 10px;
  font-weight: 600;
  margin-left: 4px;
}
.kunden-tab-content {
  min-height: 200px;
}
.kunden-detail-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap: var(--space-3);
  margin-bottom: var(--space-4);
}
.kunden-field {
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.kunden-field-label {
  font-size: 11px;
  font-weight: 500;
  color: var(--color-text-muted);
  text-transform: uppercase;
  letter-spacing: 0.5px;
}
.kunden-field-value {
  font-size: var(--text-sm);
  color: var(--color-text);
}
.kunden-notes {
  padding: var(--space-3);
  background: var(--color-bg-secondary);
  border-radius: var(--radius-md);
  font-size: var(--text-sm);
  color: var(--color-text);
}
.kunden-relation-card {
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: var(--space-3) var(--space-4);
  margin-bottom: var(--space-3);
}
.kunden-relation-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--space-3);
}
.kunden-relation-header strong {
  font-size: var(--text-sm);
}
.kunden-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: var(--space-4);
  margin-bottom: var(--space-5);
}
.kunden-ki-btn {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-2) var(--space-3);
  border: none;
  background: var(--color-accent);
  border-radius: var(--radius-full);
  color: #000;
  font-size: var(--text-sm);
  font-weight: 600;
  cursor: pointer;
  transition: opacity var(--transition-fast);
  white-space: nowrap;
}
.kunden-ki-btn:hover {
  opacity: 0.88;
}
.kunden-quick-info {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  margin-bottom: var(--space-5);
}
.kunden-quick-card {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-2) var(--space-3);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-full);
  background: var(--color-bg);
  color: var(--color-text);
  font-size: var(--text-sm);
  text-decoration: none;
  transition: all var(--transition-fast);
}
.kunden-quick-card:hover {
  border-color: var(--color-primary);
  color: var(--color-primary);
}
.kunden-quick-card svg {
  width: 16px;
  height: 16px;
  flex-shrink: 0;
  color: var(--color-text-muted);
}
.kunden-quick-card:hover svg {
  color: var(--color-primary);
}
.kunden-quick-card--copy {
  cursor: pointer;
  -webkit-user-select: none;
     -moz-user-select: none;
          user-select: none;
}
.kunden-header-actions {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-left: auto;
}
.kunden-edit-actions {
  display: flex;
  gap: 6px;
}
.kunden-edit-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap: 12px;
}
.kunden-edit-field {
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.kunden-edit-field--full {
  margin-top: 12px;
}
.kunden-edit-field .input {
  font-size: 13px;
  padding: 6px 10px;
}
.kunden-edit-field textarea.input {
  resize: vertical;
  min-height: 60px;
}
.kunden-relation-card--edit {
  border: 1px solid var(--color-primary, #3b82f6);
  border-radius: var(--radius-md);
}
.kunden-vehicle-actions {
  display: flex;
  gap: 6px;
}
.kunden-delete-overlay {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: rgba(0, 0, 0, 0.4);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 1000;
}
.kunden-delete-modal {
  background: var(--color-bg, white);
  border-radius: var(--radius-lg, 12px);
  padding: 20px 24px;
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.2);
  max-width: 360px;
  text-align: center;
}
.kunden-delete-modal p + p {
  margin-top: 4px;
}
.kunden-delete-actions {
  display: flex;
  gap: 8px;
  justify-content: center;
  margin-top: 16px;
}
.dark .kunden-delete-overlay {
  background: rgba(0, 0, 0, 0.6);
}
.dark .kunden-delete-modal {
  background: var(--color-bg-secondary, #1f2937);
}
.dark .kunden-relation-card--edit {
  border-color: var(--color-primary, #3b82f6);
}
@media (max-width: 640px) {
  .kunden-edit-grid {
    grid-template-columns: 1fr;
  }
  .kunden-header-actions {
    flex-wrap: wrap;
  }
}
.ki-panel-trigger-icon {
  width: 18px;
  height: 18px;
  flex-shrink: 0;
}
.ki-panel-trigger-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 18px;
  height: 18px;
  padding: 0 5px;
  background: var(--color-accent);
  color: #000;
  font-size: 10px;
  font-weight: 700;
  border-radius: var(--radius-full);
}
.ki-panel-backdrop {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.3);
  z-index: 1000;
  backdrop-filter: blur(2px);
  -webkit-backdrop-filter: blur(2px);
  display: block;
}
.ki-panel {
  position: fixed;
  top: 0;
  right: 0;
  bottom: 0;
  width: 420px;
  max-width: 100vw;
  z-index: 1001;
  display: flex;
  flex-direction: column;
  background: var(--color-bg);
  border-left: 1px solid var(--color-border);
  box-shadow: var(--shadow-xl);
  transform: translateX(100%);
  transition: transform 300ms ease-out;
}
.ki-panel--open {
  transform: translateX(0);
}
@media (max-width: 639px) {
  .ki-panel {
    width: 100vw;
    border-left: none;
    border-radius: 0;
  }
}
.ki-panel-header {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-4) var(--space-5);
  border-bottom: 1px solid var(--color-border);
  background: var(--color-primary);
  color: #fff;
  flex-shrink: 0;
}
.ki-panel-header-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  border-radius: var(--radius-full);
  background: rgba(255, 255, 255, 0.15);
  flex-shrink: 0;
}
.ki-panel-header-title {
  flex: 1;
  min-width: 0;
}
.ki-panel-header-title strong {
  display: block;
  font-size: var(--text-base);
  font-weight: 600;
  line-height: 1.3;
}
.ki-panel-header-title span {
  display: block;
  font-size: var(--text-xs);
  opacity: 0.75;
  line-height: 1.3;
}
.ki-panel-close-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  border: none;
  background: rgba(255, 255, 255, 0.15);
  border-radius: var(--radius-full);
  color: #fff;
  cursor: pointer;
  transition: background-color var(--transition-fast);
  flex-shrink: 0;
  -webkit-tap-highlight-color: transparent;
}
.ki-panel-close-btn:hover {
  background: rgba(255, 255, 255, 0.25);
}
.ki-panel-close-btn:active {
  background: rgba(255, 255, 255, 0.35);
}
.ki-panel-header-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
  border: none;
  background: rgba(255, 255, 255, 0.12);
  border-radius: var(--radius-md);
  color: #fff;
  cursor: pointer;
  transition: background-color var(--transition-fast);
  flex-shrink: 0;
}
.ki-panel-header-btn:hover {
  background: rgba(255, 255, 255, 0.2);
}
.ki-panel-context {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-2) var(--space-5);
  background: var(--color-bg-secondary);
  border-bottom: 1px solid var(--color-border);
  font-size: var(--text-xs);
  color: var(--color-text-muted);
  flex-shrink: 0;
}
.ki-panel-context-tag {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 2px var(--space-2);
  background: var(--color-primary);
  color: #fff;
  border-radius: var(--radius-full);
  font-size: 10px;
  font-weight: 600;
}
.ki-panel-messages {
  flex: 1;
  overflow-y: auto;
  padding: var(--space-4) var(--space-5);
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  scroll-behavior: smooth;
}
.ki-panel-messages::-webkit-scrollbar {
  width: 4px;
}
.ki-panel-messages::-webkit-scrollbar-thumb {
  background: var(--color-border-strong);
  border-radius: var(--radius-full);
}
.ki-msg {
  display: flex;
  gap: var(--space-2);
  max-width: 100%;
}
.ki-msg--user {
  flex-direction: row-reverse;
}
.ki-msg-avatar {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
  border-radius: var(--radius-full);
  background: var(--color-primary);
  color: #fff;
  font-size: 11px;
  font-weight: 700;
  flex-shrink: 0;
  line-height: 1;
}
.ki-msg--user .ki-msg-avatar {
  background: var(--color-accent);
  color: #000;
}
.ki-msg-avatar--ai {
  background: var(--color-bg-secondary);
  padding: 3px;
}
.ki-msg-avatar--ai img {
  width: 22px;
  height: 22px;
  -o-object-fit: contain;
     object-fit: contain;
}
.ki-msg-bubble {
  max-width: calc(100% - 40px);
  padding: var(--space-3) var(--space-4);
  border-radius: var(--radius-lg);
  font-size: var(--text-sm);
  line-height: 1.5;
  word-wrap: break-word;
  overflow-wrap: break-word;
}
.ki-msg--ai .ki-msg-bubble {
  background: var(--color-bg-secondary);
  color: var(--color-text);
  border-bottom-left-radius: var(--radius-sm);
}
.ki-msg--user .ki-msg-bubble {
  background: var(--color-primary);
  color: #fff;
  border-bottom-right-radius: var(--radius-sm);
}
.ki-msg-bubble p {
  margin: 0 0 var(--space-2);
}
.ki-msg-bubble p:last-child {
  margin-bottom: 0;
}
.ki-msg-bubble ul, .ki-msg-bubble ol {
  margin: var(--space-2) 0;
  padding-left: var(--space-5);
}
.ki-msg-bubble li {
  margin-bottom: 4px;
}
.ki-msg-bubble strong {
  font-weight: 600;
}
.ki-msg-bubble code {
  font-family: var(--font-mono);
  font-size: 12px;
  background: rgba(0,0,0,0.08);
  padding: 1px 4px;
  border-radius: 4px;
}
.ki-msg--user .ki-msg-bubble code {
  background: rgba(255,255,255,0.15);
}
.ki-typing {
  display: flex;
  align-items: center;
  gap: 4px;
  padding: var(--space-3) var(--space-4);
  background: var(--color-bg-secondary);
  border-radius: var(--radius-lg);
  border-bottom-left-radius: var(--radius-sm);
  width: -moz-fit-content;
  width: fit-content;
}
.ki-typing-dot {
  width: 6px;
  height: 6px;
  border-radius: var(--radius-full);
  background: var(--color-text-muted);
  animation: ki-bounce 1.2s infinite;
}
.ki-typing-dot:nth-child(2) {
  animation-delay: 0.2s;
}
.ki-typing-dot:nth-child(3) {
  animation-delay: 0.4s;
}
@keyframes ki-bounce {
  0%, 60%, 100% {
    transform: translateY(0);
  }
  30% {
    transform: translateY(-6px);
  }
}
.ki-panel-suggestions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  padding: var(--space-3) var(--space-5);
  border-top: 1px solid var(--color-border);
  flex-shrink: 0;
}
.ki-suggestion {
  padding: var(--space-1) var(--space-3);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-full);
  background: var(--color-bg);
  color: var(--color-text-secondary);
  font-size: var(--text-xs);
  cursor: pointer;
  transition: all var(--transition-fast);
  white-space: nowrap;
}
.ki-suggestion:hover {
  border-color: var(--color-primary);
  color: var(--color-primary);
  background: rgba(11, 60, 93, 0.04);
}
.ki-panel-input-area {
  display: flex;
  align-items: flex-end;
  gap: var(--space-2);
  padding: var(--space-3) var(--space-5);
  border-top: 1px solid var(--color-border);
  background: var(--color-bg);
  flex-shrink: 0;
}
.ki-panel-input {
  flex: 1;
  min-height: 40px;
  max-height: 120px;
  padding: var(--space-2) var(--space-3);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  background: var(--color-bg-secondary);
  color: var(--color-text);
  font-size: var(--text-sm);
  font-family: var(--font-sans);
  resize: none;
  outline: none;
  line-height: 1.5;
  transition: border-color var(--transition-fast);
  overflow-y: auto;
}
.ki-panel-input:focus {
  border-color: var(--color-primary);
  box-shadow: 0 0 0 3px rgba(11, 60, 93, 0.1);
}
.ki-panel-input::-moz-placeholder {
  color: var(--color-text-muted);
}
.ki-panel-input::placeholder {
  color: var(--color-text-muted);
}
.ki-panel-send-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  border: none;
  border-radius: var(--radius-lg);
  background: var(--color-primary);
  color: #fff;
  cursor: pointer;
  transition: opacity var(--transition-fast), transform var(--transition-fast);
  flex-shrink: 0;
}
.ki-panel-send-btn:hover {
  opacity: 0.9;
}
.ki-panel-send-btn:active {
  transform: scale(0.95);
}
.ki-panel-send-btn:disabled {
  opacity: 0.4;
  cursor: default;
}
.ki-panel-empty {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: var(--space-3);
  padding: var(--space-8);
  text-align: center;
  color: var(--color-text-muted);
  flex: 1;
}
.ki-panel-empty-icon {
  width: 48px;
  height: 48px;
  border-radius: var(--radius-full);
  background: var(--color-bg-secondary);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--color-text-muted);
}
.ki-panel-empty p {
  font-size: var(--text-sm);
  margin: 0;
}
.ki-panel-empty strong {
  font-size: var(--text-base);
  color: var(--color-text);
}
.dark .ki-msg--ai .ki-msg-bubble {
  background: rgba(255, 255, 255, 0.06);
}
.dark .ki-panel-input {
  background: rgba(255, 255, 255, 0.06);
}
.dark .ki-suggestion {
  background: rgba(255, 255, 255, 0.04);
}
[x-cloak] {
  display: none !important;
}
.tool-page-container {
  max-width: 1400px;
  margin: 0 auto;
  padding: var(--space-4) var(--space-4) var(--space-8);
}
.tool-back-link {
  display: inline-flex;
  align-items: center;
  gap: var(--space-1);
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  text-decoration: none;
  margin-bottom: var(--space-3);
  transition: color var(--transition-fast);
}
.tool-back-link:hover {
  color: var(--color-primary);
}
.tool-page-header {
  margin-bottom: var(--space-6);
}
.tool-page-header h1 {
  font-size: var(--text-2xl);
  font-weight: 600;
  color: var(--color-text);
  line-height: 1.3;
}
.tool-page-subtitle {
  font-size: var(--text-sm);
  color: var(--color-text-secondary);
  margin-top: var(--space-1);
}
.tool-content {
  display: flex;
  flex-direction: column;
  gap: var(--space-5);
}
.tool-section {
  background: var(--color-card);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: var(--space-5);
  transition: box-shadow var(--transition-fast);
}
.tool-section:hover {
  box-shadow: var(--shadow-sm);
}
.tool-section--full {
  width: 100%;
}
.tool-section-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--space-4);
  flex-wrap: wrap;
  gap: var(--space-2);
}
.tool-section-header h3 {
  font-size: var(--text-lg);
  font-weight: 600;
  color: var(--color-text);
}
.tool-section-header .tool-section-subtitle {
  font-size: var(--text-sm);
  color: var(--color-text-muted);
}
.tool-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-5);
}
@media (min-width: 768px) {
  .tool-grid--2 {
    grid-template-columns: 1fr 1fr;
  }
  .tool-grid--3 {
    grid-template-columns: 1fr 1fr 1fr;
  }
  .tool-grid--2-1 {
    grid-template-columns: 2fr 1fr;
  }
  .tool-grid--1-2 {
    grid-template-columns: 1fr 2fr;
  }
}
.tool-actions {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  flex-wrap: wrap;
}
.tool-divider {
  border: none;
  border-top: 1px solid var(--color-border);
  margin: var(--space-3) 0;
}
.dark .tool-section, [data-theme="dark"] .tool-section {
  background: var(--color-card);
  border-color: var(--color-border);
}
.wp-transfer-card {
  background: var(--color-card);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  transition: box-shadow var(--transition-fast);
  margin-top: var(--space-4);
  overflow: visible;
  min-width: 0;
}
.wp-transfer-card:hover {
  box-shadow: var(--shadow-sm);
}
.wp-transfer-summary {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--space-5);
  cursor: pointer;
  -webkit-user-select: none;
     -moz-user-select: none;
          user-select: none;
  list-style: none;
}
.wp-transfer-summary::-webkit-details-marker {
  display: none;
}
.wp-transfer-summary::marker {
  content: '';
}
.wp-transfer-title {
  font-size: var(--text-xl);
  font-weight: 600;
  color: var(--color-text);
  margin: 0;
}
.wp-transfer-chevron {
  color: var(--color-text-muted);
  transition: transform var(--transition-fast);
  flex-shrink: 0;
}
details[open] > .wp-transfer-summary .wp-transfer-chevron {
  transform: rotate(180deg);
}
.wp-transfer-body {
  padding: 0 var(--space-5) var(--space-5);
  min-width: 0;
  overflow: visible;
}
.wp-transfer-filter-bar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: var(--space-3);
  margin-bottom: var(--space-4);
}
.wp-transfer-search-wrap {
  position: relative;
  flex: 1;
  max-width: 320px;
  min-width: 180px;
}
.wp-transfer-search-icon {
  position: absolute;
  left: 10px;
  top: 50%;
  transform: translateY(-50%);
  color: var(--color-text-muted);
  pointer-events: none;
}
.wp-transfer-search-input {
  width: 100%;
  padding: var(--space-2) var(--space-3) var(--space-2) 34px;
  font-size: var(--text-sm);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  background: var(--color-bg);
  color: var(--color-text);
  outline: none;
  transition: border-color var(--transition-fast);
}
.wp-transfer-search-input:focus {
  border-color: var(--color-primary);
}
.wp-transfer-toggle {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--text-sm);
  color: var(--color-text-secondary);
  cursor: pointer;
  -webkit-user-select: none;
     -moz-user-select: none;
          user-select: none;
  white-space: nowrap;
}
.wp-transfer-legend {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2) var(--space-4);
  margin-bottom: var(--space-4);
  font-size: var(--text-xs);
  color: var(--color-text-secondary);
}
.wp-transfer-legend-item {
  display: flex;
  align-items: center;
  gap: var(--space-1);
}
.wp-transfer-legend-dot {
  width: 12px;
  height: 12px;
  border-radius: var(--radius-sm);
  flex-shrink: 0;
}
.wp-transfer-legend-dot--existing {
  background: var(--color-success-light, #dcfce7);
}
.wp-transfer-legend-dot--changed {
  background: var(--color-warning-light, #fef9c3);
}
.wp-transfer-legend-dot--new {
  background: var(--color-bg);
  border: 1px solid var(--color-border);
}
.dark .wp-transfer-legend-dot--existing, [data-theme="dark"] .wp-transfer-legend-dot--existing {
  background: rgba(34, 197, 94, 0.2);
}
.dark .wp-transfer-legend-dot--changed, [data-theme="dark"] .wp-transfer-legend-dot--changed {
  background: rgba(234, 179, 8, 0.2);
}
.wp-transfer-legend-dot--intern {
  background: var(--color-bg-secondary);
  border: 1px solid var(--color-border);
  position: relative;
}
.wp-transfer-legend-dot--intern::after {
  content: "✓";
  position: absolute;
  top: -1px;
  left: 1px;
  font-size: 9px;
  color: var(--color-success);
}
.wp-transfer-table-wrap {
  overflow-x: auto;
  overflow-y: visible;
  -webkit-overflow-scrolling: touch;
  border-radius: var(--radius-md);
  background: var(--color-bg);
}
.wp-transfer-table {
  table-layout: fixed;
  border-collapse: separate;
  border-spacing: 0;
  font-size: 10px;
  min-width: 1100px;
  width: 100%;
}
.wp-col-expand {
  width: 2%;
}
.wp-col-kdnr {
  width: 4%;
}
.wp-col-stat {
  width: 3%;
}
.wp-col-name {
  width: 8%;
}
.wp-col-vorname {
  width: 6%;
}
.wp-col-strasse {
  width: 5%;
}
.wp-col-plz {
  width: 3%;
}
.wp-col-ort {
  width: 6%;
}
.wp-col-mobil {
  width: 8%;
}
.wp-col-email {
  width: 10%;
}
.wp-col-fzstat {
  width: 3%;
}
.wp-col-typ {
  width: 4%;
}
.wp-col-eantrieb {
  width: 2%;
}
.wp-col-marke {
  width: 4%;
}
.wp-col-modell {
  width: 4%;
}
.wp-col-freitext {
  width: 16%;
}
.wp-col-art {
  width: 5%;
}
.wp-col-ausf {
  width: 5%;
}
.wp-col-check {
  width: 2%;
}
.wp-transfer-th {
  text-align: left;
  padding: var(--space-2) var(--space-2);
  font-weight: 600;
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--color-text-secondary);
  background: var(--color-bg-secondary);
  border-bottom: 2px solid var(--color-border);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.wp-transfer-th--check {
  text-align: center;
}
.wp-transfer-td {
  padding: var(--space-1) var(--space-2);
  border-bottom: 1px solid var(--color-border);
  vertical-align: middle;
  color: var(--color-text);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.wp-transfer-cell {
  display: block;
  width: 0;
  min-width: 100%;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.wp-transfer-td--check {
  text-align: center;
}
.wp-transfer-td--copyable {
  cursor: pointer;
  position: relative;
}
.wp-transfer-td--copyable:hover {
  background: var(--color-primary) !important;
  @supports (color: color-mix(in lab, red, red)) {
    background: color-mix(in srgb, var(--color-primary) 8%, transparent) !important;
  }
}
.wp-transfer-td--copyable:active::after {
  content: "✓";
  position: absolute;
  top: 50%;
  right: 4px;
  transform: translateY(-50%);
  font-size: 10px;
  color: var(--color-success);
}
.wp-transfer-td--notes {
  padding: 0 !important;
  overflow: hidden;
}
.wp-transfer-notes-inner {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  padding: var(--space-1) var(--space-2);
  font-size: 9px;
  line-height: 1.3;
}
.wp-transfer-notes-meta {
  display: inline-block;
  margin-top: 2px;
  font-size: 10px;
  opacity: 0.7;
}
.wp-transfer-notes-meta b {
  color: var(--color-success);
}
.wp-transfer-td--intern-unchanged {
  background: var(--color-bg-secondary);
  color: var(--color-text-secondary);
}
.wp-transfer-row:hover .wp-transfer-td {
  background: var(--color-text);
  @supports (color: color-mix(in lab, red, red)) {
    background: color-mix(in srgb, var(--color-text) 3%, transparent);
  }
}
.wp-transfer-row--transferred {
  opacity: 0.5;
}
.wp-transfer-empty {
  text-align: center;
  padding: var(--space-8) var(--space-4);
  color: var(--color-text-muted);
  font-size: var(--text-sm);
}
.wp-transfer-actions {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: var(--space-3);
  margin-top: var(--space-4);
  padding-top: var(--space-3);
  border-top: 1px solid var(--color-border);
}
.wp-transfer-count {
  font-size: var(--text-xs);
  color: var(--color-text-secondary);
}
.wp-transfer-action-buttons {
  display: flex;
  align-items: center;
  gap: var(--space-2);
}
.wp-transfer-badge {
  display: inline-flex;
  align-items: center;
  padding: 1px 4px;
  font-size: 9px;
  font-weight: 600;
  border-radius: var(--radius-full);
  color: #fff;
  white-space: nowrap;
  max-width: 100%;
  overflow: hidden;
  text-overflow: ellipsis;
}
.wp-transfer-badge--new {
  background: #dc2626 !important;
  color: #fff !important;
  font-weight: 700;
}
.wp-transfer-badge--changed {
  background: #f59e0b !important;
  color: #fff !important;
  font-weight: 700;
}
.wp-transfer-badge--existing {
  background: #22c55e !important;
  color: #fff !important;
}
.wp-transfer-badge--intern {
  background: #22c55e !important;
}
.wp-transfer-badge--extern {
  background: #9ca3af !important;
}
.wp-transfer-badge--fuzzy {
  background: #f59e0b !important;
  color: #fff !important;
  font-weight: 700;
}
.wp-transfer-fuzzy-hint {
  display: block;
  font-size: 9px;
  color: var(--color-text-muted);
  margin-top: 1px;
  white-space: nowrap;
}
.wp-transfer-fuzzy-reasons {
  font-size: 11px;
  color: var(--color-text-muted);
}
.wp-transfer-badge--vehicle-new {
  background: #dc2626 !important;
  color: #fff !important;
  font-weight: 700;
}
.wp-transfer-badge--vehicle-changed {
  background: #f59e0b !important;
  color: #fff !important;
  font-weight: 700;
}
.wp-transfer-badge--vehicle-existing {
  background: #22c55e !important;
  color: #fff !important;
}
.wp-transfer-cat-row {
  background: var(--color-bg);
  pointer-events: none;
}
.wp-transfer-cat {
  padding: var(--space-2) var(--space-2);
  font-weight: 700;
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: #fff !important;
  text-align: center;
  border-bottom: 2px solid var(--color-border);
  white-space: nowrap;
  box-shadow: inset -2px 0 0 rgba(255,255,255,0.3);
}
.wp-transfer-cat--kunde {
  background: #3b82f6 !important;
}
.wp-transfer-cat--fahrzeug {
  background: #8b5cf6 !important;
}
.wp-transfer-cat--termin {
  background: #059669 !important;
}
.wp-transfer-cat--sonstiges {
  background: #6b7280 !important;
  box-shadow: none;
}
.wp-transfer-th--kunde {
  background: rgba(59, 130, 246, 0.1);
  color: #1e40af;
}
.wp-transfer-th--fahrzeug {
  background: rgba(139, 92, 246, 0.1);
  color: #5b21b6;
}
.wp-transfer-th--termin {
  background: rgba(5, 150, 105, 0.1);
  color: #065f46;
}
.wp-transfer-th--sonstiges {
  background: rgba(107, 114, 128, 0.1);
  color: #374151;
}
.wp-transfer-th--cat-border-right, .wp-transfer-td--cat-border-right {
  box-shadow: inset -2px 0 0 var(--color-border);
}
.dark .wp-transfer-th--kunde, [data-theme="dark"] .wp-transfer-th--kunde {
  background: rgba(59, 130, 246, 0.15);
  color: #93c5fd;
}
.dark .wp-transfer-th--fahrzeug, [data-theme="dark"] .wp-transfer-th--fahrzeug {
  background: rgba(139, 92, 246, 0.15);
  color: #c4b5fd;
}
.dark .wp-transfer-th--termin, [data-theme="dark"] .wp-transfer-th--termin {
  background: rgba(5, 150, 105, 0.15);
  color: #6ee7b7;
}
.dark .wp-transfer-th--sonstiges, [data-theme="dark"] .wp-transfer-th--sonstiges {
  background: rgba(107, 114, 128, 0.15);
  color: #d1d5db;
}
.wp-transfer-th--sortable {
  cursor: pointer;
  -webkit-user-select: none;
     -moz-user-select: none;
          user-select: none;
}
.wp-transfer-th--sortable:hover {
  background: rgba(0,0,0,0.05);
}
.wp-transfer-th--sortable svg {
  transition: transform 0.2s;
}
.wp-transfer-sort--asc {
  transform: rotate(180deg);
}
.wp-transfer-expand-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 24px;
  height: 24px;
  border: none;
  background: none;
  cursor: pointer;
  color: var(--color-text-muted);
  border-radius: var(--radius-sm, 4px);
  transition: transform 0.15s, background 0.15s;
}
.wp-transfer-expand-btn:hover {
  background: var(--color-bg-secondary);
  color: var(--color-text);
}
.wp-transfer-expand-btn--open {
  transform: rotate(180deg);
}
.wp-transfer-detail-row td {
  padding: 0 !important;
  border-bottom: 1px solid var(--color-border);
}
.wp-transfer-detail-inner {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap: 8px 20px;
  padding: 12px 16px;
  background: var(--color-bg-secondary);
  font-size: 12px;
}
.wp-transfer-detail-field {
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.wp-transfer-detail-label {
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--color-text-muted);
  font-weight: 600;
}
.wp-transfer-detail-value {
  color: var(--color-text);
  word-break: break-word;
  white-space: normal;
}
.wp-transfer-detail-field--wide {
  grid-column: 1 / -1;
}
.wp-transfer-copy-hint {
  display: none;
  font-size: 9px;
  color: var(--color-text-muted);
}
.wp-transfer-td--copyable:hover .wp-transfer-copy-hint {
  display: inline;
}
.dark .wp-transfer-card, [data-theme="dark"] .wp-transfer-card {
  background: var(--color-card);
  border-color: var(--color-border);
}
.dark .wp-transfer-table-wrap, [data-theme="dark"] .wp-transfer-table-wrap {
  background: var(--color-card);
  border-color: var(--color-border);
}
.dark .wp-transfer-td--intern-unchanged, [data-theme="dark"] .wp-transfer-td--intern-unchanged {
  background: var(--color-bg-secondary);
  @supports (color: color-mix(in lab, red, red)) {
    background: color-mix(in srgb, var(--color-bg-secondary) 60%, transparent);
  }
}
.dark .wp-transfer-cat--kunde, [data-theme="dark"] .wp-transfer-cat--kunde {
  background: #2563eb;
}
.dark .wp-transfer-cat--fahrzeug, [data-theme="dark"] .wp-transfer-cat--fahrzeug {
  background: #7c3aed;
}
.dark .wp-transfer-cat--termin, [data-theme="dark"] .wp-transfer-cat--termin {
  background: #047857;
}
.dark .wp-transfer-cat--sonstiges, [data-theme="dark"] .wp-transfer-cat--sonstiges {
  background: #4b5563;
}
.wp-transfer-td--changed {
  background: #fef9c3;
}
.wp-transfer-td--existing {
  background: #dcfce7;
}
.dark .wp-transfer-td--changed, [data-theme="dark"] .wp-transfer-td--changed {
  background: rgba(234, 179, 8, 0.15);
}
.dark .wp-transfer-td--existing, [data-theme="dark"] .wp-transfer-td--existing {
  background: rgba(34, 197, 94, 0.15);
}
.wp-transfer-badge--ebike {
  background: #8b5cf6;
  color: #fff;
}
.wp-transfer-td--aw {
  font-weight: 600;
}
.wp-transfer-artnum {
  opacity: 0.5;
  font-size: 9px;
}
.wp-transfer-status-badge {
  display: inline-block;
  padding: 2px 8px;
  border-radius: 9999px;
  font-size: 11px;
  font-weight: 500;
  color: #fff;
  white-space: nowrap;
}
.wp-transfer-status-badge--booked {
  background: #3b82f6;
}
.wp-transfer-status-badge--confirmed {
  background: #10b981;
}
.wp-transfer-status-badge--completed {
  background: #6b7280;
}
.wp-transfer-status-badge--cancelled {
  background: #ef4444;
}
.wp-transfer-status-badge--noshow {
  background: #f59e0b;
}
.wp-transfer-check-done {
  color: var(--color-success, #10b981);
  font-weight: 700;
}
@media (max-width: 639px) {
  .wp-transfer-summary {
    padding: var(--space-4);
  }
  .wp-transfer-body {
    padding: 0 var(--space-3) var(--space-4);
  }
  .wp-transfer-title {
    font-size: var(--text-lg);
  }
  .wp-transfer-filter-bar {
    flex-direction: column;
    align-items: stretch;
  }
  .wp-transfer-search-wrap {
    max-width: 100%;
  }
  .wp-transfer-table-wrap {
    margin-left: calc(-1 * var(--space-3));
    margin-right: calc(-1 * var(--space-3));
    border-radius: 0;
    border-left: none;
    border-right: none;
  }
  .wp-transfer-actions {
    flex-direction: column;
    align-items: stretch;
  }
  .wp-transfer-action-buttons {
    justify-content: flex-end;
  }
}
@media (max-width: 639px) {
  .tool-page-container {
    padding: var(--space-3) var(--space-3) var(--space-6);
    overflow-x: hidden;
  }
  .tool-page-header h1 {
    font-size: var(--text-xl);
  }
  .tool-section {
    padding: var(--space-4);
    overflow-x: hidden;
    word-break: break-word;
  }
  .tool-section-header {
    flex-direction: column;
    align-items: flex-start;
  }
  .tool-section .input {
    min-width: 0;
  }
  .tool-section .btn {
    white-space: nowrap;
  }
}
.tool-section--flex-col {
  display: flex;
  flex-direction: column;
}
.tool-section--chatbot {
  min-height: 400px;
}
.leasing-chat-history {
  flex: 1;
  min-height: 200px;
  max-height: 350px;
  overflow-y: auto;
  margin-top: var(--space-3);
  padding: var(--space-3);
  border-radius: var(--radius-md);
  background: var(--color-bg-secondary);
}
.leasing-chat-placeholder {
  font-size: var(--text-sm);
  opacity: 0.5;
  text-align: center;
  padding: var(--space-4) 0;
}
.leasing-chat-input-row {
  flex-shrink: 0;
  display: flex;
  align-items: center;
  gap: var(--space-2);
  margin-top: var(--space-3);
}
.leasing-chat-hint {
  flex-shrink: 0;
  font-size: var(--text-xs);
  opacity: 0.5;
  margin-top: var(--space-2);
}
.leasing-search-row {
  flex-shrink: 0;
  display: flex;
  gap: var(--space-2);
  margin-bottom: var(--space-2);
}
.leasing-list-scroll {
  flex: 1;
  max-height: 400px;
  overflow-y: auto;
}
.leasing-list-placeholder {
  font-size: var(--text-sm);
  opacity: 0.5;
  text-align: center;
  padding: var(--space-4) 0;
}
.leasing-list-placeholder--sm {
  padding: var(--space-2) 0;
}
.leasing-stats-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-3);
  margin-top: var(--space-3);
  flex-shrink: 0;
}
.leasing-stat-tile {
  padding: var(--space-3);
  border-radius: var(--radius-md);
  background: var(--color-bg-secondary);
  text-align: center;
}
.leasing-stat-tile--primary {
  background: rgba(59, 130, 246, 0.1);
}
.leasing-stat-tile--secondary {
  background: rgba(168, 85, 247, 0.1);
}
.leasing-stat-value {
  font-size: var(--text-2xl);
  font-weight: 700;
  color: var(--color-primary);
}
.leasing-stat-value--warning {
  color: var(--color-warning);
}
.leasing-stat-value--success {
  color: var(--color-success);
}
.leasing-stat-value--secondary {
  color: #a855f7;
}
.leasing-stat-value--neutral {
  color: var(--color-text);
}
.leasing-stat-label {
  font-size: var(--text-xs);
  opacity: 0.7;
}
.leasing-providers-section {
  margin-top: var(--space-4);
  flex-shrink: 0;
}
.leasing-providers-title {
  font-size: var(--text-sm);
  font-weight: 500;
  margin-bottom: var(--space-2);
}
.leasing-providers-scroll {
  max-height: 150px;
  overflow-y: auto;
}
.leasing-warning-notice {
  margin-top: var(--space-3);
  padding: var(--space-3);
  border-radius: var(--radius-md);
  background: rgba(234, 179, 8, 0.1);
  border: 1px solid rgba(234, 179, 8, 0.3);
  flex-shrink: 0;
}
.leasing-warning-notice-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.leasing-warning-notice-label {
  font-size: var(--text-sm);
}
.leasing-warning-notice-value {
  font-weight: 700;
  color: var(--color-warning);
}
.leasing-export-row {
  margin-top: var(--space-3);
  padding-top: var(--space-3);
  border-top: 1px solid var(--color-border);
  flex-shrink: 0;
}
.leasing-status-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--space-3);
  border-radius: var(--radius-md);
  background: var(--color-bg-secondary);
  margin-top: var(--space-3);
}
.leasing-status-row--mt2 {
  margin-top: var(--space-2);
}
.leasing-status-label {
  display: flex;
  align-items: center;
  gap: var(--space-2);
}
.leasing-status-text {
  font-size: var(--text-sm);
}
.leasing-settings-hint {
  font-size: var(--text-xs);
  opacity: 0.5;
  margin-top: var(--space-4);
  text-align: center;
}
.leasing-settings-hint a {
  color: var(--color-primary);
}
.leasing-reminder-table-wrap {
  overflow-x: auto;
  margin-top: var(--space-4);
}
.leasing-reminder-table {
  width: 100%;
  font-size: var(--text-sm);
}
.leasing-reminder-thead {
  text-align: left;
  border-bottom: 1px solid var(--color-border);
}
.leasing-reminder-th {
  padding: var(--space-2);
  font-weight: 500;
}
.leasing-reminder-th--right {
  padding: var(--space-2);
  font-weight: 500;
  text-align: right;
}
.leasing-reminder-empty {
  padding: 2rem 0;
  text-align: center;
  opacity: 0.5;
}
.leasing-actions-bar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-top: var(--space-4);
  padding-top: var(--space-4);
  border-top: 1px solid var(--color-border);
}
.leasing-selected-count {
  display: flex;
  align-items: center;
  gap: var(--space-2);
}
.leasing-selected-label {
  font-size: var(--text-sm);
  opacity: 0.7;
}
.leasing-selected-value {
  font-weight: 700;
}
.leasing-sa-grid {
  margin-top: var(--space-4);
}
.leasing-sub-card {
  padding: var(--space-4);
  border-radius: var(--radius-lg);
  border: 1px solid var(--color-border);
}
.leasing-sub-card-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  margin-bottom: var(--space-3);
}
.leasing-sub-card-title {
  font-size: var(--text-sm);
  font-weight: 600;
}
.leasing-sub-card-desc {
  font-size: var(--text-xs);
  opacity: 0.7;
}
.leasing-kb-meta-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  font-size: var(--text-sm);
  margin-bottom: var(--space-3);
}
.leasing-kb-meta-label {
  opacity: 0.7;
}
.leasing-btn-full {
  width: 100%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.leasing-sub-caption {
  font-size: var(--text-xs);
  opacity: 0.5;
  margin-top: var(--space-2);
  text-align: center;
}
.leasing-control-label {
  font-size: var(--text-xs);
  font-weight: 500;
  opacity: 0.7;
}
.leasing-control-field {
  margin-bottom: var(--space-3);
}
.leasing-control-field--mt1 {
  margin-top: var(--space-1);
}
.leasing-range-row {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  margin-top: var(--space-1);
}
.leasing-range-value {
  font-size: var(--text-sm);
  font-family: monospace;
  width: 2.5rem;
}
.leasing-toggle-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--space-3);
}
.leasing-toggle-label {
  font-size: var(--text-sm);
}
.leasing-kv-list {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  margin-bottom: var(--space-3);
}
.leasing-kv-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  font-size: var(--text-sm);
}
.leasing-kv-label {
  opacity: 0.7;
}
.leasing-select-field {
  margin-bottom: var(--space-3);
}
.leasing-reminder-weeks-label {
  font-size: var(--text-sm);
  opacity: 0.7;
}
.leasing-body-text {
  font-size: var(--text-sm);
  opacity: 0.7;
}
.leasing-stats-grid-3 {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-3);
  margin-top: var(--space-3);
}
.leasing-icon-btn--muted {
  opacity: 0.5;
}
.leasing-icon-gap {
  margin-right: var(--space-2);
}
.leasing-modal-panel {
  max-width: 700px;
  max-height: 90vh;
}
.leasing-modal-subtitle {
  font-size: var(--text-sm);
  opacity: 0.7;
}
.leasing-modal-body-scroll {
  overflow-y: auto;
}
.leasing-modal-loading {
  text-align: center;
  padding: 2rem 0;
  opacity: 0.5;
}
.dark .leasing-stat-tile--primary, [data-theme="dark"] .leasing-stat-tile--primary {
  background: rgba(59, 130, 246, 0.15);
}
.dark .leasing-stat-tile--secondary, [data-theme="dark"] .leasing-stat-tile--secondary {
  background: rgba(168, 85, 247, 0.15);
}
.dark .leasing-warning-notice, [data-theme="dark"] .leasing-warning-notice {
  background: rgba(234, 179, 8, 0.08);
  border-color: rgba(234, 179, 8, 0.25);
}
.dark .leasing-status-row, [data-theme="dark"] .leasing-status-row {
  background: var(--color-bg-secondary);
}
.dark .leasing-sub-card, [data-theme="dark"] .leasing-sub-card {
  border-color: var(--color-border);
}
.tj-file-upload-row {
  display: flex;
  align-items: center;
  gap: var(--space-2);
}
.tj-file-list {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-1);
  margin-top: var(--space-1);
}
.tj-area-chips {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}
.tj-news-area-option {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  cursor: pointer;
  padding: var(--space-1) 0;
}
.tj-news-area-dot {
  display: inline-block;
  width: 12px;
  height: 12px;
  border-radius: 50%;
  flex-shrink: 0;
}
.tj-news-area-name {
  font-size: 0.875rem;
  color: var(--color-text);
}
.tj-pin-row {
  display: flex;
  align-items: center;
  gap: var(--space-3);
}
.tj-create-btn {
  width: 100%;
  margin-top: var(--space-3);
}
.tj-settings-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--space-3);
}
.tj-settings-block {
  margin-bottom: var(--space-3);
}
.tj-gmail-actions {
  margin-top: var(--space-2);
  display: flex;
  align-items: center;
  gap: var(--space-2);
}
.tj-labels-dropdown {
  margin-top: var(--space-2);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  background: var(--color-card);
  max-height: 12rem;
  overflow-y: auto;
  box-shadow: var(--shadow-md);
}
.dark .tj-labels-dropdown, [data-theme="dark"] .tj-labels-dropdown {
  background: var(--color-card);
  border-color: var(--color-border);
}
.tj-labels-loading {
  padding: var(--space-2);
  font-size: var(--text-xs);
  opacity: 0.5;
}
.tj-color-swatch {
  width: 2rem;
  height: 2rem;
  border-radius: 9999px;
  border: 2px solid transparent;
  cursor: pointer;
  padding: 0;
  background: var(--pill-color);
}
.tj-modal-wide {
  max-width: 1200px;
}
@media (max-width: 640px) {
  .tj-modal-wide {
    max-width: 100%;
    max-height: calc(100dvh - var(--space-4));
    margin: var(--space-2) 0;
  }
  .tj-modal-wide .modal-body {
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
    max-height: calc(100dvh - 180px);
  }
}
.tj-modal-title-flex {
  flex: 1;
  padding-right: var(--space-2);
}
.tj-modal-header-actions {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  flex-shrink: 0;
}
.tj-modal-pills-row {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  margin-bottom: var(--space-4);
}
.tj-modal-sender {
  font-size: var(--text-sm);
  opacity: 0.7;
  margin-bottom: var(--space-2);
}
.tj-file-pill {
  gap: var(--space-1);
  text-decoration: none;
}
.tj-file-icon {
  font-size: 1rem;
  line-height: 1;
}
.tj-gmail-link {
  gap: var(--space-1);
  text-decoration: none;
  color: var(--color-text-secondary);
  transition: color 0.15s;
}
.tj-gmail-link:hover {
  color: var(--color-primary);
}
.tj-gmail-icon {
  width: 14px;
  height: 14px;
  flex-shrink: 0;
}
.tn-area-pill {
  display: inline-flex;
  align-items: center;
  font-size: var(--text-xs);
  font-weight: 500;
  line-height: 1;
  white-space: nowrap;
  padding: var(--space-1) var(--space-2);
  border-radius: var(--radius-full);
  background: var(--pill-color, var(--color-primary));
  @supports (color: color-mix(in lab, red, red)) {
    background: color-mix(in srgb, var(--pill-color, var(--color-primary)) 15%, transparent);
  }
  color: var(--pill-color, var(--color-primary));
  border: 1px solid var(--pill-color, var(--color-primary));
  @supports (color: color-mix(in lab, red, red)) {
    border: 1px solid color-mix(in srgb, var(--pill-color, var(--color-primary)) 30%, transparent);
  }
}
.tj-attachment-img {
  max-width: 180px;
  max-height: 130px;
  -o-object-fit: contain;
     object-fit: contain;
  border: 1px solid var(--color-border);
  cursor: pointer;
}
@media (max-width: 640px) {
  .tj-attachment-img {
    max-width: 120px;
    max-height: 90px;
  }
}
.tj-modal-wide .modal-body ol {
  list-style-type: decimal;
  padding-left: var(--space-5);
  margin: var(--space-2) 0;
}
.tj-modal-wide .modal-body ul {
  list-style-type: disc;
  padding-left: var(--space-5);
  margin: var(--space-2) 0;
}
.tj-modal-wide .modal-body ol li, .tj-modal-wide .modal-body ul li {
  margin-bottom: var(--space-1);
}
.tj-pipeline-info {
  font-size: var(--text-xs);
  color: var(--color-text-muted);
}
.tj-pipeline-row {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-1) 0;
}
.tj-pipeline-row + .tj-pipeline-row {
  border-top: 1px solid var(--color-border);
}
.tj-modal-section-label {
  font-size: var(--text-sm);
  font-weight: 500;
  display: block;
  margin-bottom: var(--space-2);
}
.tj-modal-footer-split {
  display: flex;
  justify-content: space-between;
}
.tj-modal-footer-grid3 {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-2);
}
[data-tj-items-list] {
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.tj-initially-hidden {
  display: none;
}
.tj-loading-placeholder {
  font-size: var(--text-sm);
  opacity: 0.5;
  text-align: center;
  padding: var(--space-4) 0;
}
.tj-label-add-btn {
  width: 100%;
  margin-top: var(--space-2);
}
.tj-prompt-textarea {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
}
.tj-btn-close-xl {
  font-size: var(--text-xl);
}
.tj-selected-labels {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}
[data-wp-capacity-bar] {
  width: var(--util-width, 0%);
  background: var(--util-color, var(--color-primary));
}
.wp-cap-reduced {
  color: #dc2626;
  font-weight: 700;
  cursor: help;
}
.wp-cap-normal {
  color: var(--color-text-secondary, #6b7280);
  font-weight: 400;
  text-decoration: line-through;
  font-size: 0.85em;
}
.gw-search-row {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  min-width: 0;
  margin-bottom: var(--space-3);
}
.gw-search-row > select, .gw-search-row > .gw-search-wrap {
  flex: 1 1 0%;
  min-width: 0;
}
.gw-search-wrap {
  position: relative;
}
.gw-search-wrap input {
  width: 100%;
  padding-left: 2.5rem;
}
.gw-search-wrap .gw-search-icon {
  position: absolute;
  left: 0.75rem;
  top: 50%;
  transform: translateY(-50%);
  width: 1rem;
  height: 1rem;
  opacity: 0.4;
  pointer-events: none;
}
[data-gw-events-table] {
  width: 100%;
  table-layout: fixed;
}
[data-gw-events-table] thead tr {
  font-size: var(--text-xs);
  color: var(--color-text-muted);
}
[data-gw-events-table] tbody tr {
  border-bottom: 1px solid var(--color-border);
  transition: background var(--transition-fast);
}
[data-gw-events-table] tbody tr:hover {
  background: var(--color-bg-secondary);
}
[data-gw-legend] {
  display: flex;
  align-items: center;
  gap: var(--space-4);
  font-size: var(--text-xs);
  color: var(--color-text-muted);
  padding-top: var(--space-2);
  border-top: 1px solid var(--color-border);
}
[data-gw-thread-list] {
  max-height: 600px;
  overflow-y: auto;
}
[data-gw-drive-breadcrumb] {
  display: flex;
  align-items: center;
  gap: var(--space-1);
  font-size: var(--text-xs);
  color: var(--color-text-muted);
  margin-bottom: var(--space-2);
}
[data-gw-oauth-status] {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}
.loading {
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.loading-spinner {
  width: 1.25rem;
  height: 1.25rem;
  border: 2px solid var(--color-border);
  border-top-color: var(--color-primary);
  border-radius: 50%;
  animation: spin 0.6s linear infinite;
}
.loading-sm .loading-spinner, .loading.loading-sm {
  width: 1rem;
  height: 1rem;
}
@keyframes spin {
  to {
    transform: rotate(360deg);
  }
}
.badge-error {
  background: rgba(239, 68, 68, 0.15);
  color: #dc2626;
}
.badge-success {
  background: rgba(34, 197, 94, 0.15);
  color: #16a34a;
}
.gw-table-container {
  min-width: 0;
  width: 100%;
}
.gw-table-fixed {
  table-layout: fixed;
}
.gw-col-time {
  width: 8%;
}
.gw-col-type {
  width: 10%;
}
.gw-col-customer {
  width: 13%;
}
.gw-col-bike {
  width: 17%;
}
.gw-col-reason {
  width: 20%;
}
.gw-col-extra {
  width: 22%;
}
.gw-col-vp {
  width: 5%;
}
.gw-col-action {
  width: 5%;
}
.gw-col-sender {
  width: 18%;
}
.gw-col-subject {
  width: 27%;
}
.gw-col-preview {
  width: 35%;
}
.gw-col-date {
  width: 10%;
}
.gw-empty-row {
  text-align: center;
  padding: 2rem 0;
  opacity: 0.5;
  font-size: var(--text-sm);
}
.gw-loading-row {
  text-align: center;
  padding: 1rem 0;
  opacity: 0.5;
  font-size: var(--text-sm);
}
.gw-icon-success {
  color: var(--color-success);
}
.gw-icon-danger {
  color: var(--color-danger);
}
.gw-icon-warning {
  color: var(--color-warning);
}
.gw-icon-muted {
  opacity: 0.4;
}
.gw-badge-intern {
  background: #22c55e;
  color: #fff;
  font-size: 8px;
  padding: 1px 4px;
}
.gw-badge-extern {
  background: #9ca3af;
  color: #fff;
  font-size: 8px;
  padding: 1px 4px;
}
.dark .gw-badge-intern {
  background: #16a34a;
}
.dark .gw-badge-extern {
  background: #6b7280;
}
.gw-oauth-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  font-size: var(--text-sm);
}
.gw-settings-title {
  font-size: var(--text-sm);
  font-weight: 600;
  margin-bottom: var(--space-2);
}
.gw-settings-hint {
  font-size: var(--text-xs);
  opacity: 0.6;
  margin-bottom: var(--space-2);
}
.gw-settings-loading {
  font-size: var(--text-xs);
  opacity: 0.5;
}
.gw-settings-options {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--space-4);
}
.gw-settings-option-label {
  font-size: var(--text-xs);
  display: flex;
  align-items: center;
  gap: var(--space-2);
}
.gw-breadcrumb-placeholder {
  opacity: 0.6;
  font-size: var(--text-xs);
}
.gw-drive-loading {
  font-size: var(--text-sm);
  opacity: 0.5;
  padding: 1rem 0;
  text-align: center;
}
@media (max-width: 639px) {
  .gw-search-row {
    flex-direction: column;
  }
  .gw-search-row > select, .gw-search-row > .gw-search-wrap {
    width: 100%;
  }
  [data-gw-events-table] {
    font-size: var(--text-xs);
  }
}
.oh-tabs {
  display: flex;
  gap: 0;
  border-bottom: 1px solid var(--color-border);
  margin-bottom: 1.5rem;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}
.oh-tab {
  padding: 0.5rem 1rem;
  font-size: 0.8125rem;
  font-weight: 500;
  color: var(--color-text-muted);
  background: none;
  border: none;
  border-bottom: 2px solid transparent;
  cursor: pointer;
  white-space: nowrap;
  transition: color 0.15s, border-color 0.15s;
}
.oh-tab:hover {
  color: var(--color-text);
}
.oh-tab.active {
  color: var(--color-primary);
  border-bottom-color: var(--color-primary);
}
.oh-section {
  min-height: 200px;
  max-width: 100%;
  overflow-x: auto;
}
.oh-day-block {
  padding: 0.625rem 0;
  border-bottom: 1px solid var(--color-border-light, rgba(0,0,0,0.06));
}
.oh-day-block:last-child {
  border-bottom: none;
}
.oh-day-block-compact {
  padding: 0.375rem 0;
}
.oh-day-top-row {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  margin-bottom: 0.375rem;
}
.oh-day-inline-row {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  flex-wrap: wrap;
}
.oh-day-times-inline {
  display: flex;
  align-items: center;
  gap: 0.375rem;
  margin-left: auto;
}
.oh-pause-row {
  display: flex;
  align-items: center;
  gap: 0.375rem;
  padding-left: calc(90px + 0.75rem);
  margin-top: 0.25rem;
}
.oh-season-label {
  font-size: 0.8125rem;
  font-weight: 600;
  color: var(--color-text-muted);
  margin-bottom: 0.375rem;
  margin-top: 0.5rem;
}
.oh-day-label {
  font-weight: 600;
  font-size: 0.8125rem;
  min-width: 90px;
  flex-shrink: 0;
}
.oh-day-label-short {
  font-weight: 600;
  font-size: 0.8125rem;
  min-width: 28px;
  flex-shrink: 0;
}
.oh-check-label {
  display: flex;
  align-items: center;
  gap: 0.375rem;
  cursor: pointer;
  font-size: 0.8125rem;
  white-space: nowrap;
}
.oh-day-times {
  display: flex;
  align-items: center;
  gap: 0.375rem;
  flex-wrap: wrap;
  padding-left: 0;
}
.oh-pause-times {
  display: flex;
  align-items: center;
  gap: 0.375rem;
  margin-left: 0.75rem;
}
.oh-pause-label {
  font-size: 0.6875rem;
  color: var(--color-text-muted);
  font-weight: 500;
  flex-shrink: 0;
}
.oh-day-row {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  padding: 0.5rem 0;
  border-bottom: 1px solid var(--color-border-light, rgba(0,0,0,0.06));
  flex-wrap: wrap;
}
.oh-day-row:last-child {
  border-bottom: none;
}
.oh-day-row-inline {
  flex-wrap: nowrap;
  gap: 0.5rem;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}
.oh-day-name {
  font-weight: 500;
  font-size: 0.875rem;
  min-width: 100px;
}
.oh-day-name-short {
  font-weight: 600;
  font-size: 0.8125rem;
  min-width: 28px;
  flex-shrink: 0;
}
.oh-closed-toggle {
  display: flex;
  align-items: center;
  gap: 0.375rem;
  min-width: 90px;
  cursor: pointer;
}
.oh-closed-toggle input[type="checkbox"] {
  accent-color: var(--color-error, #ef4444);
}
.oh-time-select {
  width: 80px !important;
  min-width: 80px !important;
  max-width: 80px !important;
  padding: 6px 24px 6px 8px !important;
  font-size: 0.8125rem !important;
  border: 1px solid var(--color-border) !important;
  border-radius: 8px !important;
  background: var(--color-bg) !important;
  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='%23666' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E") !important;
  background-repeat: no-repeat !important;
  background-position: right 6px center !important;
  color: var(--color-text) !important;
  cursor: pointer;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  height: 34px;
}
.oh-time-inputs {
  display: flex;
  align-items: center;
  gap: 0.375rem;
}
.oh-time-group {
  display: flex;
  align-items: center;
  gap: 0.125rem;
}
.oh-time-input {
  width: 100px !important;
  min-width: 100px !important;
  max-width: 100px !important;
  padding: 0.25rem 0.5rem !important;
  font-size: 0.8125rem !important;
  border-radius: var(--radius-md, 0.375rem) !important;
  flex-shrink: 0;
}
.oh-sep {
  color: var(--color-text-muted);
  padding: 0 0.125rem;
  flex-shrink: 0;
}
.oh-date-input {
  max-width: 180px !important;
}
.oh-date-grid {
  max-width: 400px;
}
.oh-break {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  margin-left: 0.5rem;
}
.oh-break-toggle {
  display: flex;
  align-items: center;
  gap: 0.375rem;
  cursor: pointer;
}
.oh-holiday-list {
  margin-top: 0.5rem;
}
.oh-holiday-item {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  padding: 0.25rem 0;
  font-size: 0.8125rem;
}
.oh-holiday-date {
  font-weight: 500;
  min-width: 80px;
}
.oh-holiday-day {
  color: var(--color-text-muted);
  min-width: 30px;
}
.oh-closures-list, .oh-overrides-list {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}
.oh-closure-item, .oh-override-item {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  padding: 0.5rem 0.75rem;
  background: var(--color-bg-secondary, rgba(0,0,0,0.02));
  border-radius: 0.375rem;
  font-size: 0.8125rem;
}
.oh-closure-title {
  font-weight: 500;
}
.oh-closure-dates, .oh-override-date {
  color: var(--color-text-muted);
}
.oh-dept-section {
  padding: 1rem;
  background: var(--color-bg-secondary, rgba(0,0,0,0.02));
  border-radius: 0.5rem;
}
.oh-dept-toggle {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  cursor: pointer;
  font-size: 0.875rem;
}
.oh-dept-hours .input-sm {
  width: 70px;
}
.team-members-list {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}
.team-member-card {
  border: 1px solid var(--color-border);
  border-radius: 0.5rem;
  padding: 0.75rem 1rem;
}
.team-member-header {
  display: flex;
  align-items: center;
  gap: 0.75rem;
}
.team-avatar {
  width: 36px !important;
  height: 36px !important;
  min-width: 36px;
  min-height: 36px;
  max-width: 36px;
  max-height: 36px;
  border-radius: 50%;
  display: flex !important;
  align-items: center;
  justify-content: center;
  font-size: 12px;
  font-weight: 700;
  color: #fff;
  flex-shrink: 0;
  letter-spacing: 0.5px;
  overflow: hidden;
}
.team-avatar-sm {
  width: 24px;
  height: 24px;
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 0.625rem;
  font-weight: 600;
  color: #fff;
  flex-shrink: 0;
  margin-right: 0.375rem;
}
.team-member-info {
  flex: 1;
}
.team-member-badges {
  display: flex;
  gap: 0.375rem;
  align-items: center;
  flex-wrap: wrap;
  margin-top: 0.125rem;
}
.team-schedule-grid {
  display: grid !important;
  grid-template-columns: repeat(7, 1fr);
  gap: 4px;
  margin-top: 0.5rem;
  padding-top: 0.5rem;
  border-top: 1px solid var(--color-border);
}
.team-edit-form {
  margin-top: 0.75rem;
  padding-top: 0.75rem;
  border-top: 1px solid var(--color-border);
}
.team-rotation-grid {
  border: 1px solid var(--color-border);
  border-radius: 0.375rem;
  overflow: hidden;
}
.team-rotation-header {
  display: flex;
  background: var(--color-bg-secondary, rgba(0,0,0,0.03));
  border-bottom: 1px solid var(--color-border);
  font-size: 0.75rem;
  font-weight: 600;
}
.team-rotation-row {
  display: flex;
  border-bottom: 1px solid var(--color-border-light, rgba(0,0,0,0.06));
}
.team-rotation-row:last-child {
  border-bottom: none;
}
.team-rotation-name {
  min-width: 140px;
  padding: 0.5rem 0.75rem;
  display: flex;
  align-items: center;
  font-size: 0.8125rem;
  font-weight: 500;
}
.team-rotation-day-header {
  flex: 1;
  padding: 0.375rem 0.25rem;
  text-align: center;
  min-width: 40px;
  display: flex;
  flex-direction: column;
  align-items: center;
}
.team-rotation-cell {
  flex: 1;
  padding: 0.375rem 0.25rem;
  text-align: center;
  font-size: 0.75rem;
  min-width: 40px;
}
.team-rotation-cell.active {
  background: var(--color-success-bg, rgba(16, 185, 129, 0.1));
  color: var(--color-success, #10B981);
  font-weight: 600;
}
.team-rotation-cell.off {
  color: var(--color-text-muted);
}
.team-rotation-cell-check {
  flex: 1;
  padding: 0.375rem 0.25rem;
  text-align: center;
  font-size: 0.75rem;
  min-width: 40px;
  cursor: pointer;
  -webkit-user-select: none;
     -moz-user-select: none;
          user-select: none;
}
.team-rotation-cell-check.active {
  background: var(--color-success-bg, rgba(16, 185, 129, 0.1));
  color: var(--color-success, #10B981);
}
.team-rotation-cell-check:hover {
  background: var(--color-bg-hover, rgba(0,0,0,0.05));
}
.team-rotation-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.8125rem;
}
.team-rotation-table th, .team-rotation-table td {
  padding: 0.375rem 0.25rem;
  text-align: center;
  border: 1px solid var(--color-border-light, rgba(0,0,0,0.06));
}
.team-rotation-table th {
  background: var(--color-bg-secondary, rgba(0,0,0,0.03));
  font-weight: 600;
  font-size: 0.6875rem;
}
.team-rotation-table td:first-child, .team-rotation-table th:first-child {
  text-align: left;
  padding-left: 0.75rem;
  min-width: 120px;
}
.team-rot-th {
  min-width: 36px;
}
.team-rot-td {
  min-width: 36px;
  height: 32px;
}
.team-rot-td.active {
  background: var(--color-success-bg, rgba(16, 185, 129, 0.1));
  color: var(--color-success, #10B981);
  font-weight: 600;
}
.team-rot-td.off {
  color: var(--color-text-muted);
}
.team-vacation-overview {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}
.team-vacation-bar {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  font-size: 0.8125rem;
}
.team-vacation-name {
  min-width: 140px;
  font-weight: 500;
}
.team-vacation-progress {
  flex: 1;
  height: 8px;
  background: var(--color-bg-secondary, rgba(0,0,0,0.08));
  border-radius: 4px;
  overflow: hidden;
  max-width: 200px;
}
.team-vacation-fill {
  height: 100%;
  width: var(--vacation-width, 0%);
  background: var(--color-primary, #3B82F6);
  border-radius: 4px;
  transition: width 0.3s;
}
.team-absence-list {
  display: flex;
  flex-direction: column;
  gap: 0.375rem;
}
.team-absence-item {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  padding: 0.5rem 0.75rem;
  background: var(--color-bg-secondary, rgba(0,0,0,0.02));
  border-radius: 0.375rem;
  font-size: 0.8125rem;
  flex-wrap: wrap;
}
.team-absence-icon {
  font-size: 1rem;
}
.team-rotation-preview {
  margin-top: 0.5rem;
  padding-top: 0.5rem;
  border-top: 1px solid var(--color-border);
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.team-rotation-preview-row {
  display: grid;
  grid-template-columns: 28px repeat(6, 1fr);
  gap: 4px;
  align-items: center;
}
.team-rotation-week-label {
  font-size: 9px;
  font-weight: 700;
  color: var(--color-text-muted);
  text-align: center;
}
.team-rotation-preview-day {
  text-align: center;
  font-size: 11px;
  font-weight: 600;
  padding: 2px;
  border-radius: var(--radius-sm, 4px);
  color: var(--color-text-muted);
}
.team-rotation-preview-day.active {
  background: var(--color-success);
  @supports (color: color-mix(in lab, red, red)) {
    background: color-mix(in srgb, var(--color-success) 15%, transparent);
  }
  color: var(--color-success);
}
.team-schedule-grid-with-label {
  grid-template-columns: 28px repeat(6, 1fr) !important;
}
.team-schedule-grid-with-label:first-of-type {
  margin-top: 0.5rem;
  padding-top: 0.5rem;
  border-top: 1px solid var(--color-border);
}
.team-schedule-grid-with-label + .team-schedule-grid-with-label {
  margin-top: 2px;
  padding-top: 0;
  border-top: none;
}
.einstellungen-team-week-label {
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 9px;
  font-weight: 700;
  color: var(--color-text-muted);
}
.badge-sm {
  font-size: 0.6875rem;
  padding: 0.125rem 0.375rem;
}
.dark .oh-day-row {
  border-bottom-color: rgba(255,255,255,0.06);
}
.dark .oh-closure-item, .dark .oh-override-item, .dark .oh-dept-section, .dark .team-absence-item {
  background: rgba(255,255,255,0.04);
}
.dark .team-rotation-header, .dark .team-rotation-table th {
  background: rgba(255,255,255,0.06);
}
.dark .team-rotation-cell.active, .dark .team-rot-td.active, .dark .team-rotation-cell-check.active {
  background: rgba(16, 185, 129, 0.15);
}
.dark .team-vacation-progress {
  background: rgba(255,255,255,0.1);
}
@media (max-width: 768px) {
  .oh-tabs {
    gap: 0;
  }
  .oh-tab {
    padding: 0.375rem 0.625rem;
    font-size: 0.75rem;
  }
  .oh-day-name {
    min-width: 70px;
    font-size: 0.8125rem;
  }
  .oh-day-label {
    min-width: 60px;
    font-size: 0.75rem;
  }
  .oh-day-row {
    gap: 0.5rem;
  }
  .oh-day-times {
    flex-wrap: wrap;
  }
  .oh-pause-times {
    margin-left: 0;
    margin-top: 0.25rem;
  }
  .oh-day-inline-row {
    flex-wrap: wrap;
  }
  .oh-day-times-inline {
    margin-left: 0;
    width: 100%;
    margin-top: 0.25rem;
  }
  .oh-pause-row {
    padding-left: 0;
  }
  .oh-break {
    width: 100%;
    margin-left: 0;
    margin-top: 0.25rem;
  }
  .team-rotation-name {
    min-width: 100px;
  }
  .team-vacation-name {
    min-width: 100px;
  }
  .oh-time-select {
    width: 72px !important;
    min-width: 72px !important;
    max-width: 72px !important;
    padding-right: 20px !important;
    background-position: right 4px center !important;
  }
}
.bestellungen-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--space-6);
}
.bestellungen-header h1 {
  font-size: var(--text-xl);
  font-weight: 600;
  color: var(--color-text);
}
.bestellungen-filter-bar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: var(--space-3);
  margin-bottom: var(--space-6);
}
.bestellungen-search-wrap {
  position: relative;
  flex: 1;
  max-width: 320px;
  min-width: 180px;
}
.bestellungen-search-icon {
  position: absolute;
  left: 10px;
  top: 50%;
  transform: translateY(-50%);
  color: var(--color-text-muted);
  pointer-events: none;
}
.bestellungen-search-input {
  padding-left: 34px !important;
}
.bestellungen-toggle {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--text-sm);
  color: var(--color-text-secondary);
  cursor: pointer;
  -webkit-user-select: none;
     -moz-user-select: none;
          user-select: none;
  white-space: nowrap;
}
.bestellungen-table-wrap {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  background: var(--color-bg);
}
.bestellungen-table {
  width: 100%;
  border-collapse: collapse;
  font-size: var(--text-sm);
  min-width: 600px;
}
.bestellungen-th {
  text-align: left;
  padding: var(--space-3);
  font-weight: 600;
  font-size: var(--text-xs);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--color-text-secondary);
  background: var(--color-bg-secondary);
  border-bottom: 2px solid var(--color-border);
  white-space: nowrap;
}
.bestellungen-th--check {
  width: 60px;
  text-align: center;
}
.bestellungen-th--desc {
  min-width: 200px;
}
.bestellungen-th--customer {
  min-width: 120px;
}
.bestellungen-th--staff {
  width: 80px;
  text-align: center;
}
.bestellungen-th--date {
  width: 120px;
  white-space: nowrap;
}
.bestellungen-th--completed, .bestellungen-th--completed-by {
  width: 120px;
  white-space: nowrap;
}
.bestellungen-th--actions {
  width: 40px;
}
.bestellungen-td {
  padding: var(--space-2) var(--space-3);
  border-bottom: 1px solid var(--color-border);
  vertical-align: middle;
  color: var(--color-text);
}
.bestellungen-td--check {
  text-align: center;
}
.bestellungen-td--desc {
  font-weight: 500;
  word-break: break-word;
}
.bestellungen-td--staff, .bestellungen-td--completed-by {
  text-align: center;
}
.bestellungen-td--date, .bestellungen-td--completed {
  font-size: var(--text-xs);
  color: var(--color-text-secondary);
  white-space: nowrap;
}
.bestellungen-td--actions {
  text-align: center;
}
.bestellungen-row:hover {
  background: var(--color-bg-secondary);
}
.bestellungen-row--completed {
  opacity: 0.55;
}
.bestellungen-row--completed:hover {
  opacity: 0.75;
}
.bestellungen-text--done {
  text-decoration: line-through;
  color: var(--color-text-muted);
}
.bestellungen-empty {
  text-align: center;
  padding: var(--space-8) var(--space-4);
  color: var(--color-text-muted);
  font-size: var(--text-sm);
}
.bestellungen-checkbox-wrap {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
}
.bestellungen-checkbox {
  -moz-appearance: none;
       appearance: none;
  -webkit-appearance: none;
  width: 20px;
  height: 20px;
  border: 2px solid var(--color-border-strong);
  border-radius: var(--radius-sm);
  background: var(--color-bg);
  cursor: pointer;
  transition: all var(--transition-fast);
  position: relative;
}
.bestellungen-checkbox:hover {
  border-color: var(--color-primary);
}
.bestellungen-checkbox:checked, .bestellungen-checkbox--done {
  background: var(--color-success);
  border-color: var(--color-success);
}
.bestellungen-checkbox:checked::after {
  content: "";
  position: absolute;
  left: 5px;
  top: 1px;
  width: 6px;
  height: 11px;
  border: solid white;
  border-width: 0 2px 2px 0;
  transform: rotate(45deg);
}
.bestellungen-customer-link {
  color: var(--color-primary);
  text-decoration: none;
  font-size: var(--text-sm);
}
.bestellungen-customer-link:hover {
  text-decoration: underline;
}
.bestellungen-delete-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
  border: none;
  border-radius: var(--radius-sm);
  background: transparent;
  color: var(--color-text-muted);
  cursor: pointer;
  transition: all var(--transition-fast);
  opacity: 0;
}
.bestellungen-row:hover .bestellungen-delete-btn {
  opacity: 1;
}
.bestellungen-delete-btn:hover {
  color: var(--color-danger);
}
.bestellungen-td--staff .tn-member-pill {
  height: 24px;
  font-size: 11px;
  padding: 2px 6px;
}
.bestellungen-staff-pills {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}
.bestellungen-modal-section {
  margin-bottom: var(--space-4);
}
.bestellungen-modal-divider {
  height: 1px;
  background: var(--color-border);
  margin: var(--space-3) 0;
}
.bestellungen-field-error {
  color: var(--color-danger);
  font-size: var(--text-xs);
  margin-top: var(--space-1);
}
.bestellungen-new-row {
  display: flex;
  align-items: flex-start;
  gap: var(--space-2);
  padding: var(--space-3);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  margin-bottom: var(--space-2);
}
.bestellungen-new-row-fields {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}
.bestellungen-new-field {
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
}
.bestellungen-remove-row {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
  border: none;
  border-radius: var(--radius-sm);
  background: transparent;
  color: var(--color-text-muted);
  cursor: pointer;
  flex-shrink: 0;
  margin-top: var(--space-4);
}
.bestellungen-remove-row:hover {
  color: var(--color-danger);
}
.bestellungen-modal-panel {
  overflow: visible;
}
.bestellungen-modal-body {
  overflow: visible;
}
.bestellungen-customer-autocomplete {
  position: relative;
}
.bestellungen-autocomplete-results {
  position: absolute;
  top: 100%;
  left: 0;
  right: 0;
  z-index: 50;
  background: var(--color-bg);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-md);
  max-height: 200px;
  overflow-y: auto;
}
.bestellungen-autocomplete-item {
  display: flex;
  flex-direction: column;
  gap: 2px;
  width: 100%;
  padding: var(--space-2) var(--space-3);
  border: none;
  background: transparent;
  color: var(--color-text);
  text-align: left;
  cursor: pointer;
  font-size: var(--text-sm);
}
.bestellungen-autocomplete-item:hover {
  background: var(--color-bg-secondary);
}
.bestellungen-autocomplete-name {
  font-weight: 500;
}
.bestellungen-autocomplete-detail {
  font-size: var(--text-xs);
  color: var(--color-text-secondary);
}
.bestellungen-detected {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--space-1) var(--space-2);
  margin-top: var(--space-1);
  font-size: var(--text-xs);
  color: var(--color-text-secondary);
}
.bestellungen-detected-label {
  color: var(--color-text-muted);
}
.bestellungen-detected-name {
  font-weight: 600;
  color: var(--color-text);
}
.bestellungen-detected-ws {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--space-1);
}
.bestellungen-ws-pill {
  display: inline-flex;
  align-items: center;
  padding: 1px 8px;
  font-size: 10px;
  font-weight: 500;
  background: var(--color-bg-secondary);
  color: var(--color-primary);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-full);
  text-decoration: none;
  white-space: nowrap;
  transition: all var(--transition-fast);
}
.bestellungen-ws-pill:hover {
  background: var(--color-primary);
  color: white;
  border-color: var(--color-primary);
  text-decoration: none;
}
.bestellungen-complete-desc {
  font-weight: 500;
  font-size: var(--text-sm);
  color: var(--color-text);
  margin-bottom: var(--space-4);
  padding: var(--space-3);
  background: var(--color-bg-secondary);
  border-radius: var(--radius-md);
}
.modal-panel--sm {
  max-width: 440px;
}
@media (max-width: 640px) {
  .bestellungen-header {
    flex-direction: row;
    align-items: center;
    gap: var(--space-2);
  }
  .bestellungen-header h1 {
    font-size: var(--text-lg);
  }
  .bestellungen-filter-bar {
    flex-direction: column;
    align-items: stretch;
  }
  .bestellungen-search-wrap {
    max-width: 100%;
  }
  .bestellungen-new-row {
    flex-direction: column;
  }
  .bestellungen-table-wrap {
    margin-left: calc(-1 * var(--space-4, 16px));
    margin-right: calc(-1 * var(--space-4, 16px));
    border-radius: 0;
    border-left: none;
    border-right: none;
  }
}
.info-modal .modal-panel {
  max-width: 480px;
  border-radius: var(--radius-lg);
  overflow: hidden;
}
.info-modal .modal-header {
  position: absolute;
  top: 0;
  right: 0;
  z-index: 2;
  padding: var(--space-3) var(--space-4);
  background: none;
  border: none;
}
.info-modal .modal-body {
  padding: 0;
  overflow-y: auto;
  max-height: 85vh;
}
.info-modal .modal-footer {
  display: none;
}
.info-modal__content {
  padding: var(--space-5) var(--space-5) var(--space-6);
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}
.info-modal__hero {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  padding-bottom: var(--space-4);
  border-bottom: 1px solid var(--color-border);
}
.info-modal__name {
  font-size: 22px;
  font-weight: 700;
  line-height: 1.2;
  color: var(--color-text);
  margin: 0;
  padding-right: 40px;
}
.info-modal__type {
  font-size: 12px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--color-text-muted);
}
.info-modal__website {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: var(--text-sm);
  color: var(--color-primary);
  text-decoration: none;
}
.info-modal__website:hover {
  text-decoration: underline;
}
.info-modal__website svg {
  flex-shrink: 0;
  opacity: 0.7;
}
.info-modal__detail-btn {
  align-self: flex-start;
  margin-top: var(--space-1);
}
.info-modal__card {
  background: var(--color-bg-elevated, var(--color-bg-secondary));
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: var(--space-4);
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}
.info-modal__card-header {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  font-size: 13px;
  font-weight: 700;
  color: var(--color-text);
  text-transform: uppercase;
  letter-spacing: 0.04em;
}
.info-modal__card-header svg {
  flex-shrink: 0;
  color: var(--color-text-muted);
}
.info-modal__rows {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}
.info-modal__row {
  display: flex;
  align-items: flex-start;
  gap: var(--space-3);
}
.info-modal__row-icon {
  flex-shrink: 0;
  width: 20px;
  display: flex;
  align-items: center;
  justify-content: center;
  padding-top: 2px;
  color: var(--color-text-muted);
}
.info-modal__row-icon svg {
  flex-shrink: 0;
}
.info-modal__row-content {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 1px;
}
.info-modal__label {
  font-size: 11px;
  font-weight: 600;
  color: var(--color-text-muted);
  text-transform: uppercase;
  letter-spacing: 0.03em;
}
.info-modal__value {
  font-size: var(--text-sm);
  font-weight: 500;
  color: var(--color-text);
  word-break: break-word;
}
.info-modal__value--link {
  color: var(--color-primary);
  text-decoration: none;
}
.info-modal__value--link:hover {
  text-decoration: underline;
}
.info-modal__pills {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}
.info-modal__pill {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 6px 14px;
  font-size: 12px;
  font-weight: 500;
  color: var(--color-primary);
  background: var(--color-bg);
  border: 1px solid var(--color-border-strong);
  border-radius: var(--radius-full);
  cursor: pointer;
  transition: all var(--transition-fast);
}
.info-modal__pill:hover {
  background: var(--color-primary);
  color: #fff;
  border-color: var(--color-primary);
}
.info-modal__pill svg {
  width: 12px;
  height: 12px;
  flex-shrink: 0;
}
.info-modal__address {
  font-size: var(--text-sm);
  font-weight: 500;
  line-height: 1.7;
  color: var(--color-text);
}
.info-modal__notes-list {
  list-style: none;
  margin: 0;
  padding: 0;
  font-size: var(--text-sm);
  color: var(--color-text-secondary);
  line-height: 1.7;
}
.info-modal__notes-list li {
  padding: 1px 0;
}
.info-modal__notes-list li::before {
  content: "•";
  display: inline-block;
  width: 16px;
  color: var(--color-text-muted);
  font-weight: 700;
}
.info-modal__warn {
  margin-top: var(--space-2);
  padding: var(--space-3) var(--space-4);
  background: var(--color-warning-bg);
  border-radius: var(--radius-sm);
  border-left: 3px solid var(--color-warning);
}
.info-modal__warn .info-modal__notes-list {
  color: var(--color-text);
}
.info-modal__loading {
  text-align: center;
  padding: var(--space-8);
  color: var(--color-text-muted);
  font-size: var(--text-sm);
}
.dark .info-modal__card {
  background: rgba(255, 255, 255, 0.04);
  border-color: rgba(255, 255, 255, 0.08);
}
.dark .info-modal__pill {
  background: rgba(255, 255, 255, 0.05);
  border-color: rgba(255, 255, 255, 0.12);
}
.dark .info-modal__pill:hover {
  background: var(--color-primary);
  color: #fff;
}
@media (max-width: 640px) {
  .info-modal .modal-panel {
    max-width: 100%;
    margin: var(--space-3);
  }
  .info-modal__content {
    padding: var(--space-4) var(--space-4) var(--space-5);
  }
  .info-modal__name {
    font-size: 20px;
  }
  .info-modal__card {
    padding: var(--space-3);
  }
}
.wb-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 20px;
}
.wb-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 24px;
}
.wb-grid--full {
  grid-template-columns: 1fr;
}
.wb-card-pad {
  padding: 20px;
}
.wb-section-title {
  margin-bottom: 12px;
}
.wb-relative {
  position: relative;
}
.wb-mb-8 {
  margin-bottom: 8px;
}
.wb-mb-12 {
  margin-bottom: 12px;
}
.wb-mb-16 {
  margin-bottom: 16px;
}
.wb-form-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
}
.wb-crm-badge {
  margin-top: 6px;
  display: flex;
  align-items: center;
  gap: 8px;
}
.wb-dropdown {
  position: absolute;
  top: 100%;
  left: 0;
  right: 0;
  z-index: 50;
  background: var(--color-bg, white);
  border: 1px solid var(--color-border, #e5e7eb);
  border-radius: 8px;
  box-shadow: 0 4px 12px rgba(0,0,0,0.1);
  max-height: 240px;
  overflow-y: auto;
  margin-top: 4px;
}
.wb-dropdown-item {
  display: block;
  width: 100%;
  text-align: left;
  padding: 10px 14px;
  border: none;
  background: none;
  cursor: pointer;
  border-bottom: 1px solid var(--color-border, #f3f4f6);
}
.wb-dropdown-item:hover {
  background: var(--color-bg-secondary);
}
.wb-submit-area {
  margin-top: 24px;
}
.wb-submit-area .btn {
  width: 100%;
  padding: 16px;
  font-size: 16px;
}
@media (max-width: 768px) {
  .wb-grid {
    grid-template-columns: 1fr;
  }
}
.dark .wb-dropdown {
  background: var(--color-bg);
  box-shadow: 0 4px 12px rgba(0,0,0,0.3);
}
.aufgaben-dot--best {
  background: var(--color-primary);
}
.aufgaben-dot--pf {
  background: var(--color-accent, #8B5CF6);
}
.aufgaben-dot--note {
  background: #F59E0B;
}
.aufgaben-chip--best.termine-filter-chip--active {
  background: var(--color-primary);
  border-color: var(--color-primary);
}
.aufgaben-chip--pf.termine-filter-chip--active {
  background: var(--color-accent, #8B5CF6);
  border-color: var(--color-accent, #8B5CF6);
}
.aufgaben-chip--note.termine-filter-chip--active {
  background: #F59E0B;
  border-color: #F59E0B;
}
.aufgaben-type-pill {
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  padding: 1px 6px;
  border-radius: var(--radius-sm);
  flex-shrink: 0;
}
.aufgaben-type-pill--best {
  background: var(--color-primary);
  color: #fff;
}
.aufgaben-type-pill--pf {
  background: var(--color-accent, #8B5CF6);
  color: #fff;
}
.aufgaben-type-pill--note {
  background: #F59E0B;
  color: #fff;
}
.aufgaben-dept-badge {
  display: inline-flex;
  align-items: center;
  padding: 1px 8px;
  border-radius: var(--radius-sm);
  font-size: var(--text-xs);
  font-weight: 600;
}
.aufgaben-dept-badge--sales {
  background: rgba(16, 185, 129, 0.15);
  color: #059669;
}
.aufgaben-dept-badge--workshop {
  background: rgba(59, 130, 246, 0.15);
  color: #2563EB;
}
.dark .aufgaben-dept-badge--sales {
  background: rgba(16, 185, 129, 0.25);
  color: #34D399;
}
.dark .aufgaben-dept-badge--workshop {
  background: rgba(59, 130, 246, 0.25);
  color: #60A5FA;
}
.aufgaben-chip--note-dept.termine-filter-chip--active {
  background: var(--chip-active-bg, #6B7280);
  border-color: var(--chip-active-border, #6B7280);
}
.aufgaben-item--completed {
  opacity: 0.6;
}
.aufgaben-text--done {
  text-decoration: line-through;
  color: var(--color-text-muted);
}
.aufgaben-model-tag {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 1px 6px;
  background: var(--color-bg-secondary);
  border-radius: var(--radius-sm);
  font-size: var(--text-xs);
  color: var(--color-text-secondary);
  white-space: nowrap;
}
.aufgaben-models-section {
  margin-bottom: var(--space-3);
}
.aufgaben-model-row {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-2) 0;
  border-bottom: 1px solid var(--color-border);
  font-size: var(--text-sm);
}
.aufgaben-model-row:last-child {
  border-bottom: none;
}
.aufgaben-model-name {
  flex: 1;
  min-width: 0;
  color: var(--color-text);
}
.aufgaben-search-wrap {
  position: relative;
  flex: 0 1 220px;
  min-width: 160px;
}
.aufgaben-search-icon {
  position: absolute;
  left: var(--space-3);
  top: 50%;
  transform: translateY(-50%);
  color: var(--color-text-muted);
  pointer-events: none;
}
.aufgaben-search-input {
  padding-left: calc(var(--space-3) + 20px) !important;
  height: 28px;
  padding-top: 2px;
  padding-bottom: 2px;
  font-size: var(--text-sm);
  box-sizing: border-box;
}
.aufgaben-staff-filters {
  margin-bottom: var(--space-3);
}
.aufgaben-toggle {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--text-sm);
  color: var(--color-text-secondary);
  cursor: pointer;
  white-space: nowrap;
}
@media (max-width: 767px) {
  .aufgaben-model-row {
    flex-wrap: wrap;
  }
  .aufgaben-search-wrap {
    flex: 1;
    min-width: 0;
  }
}
.dark .aufgaben-model-tag {
  background: var(--color-bg-tertiary, var(--color-bg-secondary));
}
.probefahrt-back-link {
  margin-bottom: var(--space-2);
}
.probefahrt-form {
  max-width: 680px;
}
.probefahrt-section {
  margin-bottom: var(--space-6);
  padding-bottom: var(--space-6);
  border-bottom: 1px solid var(--color-border);
}
.probefahrt-section:last-of-type {
  border-bottom: none;
}
.probefahrt-section-title {
  font-size: var(--text-base);
  font-weight: 600;
  color: var(--color-text);
  margin: 0 0 var(--space-3);
}
.probefahrt-label {
  display: block;
  font-size: var(--text-sm);
  font-weight: 500;
  color: var(--color-text-secondary);
  margin-bottom: var(--space-1);
}
.probefahrt-fields {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-3);
}
@media (max-width: 767px) {
  .probefahrt-fields {
    grid-template-columns: 1fr;
  }
}
.probefahrt-field {
  margin-bottom: var(--space-3);
}
.probefahrt-field--short {
  max-width: 200px;
}
.probefahrt-textarea {
  resize: vertical;
  min-height: 80px;
}
.probefahrt-customer-search {
  position: relative;
}
.probefahrt-crm-badge {
  margin-top: var(--space-1);
}
.probefahrt-brand-label {
  font-size: var(--text-xs);
  font-weight: 600;
  color: var(--color-text-muted);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  margin-bottom: var(--space-2);
  margin-top: var(--space-3);
}
.probefahrt-brand-label:first-child {
  margin-top: 0;
}
.probefahrt-termin-switch {
  padding: var(--space-2) 0;
  margin-bottom: var(--space-2);
}
.probefahrt-termin-toggle {
  display: inline-flex;
  align-items: center;
  gap: var(--space-3);
}
.probefahrt-termin-label {
  font-size: 0.875rem;
  color: var(--color-text-secondary);
  transition: color var(--transition-fast), font-weight var(--transition-fast);
  -webkit-user-select: none;
     -moz-user-select: none;
          user-select: none;
}
.probefahrt-termin-label--active {
  color: var(--color-text);
  font-weight: 600;
}
.probefahrt-schedule {
  padding: var(--space-3) var(--space-4);
  background: var(--color-bg-secondary);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
}
.dark .probefahrt-schedule {
  background: var(--color-bg-tertiary);
}
.probefahrt-schedule-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-3);
}
.probefahrt-schedule-grid--times {
  margin-top: var(--space-3);
}
.probefahrt-schedule-field {
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
}
.probefahrt-date-input {
  min-height: 44px;
  font-size: 16px;
  -webkit-appearance: none;
  -moz-appearance: none;
       appearance: none;
}
@media (max-width: 480px) {
  .probefahrt-schedule-grid {
    grid-template-columns: 1fr;
    gap: var(--space-2);
  }
  .probefahrt-date-input {
    width: 100%;
    font-size: 16px;
  }
}
.probefahrt-brands {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--space-2);
}
@media (min-width: 768px) {
  .probefahrt-brands {
    grid-template-columns: repeat(3, 1fr);
  }
}
@media (min-width: 1024px) {
  .probefahrt-brands {
    grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
  }
}
.probefahrt-brand-btn {
  width: 100%;
  padding: var(--space-2) var(--space-3);
  background: var(--color-bg);
  border: 2px solid var(--color-border);
  border-radius: var(--radius-lg);
  font-size: var(--text-sm);
  font-weight: 500;
  font-family: var(--font-sans);
  color: var(--color-text);
  cursor: pointer;
  transition: border-color var(--transition-fast), background var(--transition-fast);
  text-align: center;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  box-sizing: border-box;
}
.probefahrt-brand-btn:hover {
  border-color: var(--color-primary);
}
.probefahrt-brand-btn--active {
  border-color: var(--color-primary);
  background: var(--color-primary);
  color: #fff;
}
.probefahrt-brand-btn--other {
  border-style: dashed;
  color: var(--color-text-muted);
}
.probefahrt-brand-count {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 18px;
  height: 18px;
  border-radius: 9px;
  background: var(--color-primary);
  color: #fff;
  font-size: 11px;
  font-weight: 600;
  margin-left: var(--space-1);
  padding: 0 5px;
}
.probefahrt-brand-btn--active .probefahrt-brand-count {
  background: rgba(255, 255, 255, 0.3);
}
.probefahrt-brand-custom {
  margin-top: var(--space-3);
}
.probefahrt-custom-search {
  margin-top: var(--space-2);
  position: relative;
  max-width: 320px;
}
.probefahrt-model-chips {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  margin-bottom: var(--space-3);
}
.probefahrt-model-input {
  position: relative;
  max-width: 400px;
}
.probefahrt-hint {
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  margin-bottom: var(--space-3);
}
.probefahrt-submit {
  padding-top: var(--space-4);
}
.probefahrt-success {
  text-align: center;
  padding: var(--space-10) var(--space-4);
}
.probefahrt-success-icon {
  color: var(--color-success);
  margin-bottom: var(--space-4);
}
.probefahrt-success h2 {
  font-size: var(--text-xl);
  font-weight: 600;
  color: var(--color-text);
  margin: 0 0 var(--space-2);
}
.probefahrt-success p {
  color: var(--color-text-muted);
  margin-bottom: var(--space-6);
}
.probefahrt-success-actions {
  display: flex;
  gap: var(--space-3);
  justify-content: center;
}
.dark .probefahrt-brand-btn {
  background: var(--color-bg);
}
.dark .probefahrt-brand-btn--active {
  background: var(--color-primary);
}
.probefahrt-vehicle-card {
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: var(--space-4);
  margin-bottom: var(--space-3);
  background: var(--color-bg);
}
.probefahrt-vehicle-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--space-3);
}
.probefahrt-vehicle-num {
  font-weight: 600;
  font-size: var(--text-sm);
  color: var(--color-text-secondary);
}
.probefahrt-chevron-icon {
  transition: transform var(--transition-fast);
}
.rotate-90 {
  transform: rotate(90deg);
}
.probefahrt-field--long {
  flex: 2;
}
.dark .probefahrt-vehicle-card {
  background: var(--color-bg-secondary);
  border-color: var(--color-border);
}
.ap-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 16px;
  flex-wrap: wrap;
  gap: 8px;
}
.ap-month-nav {
  display: flex;
  align-items: center;
  gap: 8px;
}
.ap-month-nav-btn {
  background: none;
  border: 1px solid var(--color-border, #e0e0e0);
  border-radius: var(--radius-sm, 4px);
  padding: 4px 8px;
  cursor: pointer;
  color: var(--color-text, #333);
  font-size: 14px;
  line-height: 1;
}
.ap-month-nav-btn:hover {
  background: var(--color-bg-hover, #f5f5f5);
}
.ap-month-label {
  font-size: 16px;
  font-weight: 600;
  min-width: 140px;
  text-align: center;
}
.ap-actions {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}
.ap-info-bar {
  background: rgba(253, 224, 71, 0.18);
  border: 1px solid rgba(253, 224, 71, 0.4);
  border-radius: var(--radius-sm, 4px);
  padding: 6px 12px;
  margin-bottom: 10px;
  font-size: 13px;
  color: var(--color-text, #333);
}
.dark .ap-info-bar, [data-theme="dark"] .ap-info-bar {
  background: rgba(253, 224, 71, 0.08);
  border-color: rgba(253, 224, 71, 0.2);
}
.ap-timeline-wrap {
  overflow-x: auto;
  margin-bottom: 16px;
  border: 1px solid var(--color-border, #e0e0e0);
  border-radius: var(--radius-md, 8px);
}
.ap-timeline {
  display: grid;
  min-width: 100%;
  font-size: 11px;
}
.ap-timeline-header {
  display: contents;
}
.ap-timeline-header-cell {
  padding: 6px 2px;
  text-align: center;
  font-weight: 600;
  font-size: 10px;
  background: var(--color-bg-subtle, #fafafa);
  border-bottom: 1px solid var(--color-border, #e0e0e0);
  position: sticky;
  top: 0;
  z-index: 2;
}
.ap-timeline-header-cell--staff {
  position: sticky;
  left: 0;
  z-index: 3;
  background: var(--color-bg-subtle, #fafafa);
  text-align: left;
  padding-left: 8px;
  min-width: 80px;
  font-size: 11px;
}
.ap-timeline-header-cell--weekend {
  background: var(--color-bg-muted, #f0f0f0);
}
.ap-timeline-header-cell--closed {
  background: var(--color-bg-muted, #f0f0f0);
  opacity: 0.6;
}
.ap-timeline-header-cell--today {
  background: var(--color-primary-light, #dbeafe);
  color: var(--color-primary, #3b82f6);
}
.ap-timeline-header-day {
  display: block;
  font-size: 10px;
  opacity: 0.6;
}
.ap-timeline-row {
  display: contents;
}
.ap-timeline-staff {
  position: sticky;
  left: 0;
  z-index: 2;
  background: var(--color-bg, #fff);
  padding: 6px 8px;
  font-size: 11px;
  font-weight: 500;
  border-bottom: 1px solid var(--color-border-light, #f0f0f0);
  display: flex;
  align-items: center;
  gap: 4px;
  white-space: nowrap;
  min-width: 80px;
}
.ap-timeline-staff-avatar {
  width: 18px;
  height: 18px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 8px;
  font-weight: 700;
  color: #fff;
  flex-shrink: 0;
}
.ap-timeline-cell {
  padding: 2px 1px;
  border-bottom: 1px solid var(--color-border-light, #f0f0f0);
  border-right: 1px solid var(--color-border-light, #f0f0f0);
  min-width: 28px;
  min-height: 30px;
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
}
.ap-timeline-cell--clickable {
  cursor: pointer;
}
.ap-timeline-cell--clickable:hover {
  background: var(--color-bg-hover, #f5f5f5);
}
.ap-timeline-cell--weekend {
  background: rgba(0, 0, 0, 0.02);
}
.ap-timeline-cell--closure {
  background: repeating-linear-gradient( 45deg, rgba(156, 163, 175, 0.08), rgba(156, 163, 175, 0.08) 4px, transparent 4px, transparent 8px );
}
.ap-timeline-cell--conflict {
  box-shadow: inset 0 0 0 2px var(--color-error, #dc2626);
}
.ap-timeline-cell--today {
  background: rgba(59, 130, 246, 0.05);
}
.ap-timeline-cell--vacation {
  background: rgba(34, 197, 94, 0.12);
}
.ap-timeline-cell--sick {
  background: rgba(249, 115, 22, 0.12);
}
.ap-cell-checks {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 1px;
  width: 100%;
}
.ap-check {
  font-size: 13px;
  font-weight: 700;
  line-height: 1;
}
.ap-cell-free {
  font-size: 12px;
  color: var(--color-text-muted, #9ca3af);
  font-weight: 500;
  line-height: 1;
}
.ap-cell-badge {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 20px;
  height: 20px;
  border-radius: 50%;
  font-size: 11px;
  font-weight: 700;
  line-height: 1;
}
.ap-cell-badge--vacation {
  background: #22c55e;
  color: #fff;
}
.ap-cell-badge--sick {
  background: #f97316;
  color: #fff;
}
.ap-cell-menu {
  position: absolute;
  z-index: 50;
  background: var(--color-bg, #fff);
  border: 1px solid var(--color-border, #e0e0e0);
  border-radius: var(--radius-md, 8px);
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.12);
  min-width: 200px;
  padding: 4px 0;
}
.ap-cell-menu-header {
  padding: 6px 12px;
  font-size: 11px;
  font-weight: 600;
  color: var(--color-text-secondary, #666);
  border-bottom: 1px solid var(--color-border-light, #f0f0f0);
}
.ap-cell-menu-item {
  display: flex;
  align-items: center;
  gap: 8px;
  width: 100%;
  padding: 8px 12px;
  font-size: 13px;
  color: var(--color-text, #333);
  background: none;
  border: none;
  cursor: pointer;
  text-align: left;
}
.ap-cell-menu-item:hover {
  background: var(--color-bg-hover, #f5f5f5);
}
.ap-cell-menu-icon {
  font-size: 14px;
  width: 20px;
  text-align: center;
  flex-shrink: 0;
}
.ap-legend {
  display: flex;
  gap: 16px;
  font-size: 11px;
  color: var(--color-text-secondary, #666);
  margin-bottom: 8px;
  flex-wrap: wrap;
}
.ap-legend-item {
  display: flex;
  align-items: center;
  gap: 4px;
}
.ap-legend-swatch {
  width: 12px;
  height: 8px;
  border-radius: 4px;
  display: inline-block;
}
.ap-legend-swatch--vacation {
  background: #22c55e;
}
.ap-legend-swatch--sick {
  background: #f97316;
}
.ap-legend-swatch--closure {
  background: repeating-linear-gradient(45deg, #9ca3af, #9ca3af 2px, transparent 2px, transparent 4px);
}
.ap-warnings {
  margin-bottom: 12px;
}
.ap-warning-item {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 6px 10px;
  background: #fef3c7;
  border: 1px solid #fde68a;
  border-radius: var(--radius-sm, 4px);
  font-size: 12px;
  color: #92400e;
  margin-bottom: 4px;
}
.ap-warning-item--info {
  background: #dbeafe;
  border-color: #bfdbfe;
  color: #1e40af;
}
.ap-vacation-account {
  margin-bottom: 16px;
}
.ap-vacation-account-title {
  font-size: 13px;
  font-weight: 600;
  margin-bottom: 8px;
  color: var(--color-text, #333);
}
.ap-list-filters {
  display: flex;
  gap: 8px;
  margin-bottom: 10px;
  flex-wrap: wrap;
  align-items: center;
}
.ap-scope-toggle {
  display: flex;
  gap: 4px;
}
.ap-list-filter {
  font-size: 12px;
  padding: 4px 8px;
  border: 1px solid var(--color-border, #e0e0e0);
  border-radius: var(--radius-sm, 4px);
  background: var(--color-bg, #fff);
  color: var(--color-text, #333);
}
.ap-list {
  margin-bottom: 16px;
}
.ap-list-item {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 8px 10px;
  border-bottom: 1px solid var(--color-border-light, #f0f0f0);
  font-size: 13px;
  flex-wrap: wrap;
}
.ap-list-item:last-child {
  border-bottom: none;
}
.ap-list-item-warning {
  font-size: 11px;
  color: #92400e;
  background: #fef3c7;
  padding: 1px 6px;
  border-radius: 10px;
}
.ap-form-section {
  margin-bottom: 16px;
  padding-top: 12px;
  border-top: 1px solid var(--color-border-light, #f0f0f0);
}
.ap-form-title {
  font-size: 13px;
  font-weight: 600;
  margin-bottom: 8px;
}
.ap-form-warnings {
  margin-top: 8px;
}
.ap-form-warning {
  display: flex;
  align-items: center;
  gap: 4px;
  padding: 4px 8px;
  background: #fef3c7;
  border-radius: var(--radius-sm, 4px);
  font-size: 12px;
  color: #92400e;
  margin-bottom: 4px;
}
.ap-section {
  margin-bottom: 20px;
  position: relative;
}
.ap-plan-table {
  border-collapse: collapse;
  width: 100%;
}
.ap-plan-th {
  text-align: center;
  font-size: 11px;
  font-weight: 600;
  padding: 6px 4px;
  min-width: 36px;
  white-space: nowrap;
  background: var(--color-bg-subtle, #fafafa);
  border-bottom: 2px solid var(--color-border, #e0e0e0);
}
.ap-plan-th--weekend {
  background: var(--color-bg-muted, #f0f0f0);
  color: var(--color-text-muted, #9ca3af);
}
.ap-plan-th--closed {
  background: var(--color-bg-muted, #f0f0f0);
  opacity: 0.5;
}
.ap-plan-th--today {
  background: var(--color-primary-light, #dbeafe);
  color: var(--color-primary, #3b82f6);
}
.ap-plan-staff-th {
  text-align: left;
  font-size: 12px;
  font-weight: 600;
  padding: 8px 10px;
  min-width: 200px;
  white-space: nowrap;
  background: var(--color-bg-subtle, #fafafa);
  border-bottom: 2px solid var(--color-border, #e0e0e0);
  position: sticky;
  left: 0;
  z-index: 2;
}
.ap-plan-staff-td {
  padding: 6px 8px;
  font-size: 12px;
  font-weight: 500;
  white-space: nowrap;
  display: flex;
  align-items: center;
  gap: 6px;
  min-width: 200px;
  position: sticky;
  left: 0;
  z-index: 1;
  background: var(--color-bg, #fff);
  border-bottom: 1px solid var(--color-border-light, #f0f0f0);
}
.ap-plan-staff-name {
  font-weight: 600;
  font-size: 12px;
}
.ap-plan-staff-pills {
  display: inline-flex;
  gap: 2px;
  margin-left: 2px;
}
.ap-plan-staff-pills .pill {
  font-size: 9px;
  padding: 1px 4px;
  line-height: 1.2;
}
.ap-plan-td {
  text-align: center;
  vertical-align: middle;
  padding: 4px 2px;
  min-width: 36px;
  min-height: 38px;
  cursor: pointer;
  border-bottom: 1px solid var(--color-border-light, #f0f0f0);
  transition: background 0.1s;
}
.ap-plan-td:hover {
  background: var(--color-bg-hover, #f5f5f5);
}
.ap-plan-td--closed {
  background: repeating-linear-gradient( 45deg, rgba(156, 163, 175, 0.06), rgba(156, 163, 175, 0.06) 4px, transparent 4px, transparent 8px );
  cursor: default;
}
.ap-plan-td--closed:hover {
  background: repeating-linear-gradient( 45deg, rgba(156, 163, 175, 0.06), rgba(156, 163, 175, 0.06) 4px, transparent 4px, transparent 8px );
}
.ap-plan-td--weekend {
  background: rgba(0, 0, 0, 0.015);
}
.ap-plan-td--today {
  background: rgba(59, 130, 246, 0.06);
}
.ap-plan-td--vacation {
  background: rgba(253, 224, 71, 0.35);
  cursor: default;
}
.ap-plan-td--vacation:hover {
  background: rgba(253, 224, 71, 0.35);
}
.ap-plan-td--sick {
  background: rgba(147, 197, 253, 0.35);
  cursor: default;
}
.ap-plan-td--sick:hover {
  background: rgba(147, 197, 253, 0.35);
}
.ap-plan-td--conflict {
  box-shadow: inset 0 0 0 2px var(--color-error, #dc2626);
}
.rot-cell-active {
  background: rgba(34, 197, 94, 0.10);
}
.ap-col-hover {
  background-color: rgba(59, 130, 246, 0.08) !important;
}
.ap-plan-th--week-start, .ap-plan-td--week-start {
  border-left: 3px solid var(--color-border, #d1d5db);
}
.ap-plan-checks {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 1px;
}
.ap-plan-check {
  font-size: 15px;
  font-weight: 700;
  line-height: 1;
}
.ap-plan-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 22px;
  height: 22px;
  border-radius: 50%;
  font-size: 11px;
  font-weight: 700;
  line-height: 1;
  color: #fff;
}
.ap-plan-badge--vacation {
  background: #22c55e;
}
.ap-plan-badge--sick {
  background: #f97316;
}
.ap-plan-badge--holiday {
  background: #8b5cf6;
  font-size: 9px;
}
.ap-plan-badge--closure {
  background: #6366f1;
  font-size: 8px;
  letter-spacing: -0.5px;
}
.ap-plan-th-marker {
  font-size: 8px;
  font-weight: 700;
  line-height: 1;
  border-radius: 3px;
  padding: 1px 3px;
  margin-top: 1px;
  color: #fff;
}
.ap-plan-th-marker--holiday {
  background: #8b5cf6;
}
.ap-plan-th-marker--closure {
  background: #6366f1;
}
.ap-plan-th--holiday {
  background: rgba(139, 92, 246, 0.12);
}
.ap-plan-th--closure {
  background: rgba(99, 102, 241, 0.12);
}
.ap-plan-td--holiday {
  background: rgba(139, 92, 246, 0.06);
}
.ap-plan-td--closure {
  background: rgba(99, 102, 241, 0.06);
}
.ap-legend-badge {
  width: 18px;
  height: 18px;
  font-size: 10px;
}
.ap-legend-item--hint {
  font-style: italic;
  opacity: 0.7;
}
.dark .ap-month-nav-btn, [data-theme="dark"] .ap-month-nav-btn {
  border-color: var(--color-border, #374151);
  color: var(--color-text, #e5e7eb);
}
.dark .ap-month-nav-btn:hover, [data-theme="dark"] .ap-month-nav-btn:hover {
  background: var(--color-bg-hover, #374151);
}
.dark .ap-timeline-header-cell, [data-theme="dark"] .ap-timeline-header-cell {
  background: var(--color-bg-subtle, #1f2937);
  border-color: var(--color-border, #374151);
}
.dark .ap-timeline-header-cell--staff, [data-theme="dark"] .ap-timeline-header-cell--staff {
  background: var(--color-bg-subtle, #1f2937);
}
.dark .ap-timeline-header-cell--weekend, [data-theme="dark"] .ap-timeline-header-cell--weekend {
  background: var(--color-bg-muted, #111827);
}
.dark .ap-timeline-header-cell--closed, [data-theme="dark"] .ap-timeline-header-cell--closed {
  background: var(--color-bg-muted, #111827);
}
.dark .ap-timeline-staff, [data-theme="dark"] .ap-timeline-staff {
  background: var(--color-bg, #111827);
  border-color: var(--color-border, #374151);
}
.dark .ap-timeline-cell, [data-theme="dark"] .ap-timeline-cell {
  border-color: var(--color-border, #374151);
}
.dark .ap-timeline-cell--clickable:hover, [data-theme="dark"] .ap-timeline-cell--clickable:hover {
  background: var(--color-bg-hover, #1f2937);
}
.dark .ap-timeline-cell--weekend, [data-theme="dark"] .ap-timeline-cell--weekend {
  background: rgba(255, 255, 255, 0.02);
}
.dark .ap-timeline-cell--closure, [data-theme="dark"] .ap-timeline-cell--closure {
  background: repeating-linear-gradient(45deg, rgba(156,163,175,0.12), rgba(156,163,175,0.12) 4px, transparent 4px, transparent 8px);
}
.dark .ap-timeline-cell--vacation, [data-theme="dark"] .ap-timeline-cell--vacation {
  background: rgba(34, 197, 94, 0.15);
}
.dark .ap-timeline-cell--sick, [data-theme="dark"] .ap-timeline-cell--sick {
  background: rgba(249, 115, 22, 0.15);
}
.dark .ap-timeline-wrap, [data-theme="dark"] .ap-timeline-wrap {
  border-color: var(--color-border, #374151);
}
.dark .ap-cell-free, [data-theme="dark"] .ap-cell-free {
  color: var(--color-text-muted, #6b7280);
}
.dark .ap-cell-menu, [data-theme="dark"] .ap-cell-menu {
  background: var(--color-bg, #1f2937);
  border-color: var(--color-border, #374151);
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.3);
}
.dark .ap-cell-menu-header, [data-theme="dark"] .ap-cell-menu-header {
  color: var(--color-text-secondary, #9ca3af);
  border-color: var(--color-border, #374151);
}
.dark .ap-cell-menu-item, [data-theme="dark"] .ap-cell-menu-item {
  color: var(--color-text, #e5e7eb);
}
.dark .ap-cell-menu-item:hover, [data-theme="dark"] .ap-cell-menu-item:hover {
  background: var(--color-bg-hover, #374151);
}
.dark .ap-warning-item, [data-theme="dark"] .ap-warning-item {
  background: #78350f;
  border-color: #92400e;
  color: #fef3c7;
}
.dark .ap-warning-item--info, [data-theme="dark"] .ap-warning-item--info {
  background: #1e3a5f;
  border-color: #1e40af;
  color: #dbeafe;
}
.dark .ap-list-item, [data-theme="dark"] .ap-list-item {
  border-color: var(--color-border, #374151);
}
.dark .ap-list-item-warning, [data-theme="dark"] .ap-list-item-warning {
  background: #78350f;
  color: #fef3c7;
}
.dark .ap-form-warning, [data-theme="dark"] .ap-form-warning {
  background: #78350f;
  color: #fef3c7;
}
.dark .ap-form-section, [data-theme="dark"] .ap-form-section {
  border-color: var(--color-border, #374151);
}
.dark .ap-list-filter, [data-theme="dark"] .ap-list-filter {
  background: var(--color-bg, #111827);
  border-color: var(--color-border, #374151);
  color: var(--color-text, #e5e7eb);
}
.dark .ap-plan-th, [data-theme="dark"] .ap-plan-th {
  background: var(--color-bg-subtle, #1f2937);
  border-color: var(--color-border, #374151);
}
.dark .ap-plan-th--weekend, [data-theme="dark"] .ap-plan-th--weekend {
  background: var(--color-bg-muted, #111827);
  color: var(--color-text-muted, #6b7280);
}
.dark .ap-plan-th--closed, [data-theme="dark"] .ap-plan-th--closed {
  background: var(--color-bg-muted, #111827);
}
.dark .ap-plan-th--holiday, [data-theme="dark"] .ap-plan-th--holiday {
  background: rgba(139, 92, 246, 0.18);
}
.dark .ap-plan-th--closure, [data-theme="dark"] .ap-plan-th--closure {
  background: rgba(99, 102, 241, 0.18);
}
.dark .ap-plan-td--holiday, [data-theme="dark"] .ap-plan-td--holiday {
  background: rgba(139, 92, 246, 0.10);
}
.dark .ap-plan-td--closure, [data-theme="dark"] .ap-plan-td--closure {
  background: rgba(99, 102, 241, 0.10);
}
.dark .ap-plan-staff-th, [data-theme="dark"] .ap-plan-staff-th {
  background: var(--color-bg-subtle, #1f2937);
  border-color: var(--color-border, #374151);
}
.dark .ap-plan-staff-td, [data-theme="dark"] .ap-plan-staff-td {
  background: var(--color-bg, #111827);
  border-color: var(--color-border, #374151);
}
.dark .ap-plan-td, [data-theme="dark"] .ap-plan-td {
  border-color: var(--color-border, #374151);
}
.dark .ap-plan-td:hover, [data-theme="dark"] .ap-plan-td:hover {
  background: var(--color-bg-hover, #1f2937);
}
.dark .ap-plan-td--closed, [data-theme="dark"] .ap-plan-td--closed {
  background: repeating-linear-gradient(45deg, rgba(156,163,175,0.10), rgba(156,163,175,0.10) 4px, transparent 4px, transparent 8px);
}
.dark .ap-plan-td--closed:hover, [data-theme="dark"] .ap-plan-td--closed:hover {
  background: repeating-linear-gradient(45deg, rgba(156,163,175,0.10), rgba(156,163,175,0.10) 4px, transparent 4px, transparent 8px);
}
.dark .ap-plan-td--weekend, [data-theme="dark"] .ap-plan-td--weekend {
  background: rgba(255, 255, 255, 0.02);
}
.dark .ap-plan-td--today, [data-theme="dark"] .ap-plan-td--today {
  background: rgba(59, 130, 246, 0.08);
}
.dark .ap-plan-td--vacation, [data-theme="dark"] .ap-plan-td--vacation {
  background: rgba(253, 224, 71, 0.20);
}
.dark .ap-plan-td--vacation:hover, [data-theme="dark"] .ap-plan-td--vacation:hover {
  background: rgba(253, 224, 71, 0.20);
}
.dark .ap-plan-td--sick, [data-theme="dark"] .ap-plan-td--sick {
  background: rgba(147, 197, 253, 0.20);
}
.dark .ap-plan-td--sick:hover, [data-theme="dark"] .ap-plan-td--sick:hover {
  background: rgba(147, 197, 253, 0.20);
}
.dark .rot-cell-active, [data-theme="dark"] .rot-cell-active {
  background: rgba(34, 197, 94, 0.12);
}
.dark .ap-col-hover, [data-theme="dark"] .ap-col-hover {
  background-color: rgba(59, 130, 246, 0.12) !important;
}
.dark .ap-plan-th--week-start, [data-theme="dark"] .ap-plan-th--week-start, .dark .ap-plan-td--week-start, [data-theme="dark"] .ap-plan-td--week-start {
  border-left-color: var(--color-border, #4b5563);
}
.import-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--space-4) var(--space-6);
  margin-bottom: var(--space-4);
}
.import-header h1 {
  font-size: var(--text-xl);
  font-weight: 700;
  color: var(--color-text);
  margin: 0;
}
.import-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-4);
  padding: 0 var(--space-6) var(--space-6);
}
@media (min-width: 768px) {
  .import-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (min-width: 1200px) {
  .import-grid {
    grid-template-columns: repeat(3, 1fr);
  }
}
.import-grid .import-card--full {
  grid-column: 1 / -1;
}
.import-grid .import-card--span2 {
  grid-column: span 1;
}
@media (min-width: 768px) {
  .import-grid .import-card--span2 {
    grid-column: span 2;
  }
}
.import-card {
  background: var(--color-card);
  border-radius: var(--radius-md);
  padding: var(--space-5);
  display: flex;
  flex-direction: column;
}
.import-card-title {
  font-size: var(--text-lg);
  font-weight: 600;
  color: var(--color-text);
  margin: 0 0 var(--space-1) 0;
}
.import-card-subtitle {
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  margin: 0;
}
.import-dropzone {
  border: 2px dashed var(--color-border-strong);
  border-radius: var(--radius-md);
  padding: var(--space-8) var(--space-6);
  text-align: center;
  cursor: pointer;
  transition: border-color var(--transition-base), background var(--transition-base);
  margin-top: var(--space-4);
}
.import-dropzone:hover {
  border-color: var(--color-primary-light);
  background: rgba(11, 60, 93, 0.03);
}
.import-dropzone--active {
  border-color: var(--color-primary);
  background: rgba(11, 60, 93, 0.06);
  border-style: solid;
}
.import-dropzone-icon {
  width: 48px;
  height: 48px;
  margin: 0 auto var(--space-3);
  color: var(--color-text-muted);
  transition: color var(--transition-base);
}
.import-dropzone:hover .import-dropzone-icon, .import-dropzone--active .import-dropzone-icon {
  color: var(--color-primary);
}
.import-dropzone-text {
  font-size: var(--text-base);
  font-weight: 500;
  color: var(--color-text);
  margin-bottom: var(--space-1);
}
.import-dropzone-hint {
  font-size: var(--text-sm);
  color: var(--color-text-muted);
}
.import-dropzone-btn {
  margin-top: var(--space-4);
}
.import-detection {
  margin-top: var(--space-4);
  padding: var(--space-4);
  border-radius: var(--radius-md);
  background: var(--color-success-bg);
  border: 1px solid rgba(52, 199, 89, 0.2);
  display: flex;
  align-items: center;
  gap: var(--space-3);
  flex-wrap: wrap;
}
.import-detection-icon {
  width: 24px;
  height: 24px;
  color: var(--color-success);
  flex-shrink: 0;
}
.import-detection-text {
  flex: 1;
  min-width: 200px;
}
.import-detection-label {
  font-size: var(--text-sm);
  color: var(--color-text-muted);
}
.import-detection-value {
  font-size: var(--text-base);
  font-weight: 600;
  color: var(--color-text);
}
.import-detection-meta {
  font-size: var(--text-sm);
  color: var(--color-text-secondary);
}
.import-detection-actions {
  display: flex;
  gap: var(--space-2);
  flex-shrink: 0;
}
.import-category-override {
  margin-top: var(--space-3);
  padding: var(--space-3);
  border-radius: var(--radius-sm);
  background: var(--color-card);
  border: 1px solid var(--color-border);
}
.import-category-override select {
  width: 100%;
  padding: var(--space-2) var(--space-3);
  border-radius: var(--radius-sm);
  border: 1px solid var(--color-border-strong);
  background: var(--color-bg);
  color: var(--color-text);
  font-size: var(--text-sm);
}
.import-file-display {
  margin-top: var(--space-3);
  padding: var(--space-3) var(--space-4);
  border-radius: var(--radius-sm);
  background: var(--color-card);
  border: 1px solid var(--color-border);
  display: flex;
  align-items: center;
  gap: var(--space-3);
}
.import-file-icon {
  width: 20px;
  height: 20px;
  color: var(--color-primary);
  flex-shrink: 0;
}
.import-file-name {
  flex: 1;
  font-size: var(--text-sm);
  font-weight: 500;
  color: var(--color-text);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.import-file-size {
  font-size: var(--text-xs);
  color: var(--color-text-muted);
  flex-shrink: 0;
}
.import-file-remove {
  width: 20px;
  height: 20px;
  color: var(--color-text-muted);
  cursor: pointer;
  flex-shrink: 0;
  transition: color var(--transition-fast);
}
.import-file-remove:hover {
  color: var(--color-danger);
}
.import-loading {
  margin-top: var(--space-4);
  text-align: center;
  padding: var(--space-6);
}
.import-loading-spinner {
  width: 32px;
  height: 32px;
  border: 3px solid var(--color-border);
  border-top-color: var(--color-primary);
  border-radius: 50%;
  animation: import-spin 0.8s linear infinite;
  margin: 0 auto var(--space-3);
}
@keyframes import-spin {
  to {
    transform: rotate(360deg);
  }
}
.import-loading-text {
  font-size: var(--text-sm);
  color: var(--color-text-muted);
}
.import-freshness-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--space-3);
  margin-top: var(--space-3);
}
@media (min-width: 768px) {
  .import-freshness-grid {
    grid-template-columns: repeat(4, 1fr);
  }
}
.import-freshness-item {
  padding: var(--space-3);
  border-radius: var(--radius-sm);
  background: var(--color-bg);
  border-left: 4px solid var(--color-border);
}
.import-freshness-item--success {
  border-left-color: var(--color-success);
}
.import-freshness-item--warning {
  border-left-color: var(--color-warning);
}
.import-freshness-item--error {
  border-left-color: var(--color-danger);
}
.import-freshness-item--muted {
  border-left-color: var(--color-text-muted);
}
.import-bg-block {
  padding: var(--space-3);
  border-radius: var(--radius-sm);
  background: var(--color-bg);
}
.import-bg-block--card {
  padding: var(--space-4);
  border-radius: var(--radius-md);
  background: var(--color-card);
}
.import-stat-block {
  padding: var(--space-2);
  border-radius: var(--radius-sm);
  background: var(--color-bg);
  text-align: center;
}
.import-border-top {
  border-top: 1px solid var(--color-border);
}
.import-border-bottom {
  border-bottom: 1px solid var(--color-border);
}
.import-table-head {
  background: var(--color-card);
}
.import-scroll-list {
  max-height: 300px;
  overflow-y: auto;
}
.import-unmatched-banner {
  padding: var(--space-3);
  border-radius: var(--radius-md);
  background: rgba(249, 115, 22, 0.08);
  border: 1px solid rgba(249, 115, 22, 0.2);
}
.import-options-block {
  background: var(--color-bg-secondary);
}
.import-freshness-label {
  font-size: var(--text-xs);
  color: var(--color-text-muted);
  margin-bottom: var(--space-1);
}
.import-freshness-title {
  font-size: var(--text-sm);
  font-weight: 500;
  color: var(--color-text);
}
.import-freshness-date {
  font-size: var(--text-xs);
  color: var(--color-text-muted);
  margin-top: var(--space-1);
}
.import-legend {
  display: flex;
  align-items: center;
  gap: var(--space-4);
  font-size: var(--text-xs);
  color: var(--color-text-muted);
  margin-top: var(--space-3);
}
.import-legend-item {
  display: flex;
  align-items: center;
  gap: var(--space-1);
}
.import-legend-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  flex-shrink: 0;
}
.import-legend-dot--success {
  background: var(--color-success);
}
.import-legend-dot--warning {
  background: var(--color-warning);
}
.import-legend-dot--error {
  background: var(--color-danger);
}
.import-legend-dot--muted {
  background: var(--color-text-muted);
}
.import-legend-dot--info {
  background: var(--color-primary);
}
.import-section-title {
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--color-text-muted);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  padding: var(--space-2) 0;
  grid-column: 1 / -1;
  margin-top: var(--space-4);
}
.import-danger-zone {
  padding: var(--space-3);
  border-radius: var(--radius-sm);
  background: var(--color-danger-bg);
  border: 1px solid rgba(217, 45, 32, 0.2);
  margin-top: auto;
}
.import-danger-text {
  font-size: var(--text-xs);
  color: var(--color-text-secondary);
  margin-bottom: var(--space-2);
}
.import-ics-preview {
  margin-top: var(--space-3);
  overflow-x: auto;
}
.import-ics-preview table {
  width: 100%;
  font-size: var(--text-xs);
}
.import-ics-stats {
  display: flex;
  align-items: center;
  gap: var(--space-4);
  flex-wrap: wrap;
  font-size: var(--text-xs);
  margin-top: var(--space-3);
}
.dark .import-dropzone, [data-theme="dark"] .import-dropzone {
  border-color: rgba(255, 255, 255, 0.15);
}
.dark .import-dropzone:hover, [data-theme="dark"] .import-dropzone:hover {
  border-color: var(--color-primary-light);
  background: rgba(26, 90, 138, 0.08);
}
.dark .import-dropzone--active, [data-theme="dark"] .import-dropzone--active {
  border-color: var(--color-primary-light);
  background: rgba(26, 90, 138, 0.12);
}
.dark .import-freshness-item, [data-theme="dark"] .import-freshness-item {
  background: var(--color-bg-secondary);
}
.dark .import-detection, [data-theme="dark"] .import-detection {
  background: rgba(52, 199, 89, 0.08);
  border-color: rgba(52, 199, 89, 0.15);
}
.dark .import-file-display, [data-theme="dark"] .import-file-display {
  background: var(--color-bg-secondary);
  border-color: rgba(255, 255, 255, 0.1);
}
.dark .import-category-override, [data-theme="dark"] .import-category-override {
  background: var(--color-bg-secondary);
  border-color: rgba(255, 255, 255, 0.1);
}
.dark .import-category-override select, [data-theme="dark"] .import-category-override select {
  background: var(--color-bg);
  border-color: rgba(255, 255, 255, 0.15);
  color: var(--color-text);
}
.dark .import-danger-zone, [data-theme="dark"] .import-danger-zone {
  background: rgba(217, 45, 32, 0.08);
  border-color: rgba(217, 45, 32, 0.15);
}
.dark .import-unmatched-banner, [data-theme="dark"] .import-unmatched-banner {
  background: rgba(249, 115, 22, 0.06);
  border-color: rgba(249, 115, 22, 0.15);
}
.dark .import-bg-block, [data-theme="dark"] .import-bg-block {
  background: var(--color-bg-secondary);
}
.dark .import-stat-block, [data-theme="dark"] .import-stat-block {
  background: var(--color-bg-secondary);
}
.import-customer-item {
  padding: var(--space-3) var(--space-4);
  cursor: pointer;
  border-bottom: 1px solid var(--color-border);
}
.import-customer-item:hover {
  background: var(--color-bg-subtle);
}
.import-raw-content-block {
  padding: var(--space-2);
  border-radius: var(--radius-md);
  background: var(--color-bg-subtle, rgba(0,0,0,0.03));
}
.import-editable-field {
  min-width: 80px;
  max-width: 160px;
}
.import-debug-path {
  cursor: pointer;
  font-family: monospace;
  word-break: break-all;
  background: var(--color-bg-secondary);
}
.import-debug-panel {
  margin-top: var(--space-4);
  padding: var(--space-4);
  background: rgba(59, 130, 246, 0.05);
  border: 1px solid rgba(59, 130, 246, 0.2);
  border-radius: var(--radius-lg);
  font-size: 12px;
  font-family: monospace;
}
.import-debug-log {
  max-height: 200px;
  overflow: auto;
  margin-top: var(--space-2);
  white-space: pre-wrap;
}
.dark .import-debug-panel, [data-theme="dark"] .import-debug-panel {
  background: rgba(59, 130, 246, 0.1);
  border-color: rgba(59, 130, 246, 0.3);
}
.version-badge {
  position: fixed;
  bottom: 10px;
  right: 10px;
  font-size: 0.65rem;
  color: #c0c0c0;
  z-index: 1;
  pointer-events: none;
  -webkit-user-select: none;
     -moz-user-select: none;
          user-select: none;
  letter-spacing: 0.02em;
}
.dark .version-badge, [data-theme="dark"] .version-badge {
  color: #666;
}
@media (max-width: 768px) {
  .version-badge {
    bottom: calc(60px + 10px);
  }
}
.crm-detail-modal {
  width: 90vw;
  max-width: 1400px;
  height: 90vh;
  max-height: 90vh;
  display: flex;
  flex-direction: column;
  border: none;
  overflow: hidden;
}
.crm-tiles-body {
  flex: 1;
  overflow: hidden;
  padding: 0.5rem 1rem;
  display: flex;
  flex-direction: column;
}
.crm-tiles-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-template-rows: 1fr 1fr;
  gap: 0.75rem;
  flex: 1;
  min-height: 0;
}
.crm-tile {
  background: var(--color-card, rgba(0,0,0,0.03));
  border-radius: var(--radius-xl);
  padding: var(--space-4);
  display: flex;
  flex-direction: column;
  overflow: hidden;
}
.crm-tile-title {
  font-weight: 600;
  color: var(--color-primary);
  margin-bottom: var(--space-3);
  flex-shrink: 0;
}
.crm-tile-content {
  overflow-y: auto;
  flex: 1;
  scrollbar-width: thin;
}
.crm-tile-content * {
  word-wrap: break-word;
  overflow-wrap: break-word;
}
.crm-import-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-3);
}
@media (max-width: 768px) {
  .crm-detail-modal {
    width: 100%;
    max-width: 100%;
    height: 95vh;
    max-height: 95vh;
    border-radius: var(--radius-2xl) var(--radius-2xl) 0 0;
  }
  .crm-tiles-grid {
    grid-template-columns: 1fr;
    grid-template-rows: auto;
    gap: var(--space-3);
    overflow-y: auto;
  }
  .crm-tile {
    min-height: 200px;
    max-height: 300px;
  }
  .crm-tiles-body {
    overflow-y: auto;
    padding: var(--space-3);
  }
  .crm-import-grid {
    grid-template-columns: 1fr;
  }
  .crm-detail-modal .modal-header {
    padding: var(--space-3) var(--space-4);
  }
  .crm-detail-modal .modal-header .flex.items-center.gap-4 {
    flex-direction: column;
    align-items: flex-start;
    gap: var(--space-1);
  }
}
@media (max-width: 480px) {
  .crm-tile {
    padding: var(--space-3);
    min-height: 150px;
  }
  .crm-tile-title {
    font-size: var(--text-sm);
    margin-bottom: var(--space-2);
  }
  .crm-tile-content {
    font-size: var(--text-sm);
  }
}
.crm-tile table td {
  padding: var(--space-2) var(--space-1);
  word-break: break-word;
}
.crm-tile table td:first-child {
  white-space: nowrap;
  padding-right: var(--space-3);
}
@media (max-width: 480px) {
  .crm-tile table td:first-child {
    white-space: normal;
    min-width: 60px;
  }
}
.import-lock-overlay {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.6);
  backdrop-filter: blur(2px);
  -webkit-backdrop-filter: blur(2px);
  border-radius: inherit;
  z-index: 10;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: opacity var(--transition-base);
}
.import-lock-overlay.hidden {
  opacity: 0;
  pointer-events: none;
}
.import-lock-message {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  color: white;
  font-size: var(--text-sm);
  font-weight: 500;
  padding: var(--space-4);
}
:root:not(.dark) .import-lock-overlay {
  background: rgba(255, 255, 255, 0.85);
}
:root:not(.dark) .import-lock-message {
  color: var(--color-text-muted);
}
.crm-initially-hidden {
  display: none;
}
.crm-supplier-card {
  background: var(--color-card, rgba(0,0,0,0.03));
}
.supplier-detail-grid-2col {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0.75rem;
}
.crm-supplier-modal {
  width: 92vw;
  max-width: 1100px;
  height: auto;
  max-height: 90vh;
  display: flex;
  flex-direction: column;
  border: none;
  overflow: hidden;
}
.crm-import-preview-modal {
  width: 95vw;
  max-width: 1200px;
  height: auto;
  max-height: 90vh;
  display: flex;
  flex-direction: column;
  border: none;
  overflow: hidden;
}
.crm-preview-card {
  background: var(--color-card, rgba(0,0,0,0.02));
}
.crm-modal-header {
  flex-shrink: 0;
  border-bottom: none;
  padding: 1.25rem 1.5rem;
}
.crm-modal-header-sm {
  flex-shrink: 0;
  border-bottom: none;
  padding: 1rem 1.5rem;
}
.crm-modal-header-border {
  flex-shrink: 0;
  border-bottom: 1px solid var(--color-border);
  padding: 1.25rem 1.5rem;
}
.crm-modal-body-scroll {
  flex: 1;
  overflow-y: auto;
  padding: 1rem;
}
.crm-modal-body-scroll-lg {
  flex: 1;
  overflow-y: auto;
  padding: 1.5rem;
}
.crm-supplier-modal-body {
  flex: 1;
  overflow-y: auto;
  padding: 0.5rem 1rem 1rem;
  scrollbar-width: thin;
}
.crm-modal-footer-end {
  flex-shrink: 0;
  justify-content: flex-end;
  border-top: none;
  padding-top: 0.5rem;
}
.crm-modal-footer-between {
  flex-shrink: 0;
  justify-content: space-between;
  border-top: none;
  padding-top: 0.5rem;
}
.crm-modal-footer-border {
  flex-shrink: 0;
  border-top: 1px solid var(--color-border);
  padding: 1rem 1.5rem;
}
.crm-action-btn {
  height: 36px;
  display: flex;
  align-items: center;
}
.crm-tile-title-noshrink {
  flex-shrink: 0;
}
.crm-supplier-list {
  flex: 1;
  max-height: 480px;
}
.crm-customer-search-input {
  width: 180px;
}
.crm-col-num {
  width: 40px;
}
.crm-col-name {
  width: 20%;
}
.crm-col-email {
  width: 15%;
}
.crm-col-action {
  width: 65%;
}
@media (max-width: 768px) {
  [data-crm-modal="global-provider-detail"] .modal-body .grid, [data-crm-modal="global-provider-detail"] .grid {
    grid-template-columns: 1fr !important;
  }
  [data-crm-modal="global-provider-detail"] .modal-body * {
    word-wrap: break-word;
    overflow-wrap: break-word;
  }
}
@media (max-width: 768px) {
  [data-crm-modal="supplier-detail"] {
    padding: 0 !important;
    align-items: stretch !important;
  }
  [data-crm-modal="supplier-detail"] .modal-panel {
    width: 100vw !important;
    max-width: 100vw !important;
    height: 100vh !important;
    height: 100dvh !important;
    max-height: 100vh !important;
    max-height: 100dvh !important;
    border-radius: 0 !important;
    margin: 0 !important;
    padding-top: env(safe-area-inset-top, 0px) !important;
  }
  [data-crm-modal="supplier-detail"] .modal-header {
    position: sticky !important;
    top: 0 !important;
    z-index: 50 !important;
    background: var(--color-bg, #fff) !important;
    padding: 0.625rem 0.75rem !important;
    border-bottom: 1px solid rgba(0,0,0,0.08) !important;
    flex-shrink: 0 !important;
    min-height: 48px !important;
  }
  html.dark [data-crm-modal="supplier-detail"] .modal-header {
    background: var(--color-bg, #1a1a2e) !important;
    border-bottom-color: rgba(255,255,255,0.08) !important;
  }
  [data-crm-modal="supplier-detail"] .modal-header .modal-title {
    font-size: 1rem !important;
    line-height: 1.3 !important;
    max-width: 60vw !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
  }
  [data-crm-modal="supplier-detail"] .modal-header .pill {
    font-size: 0.65rem !important;
    padding: 0.125rem 0.5rem !important;
    max-width: 40vw !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
  }
  [data-crm-modal="supplier-detail"] .modal-close {
    width: 32px !important;
    height: 32px !important;
    min-width: 32px !important;
    flex-shrink: 0 !important;
  }
  [data-crm-modal="supplier-detail"] .modal-body {
    flex: 1 !important;
    overflow-y: auto !important;
    -webkit-overflow-scrolling: touch !important;
    padding: 0.5rem 0.625rem 1rem !important;
  }
  [data-crm-modal="supplier-detail"] .modal-footer {
    position: sticky !important;
    bottom: 0 !important;
    z-index: 50 !important;
    background: var(--color-bg, #fff) !important;
    padding: 0.5rem 0.75rem !important;
    padding-bottom: calc(0.5rem + env(safe-area-inset-bottom, 0px)) !important;
    border-top: 1px solid rgba(0,0,0,0.08) !important;
    flex-shrink: 0 !important;
    flex-wrap: wrap !important;
    gap: 0.5rem !important;
  }
  html.dark [data-crm-modal="supplier-detail"] .modal-footer {
    background: var(--color-bg, #1a1a2e) !important;
    border-top-color: rgba(255,255,255,0.08) !important;
  }
  [data-crm-modal="supplier-detail"] .modal-footer .btn {
    font-size: 0.75rem !important;
    padding: 0.375rem 0.625rem !important;
  }
  [data-crm-modal="supplier-detail"] .modal-footer [data-supplier-suggest-change] {
    font-size: 0.7rem !important;
    padding: 0.25rem 0.5rem !important;
  }
  .supplier-detail-grid-2col {
    grid-template-columns: 1fr !important;
    gap: 0.5rem !important;
  }
  [data-crm-modal="supplier-detail"] .rounded-xl {
    padding: 0.75rem !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
  }
  [data-crm-modal="supplier-detail"] .rounded-xl > h4 {
    font-size: 0.8rem !important;
  }
  [data-crm-modal="supplier-detail"] .rounded-xl table td {
    font-size: 0.75rem !important;
    padding-top: 0.375rem !important;
    padding-bottom: 0.375rem !important;
  }
  [data-crm-modal="supplier-detail"] .grid-cols-3 {
    grid-template-columns: 1fr 1fr !important;
  }
  [data-crm-modal="supplier-detail"] [data-supplier-service-packages] {
    overflow-x: auto !important;
    -webkit-overflow-scrolling: touch !important;
  }
  [data-crm-modal="supplier-detail"] [data-supplier-service-packages] table {
    min-width: 500px !important;
  }
  [data-crm-modal="supplier-detail"] #anchor-insurer-link {
    min-height: 48px !important;
  }
  [data-crm-modal="supplier-detail"] [data-supplier-customer-search] {
    width: 120px !important;
  }
  [data-crm-modal="supplier-detail"] #anchor-kunden > .flex.items-center.justify-between {
    flex-wrap: wrap !important;
    gap: 0.5rem !important;
  }
  [data-crm-modal="supplier-detail"] [data-supplier-detail-sources] .text-xs {
    font-size: 0.7rem !important;
  }
  [data-crm-modal="supplier-detail"] [data-supplier-admin-edit] {
    width: 32px !important;
    height: 32px !important;
    padding: 0.25rem !important;
  }
  [data-crm-modal="supplier-detail"] [data-supplier-detail-favorite] {
    width: 32px !important;
    height: 32px !important;
    padding: 0.25rem !important;
  }
}
@media (max-width: 400px) {
  [data-crm-modal="supplier-detail"] .modal-header .modal-title {
    font-size: 0.875rem !important;
    max-width: 50vw !important;
  }
  [data-crm-modal="supplier-detail"] .modal-header .pill {
    display: none !important;
  }
  [data-crm-modal="supplier-detail"] .modal-footer {
    flex-direction: column !important;
    align-items: stretch !important;
  }
  [data-crm-modal="supplier-detail"] .modal-footer > div {
    justify-content: stretch !important;
  }
  [data-crm-modal="supplier-detail"] .modal-footer .btn {
    flex: 1 !important;
  }
  [data-crm-modal="supplier-detail"] .grid-cols-3 {
    grid-template-columns: 1fr !important;
  }
}
@media (max-width: 768px) {
  [data-crm-modal="customer-detail"] {
    padding: 0 !important;
    align-items: stretch !important;
  }
  [data-crm-modal="customer-detail"] .modal-panel {
    width: 100vw !important;
    max-width: 100vw !important;
    height: 100vh !important;
    height: 100dvh !important;
    max-height: 100vh !important;
    max-height: 100dvh !important;
    border-radius: 0 !important;
    margin: 0 !important;
  }
  [data-crm-modal="customer-detail"] .modal-header {
    position: sticky !important;
    top: 0 !important;
    z-index: 50 !important;
    background: var(--color-bg, #fff) !important;
    padding: 0.625rem 0.75rem !important;
    border-bottom: 1px solid rgba(0,0,0,0.08) !important;
  }
  html.dark [data-crm-modal="customer-detail"] .modal-header {
    background: var(--color-bg, #1a1a2e) !important;
  }
  [data-crm-modal="customer-detail"] .modal-body {
    padding: 0.5rem 0.625rem 1rem !important;
  }
  [data-crm-modal="customer-detail"] .modal-footer {
    position: sticky !important;
    bottom: 0 !important;
    z-index: 50 !important;
    background: var(--color-bg, #fff) !important;
    padding: 0.5rem 0.75rem !important;
    padding-bottom: calc(0.5rem + env(safe-area-inset-bottom, 0px)) !important;
    border-top: 1px solid rgba(0,0,0,0.08) !important;
  }
  html.dark [data-crm-modal="customer-detail"] .modal-footer {
    background: var(--color-bg, #1a1a2e) !important;
  }
}
@media (max-width: 768px) {
  .modal-backdrop {
    padding: 0 !important;
    align-items: flex-end !important;
  }
  .modal-panel {
    max-width: 100vw !important;
    width: 100vw !important;
    border-radius: 1rem 1rem 0 0 !important;
    max-height: 90vh !important;
    max-height: 90dvh !important;
  }
}
.tool-grid {
  display: grid;
  grid-template-columns: repeat(12,minmax(0,1fr));
  gap: 1rem;
}
.tool-col-12 {
  grid-column: span 12;
}
.tool-col-6 {
  grid-column: span 6;
}
.tool-col-4 {
  grid-column: span 4;
}
.hidden {
  display: none !important;
}
.d-none {
  display: none;
}
.invisible {
  visibility: hidden;
}
.block {
  display: block;
}
.inline {
  display: inline;
}
.inline-block {
  display: inline-block;
}
.flex {
  display: flex;
}
.inline-flex {
  display: inline-flex;
}
.grid {
  display: grid;
}
.flex-row {
  flex-direction: row;
}
.flex-col {
  flex-direction: column;
}
.flex-wrap {
  flex-wrap: wrap;
}
.flex-nowrap {
  flex-wrap: nowrap;
}
.items-start {
  align-items: flex-start;
}
.items-center {
  align-items: center;
}
.items-end {
  align-items: flex-end;
}
.items-stretch {
  align-items: stretch;
}
.justify-start {
  justify-content: flex-start;
}
.justify-center {
  justify-content: center;
}
.justify-end {
  justify-content: flex-end;
}
.justify-between {
  justify-content: space-between;
}
.flex-1 {
  flex: 1 1 0%;
}
.flex-auto {
  flex: 1 1 auto;
}
.flex-none {
  flex: none;
}
.flex-shrink-0 {
  flex-shrink: 0;
}
.gap-1 {
  gap: var(--space-1);
}
.gap-2 {
  gap: var(--space-2);
}
.gap-3 {
  gap: var(--space-3);
}
.gap-4 {
  gap: var(--space-4);
}
.gap-5 {
  gap: var(--space-5);
}
.gap-6 {
  gap: var(--space-6);
}
.w-full {
  width: 100%;
}
.w-auto {
  width: auto;
}
.max-w-full {
  max-width: 100%;
}
.min-w-0 {
  min-width: 0;
}
.mt-1 {
  margin-top: var(--space-1);
}
.mt-2 {
  margin-top: var(--space-2);
}
.mt-3 {
  margin-top: var(--space-3);
}
.mt-4 {
  margin-top: var(--space-4);
}
.mt-5 {
  margin-top: var(--space-5);
}
.mt-6 {
  margin-top: var(--space-6);
}
.mb-1 {
  margin-bottom: var(--space-1);
}
.mb-2 {
  margin-bottom: var(--space-2);
}
.mb-3 {
  margin-bottom: var(--space-3);
}
.mb-4 {
  margin-bottom: var(--space-4);
}
.ml-auto {
  margin-left: auto;
}
.mr-auto {
  margin-right: auto;
}
.mx-auto {
  margin-left: auto;
  margin-right: auto;
}
.p-1 {
  padding: var(--space-1);
}
.p-2 {
  padding: var(--space-2);
}
.p-3 {
  padding: var(--space-3);
}
.p-4 {
  padding: var(--space-4);
}
.p-5 {
  padding: var(--space-5);
}
.p-6 {
  padding: var(--space-6);
}
.pt-4 {
  padding-top: var(--space-4);
}
.pb-4 {
  padding-bottom: var(--space-4);
}
.px-4 {
  padding-left: var(--space-4);
  padding-right: var(--space-4);
}
.py-4 {
  padding-top: var(--space-4);
  padding-bottom: var(--space-4);
}
.py-8 {
  padding-top: var(--space-8);
  padding-bottom: var(--space-8);
}
.text-left {
  text-align: left;
}
.text-center {
  text-align: center;
}
.text-right {
  text-align: right;
}
.truncate {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.whitespace-nowrap {
  white-space: nowrap;
}
.whitespace-normal {
  white-space: normal;
}
.break-all {
  word-break: break-all;
}
.opacity-0 {
  opacity: 0;
}
.opacity-50 {
  opacity: 0.5;
}
.opacity-60 {
  opacity: 0.6;
}
.opacity-70 {
  opacity: 0.7;
}
.opacity-80 {
  opacity: 0.8;
}
.opacity-90 {
  opacity: 0.9;
}
.opacity-100 {
  opacity: 1;
}
.cursor-pointer {
  cursor: pointer;
}
.cursor-not-allowed {
  cursor: not-allowed;
}
.overflow-hidden {
  overflow: hidden;
}
.overflow-auto {
  overflow: auto;
}
.overflow-x-auto {
  overflow-x: auto;
}
.overflow-y-auto {
  overflow-y: auto;
}
.relative {
  position: relative;
}
.absolute {
  position: absolute;
}
.fixed {
  position: fixed;
}
.sticky {
  position: sticky;
}
.inset-0 {
  inset: 0;
}
.top-0 {
  top: 0;
}
.right-0 {
  right: 0;
}
.bottom-0 {
  bottom: 0;
}
.left-0 {
  left: 0;
}
.rounded {
  border-radius: var(--radius-md);
}
.rounded-lg {
  border-radius: var(--radius-lg);
}
.rounded-xl {
  border-radius: var(--radius-xl);
}
.rounded-2xl {
  border-radius: var(--radius-2xl);
}
.rounded-full {
  border-radius: var(--radius-full);
}
.border {
  border: 1px solid var(--color-border);
}
.border-0 {
  border: none;
}
.border-b {
  border-bottom: 1px solid var(--color-border);
}
.border-t {
  border-top: 1px solid var(--color-border);
}
.bg-transparent {
  background: transparent;
}
.bg-white {
  background: white;
}
.bg-secondary {
  background: var(--color-bg-secondary);
}
.bg-card {
  background: var(--color-card);
}
.import-result--success {
  background: rgba(34, 197, 94, 0.08);
  border: 1px solid rgba(34, 197, 94, 0.2);
}
.import-result--error {
  background: rgba(239, 68, 68, 0.08);
  border: 1px solid rgba(239, 68, 68, 0.2);
}
.dark .import-result--success, [data-theme="dark"] .import-result--success {
  background: rgba(34, 197, 94, 0.12);
  border-color: rgba(34, 197, 94, 0.3);
}
.dark .import-result--error, [data-theme="dark"] .import-result--error {
  background: rgba(239, 68, 68, 0.12);
  border-color: rgba(239, 68, 68, 0.3);
}
.shadow {
  box-shadow: var(--shadow-md);
}
.shadow-lg {
  box-shadow: var(--shadow-lg);
}
.shadow-xl {
  box-shadow: var(--shadow-xl);
}
.shadow-none {
  box-shadow: none;
}
.transition {
  transition: all var(--transition-base);
}
.transition-fast {
  transition: all var(--transition-fast);
}
.select-none {
  -webkit-user-select: none;
     -moz-user-select: none;
          user-select: none;
}
.select-all {
  -webkit-user-select: all;
     -moz-user-select: all;
          user-select: all;
}
.pointer-events-none {
  pointer-events: none;
}
.pointer-events-auto {
  pointer-events: auto;
}
.z-10 {
  z-index: 10;
}
.z-20 {
  z-index: 20;
}
.z-50 {
  z-index: 50;
}
.list-none {
  list-style: none;
}
.list-disc {
  list-style-type: disc;
}
.list-decimal {
  list-style-type: decimal;
}
.pl-5 {
  padding-left: var(--space-5);
}
.text-xs {
  font-size: var(--text-xs);
}
.text-sm {
  font-size: var(--text-sm);
}
.text-base {
  font-size: var(--text-base);
}
.text-lg {
  font-size: var(--text-lg);
}
.font-500 {
  font-weight: 500;
}
.font-600 {
  font-weight: 600;
}
.font-bold {
  font-weight: 700;
}
.font-mono {
  font-family: var(--font-mono);
}
.label-muted {
  font-size: var(--text-sm);
  opacity: 0.7;
}
.label-xs-muted {
  font-size: var(--text-xs);
  opacity: 0.5;
}
.text-muted-70 {
  opacity: 0.7;
}
.text-muted-60 {
  opacity: 0.6;
}
.text-muted-50 {
  opacity: 0.5;
}
.text-muted-40 {
  opacity: 0.4;
}
.text-muted-80 {
  opacity: 0.8;
}
.privacy-blurred {
  filter: blur(8px);
  -webkit-user-select: none;
     -moz-user-select: none;
          user-select: none;
  pointer-events: none;
}
.status-badge {
  display: inline-flex;
  align-items: center;
  border-radius: var(--radius-full);
  padding: 0.25rem 0.75rem;
  font-size: var(--text-sm);
}
.status-badge-success {
  border: 1px solid rgba(34, 197, 94, 0.3);
  background: rgba(34, 197, 94, 0.1);
  font-weight: 500;
  color: #16a34a;
}
.status-badge-lg {
  padding: 0.5rem 1rem;
}
.status-badge-disconnected {
  background: rgba(0, 0, 0, 0.05);
  opacity: 0.8;
}
.status-badge-connected {
  background: rgba(34, 197, 94, 0.2);
  color: #16a34a;
}
.dark .status-badge-disconnected {
  background: rgba(255, 255, 255, 0.08);
}
.dark .status-badge-success {
  color: #4ade80;
  border-color: rgba(74, 222, 128, 0.3);
  background: rgba(74, 222, 128, 0.1);
}
.dark .status-badge-connected {
  color: #4ade80;
  background: rgba(74, 222, 128, 0.2);
}
.alert-success-banner {
  border-radius: var(--radius-lg);
  background: rgba(34, 197, 94, 0.1);
  border: 1px solid rgba(34, 197, 94, 0.3);
  padding: var(--space-3);
  font-size: var(--text-sm);
  color: #16a34a;
}
.alert-danger-banner {
  border-radius: var(--radius-lg);
  background: rgba(239, 68, 68, 0.1);
  border: 1px solid rgba(239, 68, 68, 0.3);
  padding: var(--space-3);
  font-size: var(--text-sm);
  color: #dc2626;
}
.dark .alert-success-banner {
  color: #4ade80;
  background: rgba(74, 222, 128, 0.1);
  border-color: rgba(74, 222, 128, 0.3);
}
.dark .alert-danger-banner {
  color: #f87171;
  background: rgba(248, 113, 113, 0.1);
  border-color: rgba(248, 113, 113, 0.3);
}
.icon-gmail {
  color: #dc2626;
}
.icon-gdrive {
  color: #eab308;
}
.icon-gcal {
  color: #3b82f6;
}
.dark .icon-gmail {
  color: #f87171;
}
.dark .icon-gdrive {
  color: #fde047;
}
.dark .icon-gcal {
  color: #60a5fa;
}
.info-box-blue {
  border-radius: var(--radius-lg);
  background: rgba(59, 130, 246, 0.1);
  border: 1px solid rgba(59, 130, 246, 0.2);
}
.table-wide {
  min-width: 70rem;
  width: -moz-max-content;
  width: max-content;
}
@keyframes spin {
  from {
    transform: rotate(0deg);
  }
  to {
    transform: rotate(360deg);
  }
}
.animate-spin {
  animation: spin 1s linear infinite;
}
.w-6 {
  width: 1.5rem;
}
.w-12 {
  width: 3rem;
}
.w-24 {
  width: 6rem;
}
.min-w-10 {
  min-width: 2.5rem;
}
.min-w-60 {
  min-width: 60px;
}
.min-h-24 {
  min-height: 6rem;
}
.min-h-200 {
  min-height: 200px;
}
.max-h-400 {
  max-height: 400px;
}
.self-center {
  align-self: center;
}
.self-start {
  align-self: flex-start;
}
.self-end {
  align-self: flex-end;
}
.mr-1 {
  margin-right: 0.25rem;
}
.mb-2 {
  margin-bottom: var(--space-2);
}
.ml-1 {
  margin-left: 0.25rem;
}
.w-40 {
  width: 10rem;
}
.text-uppercase {
  text-transform: uppercase;
}
.grid-7-5 {
  grid-template-columns: 7fr 5fr;
}
.grid-2-1 {
  grid-template-columns: 2fr 1fr;
}
.grid-cols-3-auto {
  grid-template-columns: repeat(3, 1fr);
}
.no-underline {
  text-decoration: none;
}
.line-through {
  text-decoration: line-through;
}
.px-2 {
  padding-left: var(--space-2);
  padding-right: var(--space-2);
}
.py-2 {
  padding-top: var(--space-2);
  padding-bottom: var(--space-2);
}
.px-3 {
  padding-left: var(--space-3);
  padding-right: var(--space-3);
}
.py-3 {
  padding-top: var(--space-3);
  padding-bottom: var(--space-3);
}
.pt-3 {
  padding-top: var(--space-3);
}
.pb-3 {
  padding-bottom: var(--space-3);
}
.pr-4 {
  padding-right: var(--space-4);
}
.pl-4 {
  padding-left: var(--space-4);
}
.px-px4 {
  padding-left: var(--space-4);
  padding-right: var(--space-4);
}
.oauth-card-inner {
  padding: var(--space-4);
  border-radius: var(--radius-lg);
  border: 1px solid var(--color-border);
}
.border-t-color {
  border-top: 1px solid var(--color-border);
}
.knowledge-tabs-bar {
  display: flex;
  border-bottom: 1px solid var(--color-border);
  background: var(--color-bg-secondary);
  overflow-x: auto;
}
.knowledge-tab-active {
  border-bottom: 2px solid var(--color-primary);
  color: var(--color-primary);
}
.knowledge-tab-inactive {
  border-bottom: 2px solid transparent;
  opacity: 0.6;
}
.knowledge-tab-btn {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-3) var(--space-4);
  font-size: var(--text-sm);
  font-weight: 500;
}
.knowledge-settings-icon {
  margin-left: 0.25rem;
  padding: 0.25rem;
  border-radius: var(--radius-sm);
}
.chat-messages {
  padding: var(--space-4);
  min-height: 200px;
  max-height: 400px;
  overflow-y: auto;
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}
.chat-input-bar {
  border-top: 1px solid var(--color-border);
  background: var(--color-bg-secondary);
  padding: var(--space-3);
  display: flex;
  gap: var(--space-2);
  align-items: flex-end;
}
.chat-input-pill {
  border-radius: var(--radius-full);
  padding-left: var(--space-4);
  padding-right: var(--space-4);
}
.spinner-icon {
  animation: spin 1s linear infinite;
}
.spinner-track {
  opacity: 0.25;
}
.spinner-fill {
  opacity: 0.75;
}
.leading-none {
  line-height: 1;
}
.leading-tight {
  line-height: 1.25;
}
.leading-relaxed {
  line-height: 1.625;
}
.grid-cols-1 {
  grid-template-columns: repeat(1, 1fr);
}
.grid-cols-2 {
  grid-template-columns: repeat(2, 1fr);
}
.grid-cols-3 {
  grid-template-columns: repeat(3, 1fr);
}
@media (min-width: 768px) {
  .md\:grid-cols-2 {
    grid-template-columns: repeat(2, 1fr);
  }
  .md\:grid-cols-3 {
    grid-template-columns: repeat(3, 1fr);
  }
  .md\:w-auto {
    width: auto;
  }
}
.mt-3-quarter {
  margin-top: 0.75rem;
}
.mb-1-quarter {
  margin-bottom: 0.25rem;
}
.mb-2-half {
  margin-bottom: 0.5rem;
}
.my-4 {
  margin-top: var(--space-4);
  margin-bottom: var(--space-4);
}
.modal-panel--sm {
  max-width: 500px;
}
.modal-panel--md {
  max-width: 600px;
}
.address-ac-dropdown {
  position: absolute;
  top: 100%;
  left: 0;
  right: 0;
  z-index: var(--z-dropdown, 50);
  background: var(--color-bg);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md, 8px);
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
  max-height: 240px;
  overflow-y: auto;
  margin-top: 2px;
}
.address-ac-item {
  padding: var(--space-2) var(--space-3);
  cursor: pointer;
  border-bottom: 1px solid var(--color-border);
  transition: background var(--transition-fast);
}
.address-ac-item:last-child {
  border-bottom: none;
}
.address-ac-item:hover {
  background: var(--color-bg-secondary);
}
.address-ac-title {
  font-size: var(--text-sm);
  font-weight: 500;
  color: var(--color-text);
}
.address-ac-sub {
  font-size: 12px;
  color: var(--color-text-muted);
}
.address-ac-empty {
  padding: var(--space-2) var(--space-3);
  font-size: var(--text-sm);
  color: var(--color-text-muted);
}
.sa-cost-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.sa-cost-row + .sa-cost-row {
  margin-top: 4px;
}
.sa-stat-card {
  background: var(--color-bg-secondary);
  padding: 10px;
  border-radius: var(--radius-md);
  text-align: center;
}
.sa-grid-2x2 {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
}
.sa-progress-track {
  background: var(--color-bg-secondary);
  border-radius: var(--radius-sm);
  height: 8px;
  overflow: hidden;
}
.sa-progress-bar {
  height: 100%;
  background: var(--color-accent);
  border-radius: var(--radius-sm);
  transition: width 0.5s ease;
  width: 0%;
}
.text-accent {
  color: var(--color-accent);
}
.text-success {
  color: var(--color-success);
}
.text-error {
  color: var(--color-error, #ef4444);
}
.text-danger {
  color: var(--color-danger, #d92d20);
}
.dark .text-accent {
  color: var(--color-accent-light, var(--color-accent));
}
.dark .text-success {
  color: #4ade80;
}
.dark .text-error {
  color: #f87171;
}
.dark .text-danger {
  color: #f87171;
}
.text-2xs {
  font-size: 0.75rem;
}
.w-120 {
  width: 120px;
}
.max-h-300 {
  max-height: 300px;
}
.max-h-dvh-1 {
  max-height: calc(100dvh - 1rem);
}
.min-h-8 {
  min-height: 8px;
}
.emoji-icon {
  font-size: 14px;
  line-height: 1;
}
.emoji-icon-sm {
  font-size: 6px;
  line-height: 1;
}
.import-card-full {
  height: 100%;
}
.import-freshness-border {
  border-color: var(--color-error);
}
.import-legend-dot {
  width: 0.75rem;
  height: 0.75rem;
  border-radius: var(--radius-md);
  display: inline-block;
  flex-shrink: 0;
}
.import-legend-dot--success {
  background: var(--color-success);
}
.import-legend-dot--info {
  background: var(--color-primary);
}
.import-legend-dot--warning {
  background: var(--color-warning);
}
.import-legend-dot--error {
  background: var(--color-error);
}
.import-legend-dot--muted {
  background: var(--color-text-muted);
}
.modal-panel--wide {
  width: 95vw;
  max-width: 1200px;
  max-height: 90vh;
}
.import-th-num {
  width: 40px;
}
.import-th-name {
  width: 20%;
}
.import-th-email {
  width: 15%;
}
.import-th-action {
  width: 65%;
}
.scroll-touch {
  -webkit-overflow-scrolling: touch;
}
.avatar-leasing {
  background: #e0f2fe;
  color: #0369a1;
}
.avatar-insurance {
  background: #fef3c7;
  color: #d97706;
}
.avatar-accent {
  background: var(--color-accent);
  color: #000;
}
.avatar-supplier-wholesaler {
  background: var(--color-warning-bg);
  color: var(--color-warning);
}
.avatar-supplier-parts {
  background: var(--color-info-bg);
  color: var(--color-info);
}
.dark .avatar-leasing {
  background: rgba(14, 116, 144, 0.2);
  color: #67e8f9;
}
.dark .avatar-insurance {
  background: rgba(217, 119, 6, 0.2);
  color: #fbbf24;
}
.dark .avatar-accent {
  background: var(--color-accent);
  color: #000;
}
.avatar-status-active {
  background: #dcfce7;
  color: #16a34a;
}
.avatar-status-expired {
  background: #fee2e2;
  color: #dc2626;
}
.avatar-status-default {
  background: #f3f4f6;
  color: #6b7280;
}
.dark .avatar-status-active {
  background: rgba(22, 163, 74, 0.2);
  color: #4ade80;
}
.dark .avatar-status-expired {
  background: rgba(220, 38, 38, 0.2);
  color: #f87171;
}
.dark .avatar-status-default {
  background: rgba(107, 114, 128, 0.2);
  color: #9ca3af;
}
.col-span-full {
  grid-column: 1 / -1;
}
.link-block {
  display: block;
  text-decoration: none;
  color: inherit;
}
.max-w-500 {
  max-width: 500px;
}
.max-w-600 {
  max-width: 600px;
}
.max-w-120 {
  max-width: 120px;
}
.legacy-tool-frame {
  height: calc(100vh - 260px);
  min-height: 520px;
}
.border-none {
  border: 0;
}
.bg-dropdown {
  background: var(--color-bg-secondary);
}
.dark .bg-dropdown {
  background: var(--color-bg-secondary, #1e293b);
}
.table-fixed {
  table-layout: fixed;
}
.col-w-45 {
  width: 45px;
}
.col-w-60 {
  width: 60px;
}
.col-w-65 {
  width: 65px;
}
.tab-size-2 {
  -o-tab-size: 2;
     tab-size: 2;
  -moz-tab-size: 2;
}
.max-h-500 {
  max-height: 500px;
}
.max-h-dvh {
  max-height: 100dvh;
}
.col-span-2 {
  grid-column: span 2;
}
.scroll-touch {
  -webkit-overflow-scrolling: touch;
}
.scroll-contain {
  -webkit-overflow-scrolling: touch;
  overscroll-behavior: contain;
}
.blend-hard-light {
  mix-blend-mode: hard-light;
}
.blend-plus-darker {
  mix-blend-mode: plus-darker;
}
.avatar-insurance {
  background: rgba(254, 243, 199, 1);
  color: #d97706;
}
.dark .avatar-insurance {
  background: rgba(254, 243, 199, 0.15);
  color: #fbbf24;
}
.pill-crm-linked {
  background: #16a34a;
  color: white;
  font-size: 10px;
  padding: 2px 6px;
}
.dark .pill-crm-linked {
  background: #22c55e;
}
.btn-link-underline {
  text-decoration: underline;
  cursor: pointer;
  background: none;
  border: none;
}
.pill-mini-success {
  background: #10b981;
  color: white;
  font-size: 9px;
  padding: 0 4px;
  margin-left: 4px;
}
.dark .pill-mini-success {
  background: #34d399;
}
.pill-mini-warning {
  background: #f59e0b;
  color: white;
  font-size: 9px;
  padding: 0 4px;
  margin-left: 4px;
}
.dark .pill-mini-warning {
  background: #fbbf24;
  color: #1a1a1a;
}
.pill-mini-muted {
  background: var(--color-bg-secondary);
  color: var(--color-text-secondary);
  font-size: 9px;
  padding: 0 4px;
  margin-left: 4px;
  border-radius: var(--radius-sm);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.3px;
}
.widget-vortag-section {
  margin-top: 8px;
  padding-top: 8px;
  border-top: 1px solid var(--color-border);
}
.widget-vortag-header {
  font-size: 11px;
  color: var(--color-text-muted);
  font-weight: 600;
  margin-bottom: 4px;
}
.cb-card-colored {
  border-left: 4px solid var(--service-color);
}
.sa-modal-overlay {
  background: rgba(0, 0, 0, 0.6);
  backdrop-filter: blur(4px);
}
.dark .sa-modal-overlay {
  background: rgba(0, 0, 0, 0.75);
}
.cb-manage-action-bar {
  display: flex;
  gap: 12px;
  margin-top: 16px;
}
.widget-team-initials--colored-single {
  background-color: var(--avatar-color-1);
}
.widget-team-initials--colored-both {
  background: conic-gradient(var(--avatar-color-1) 0deg, var(--avatar-color-1) 180deg, var(--avatar-color-2) 180deg, var(--avatar-color-2) 360deg);
}
.gw-blurred {
  filter: blur(8px);
  transition: filter .3s ease;
  pointer-events: none;
  -webkit-user-select: none;
     -moz-user-select: none;
          user-select: none;
}
.gw-blurred.gw-revealed {
  filter: none;
  pointer-events: auto;
  -webkit-user-select: auto;
     -moz-user-select: auto;
          user-select: auto;
}
@property --tw-translate-x {
  syntax: "*";
  inherits: false;
  initial-value: 0;
}
@property --tw-translate-y {
  syntax: "*";
  inherits: false;
  initial-value: 0;
}
@property --tw-translate-z {
  syntax: "*";
  inherits: false;
  initial-value: 0;
}
@property --tw-scale-x {
  syntax: "*";
  inherits: false;
  initial-value: 1;
}
@property --tw-scale-y {
  syntax: "*";
  inherits: false;
  initial-value: 1;
}
@property --tw-scale-z {
  syntax: "*";
  inherits: false;
  initial-value: 1;
}
@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-pan-x {
  syntax: "*";
  inherits: false;
}
@property --tw-pan-y {
  syntax: "*";
  inherits: false;
}
@property --tw-pinch-zoom {
  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-shadow {
  syntax: "*";
  inherits: false;
  initial-value: 0 0 #0000;
}
@property --tw-shadow-color {
  syntax: "*";
  inherits: false;
}
@property --tw-shadow-alpha {
  syntax: "<percentage>";
  inherits: false;
  initial-value: 100%;
}
@property --tw-inset-shadow {
  syntax: "*";
  inherits: false;
  initial-value: 0 0 #0000;
}
@property --tw-inset-shadow-color {
  syntax: "*";
  inherits: false;
}
@property --tw-inset-shadow-alpha {
  syntax: "<percentage>";
  inherits: false;
  initial-value: 100%;
}
@property --tw-ring-color {
  syntax: "*";
  inherits: false;
}
@property --tw-ring-shadow {
  syntax: "*";
  inherits: false;
  initial-value: 0 0 #0000;
}
@property --tw-inset-ring-color {
  syntax: "*";
  inherits: false;
}
@property --tw-inset-ring-shadow {
  syntax: "*";
  inherits: false;
  initial-value: 0 0 #0000;
}
@property --tw-ring-inset {
  syntax: "*";
  inherits: false;
}
@property --tw-ring-offset-width {
  syntax: "<length>";
  inherits: false;
  initial-value: 0px;
}
@property --tw-ring-offset-color {
  syntax: "*";
  inherits: false;
  initial-value: #fff;
}
@property --tw-ring-offset-shadow {
  syntax: "*";
  inherits: false;
  initial-value: 0 0 #0000;
}
@property --tw-outline-style {
  syntax: "*";
  inherits: false;
  initial-value: solid;
}
@property --tw-blur {
  syntax: "*";
  inherits: false;
}
@property --tw-brightness {
  syntax: "*";
  inherits: false;
}
@property --tw-contrast {
  syntax: "*";
  inherits: false;
}
@property --tw-grayscale {
  syntax: "*";
  inherits: false;
}
@property --tw-hue-rotate {
  syntax: "*";
  inherits: false;
}
@property --tw-invert {
  syntax: "*";
  inherits: false;
}
@property --tw-opacity {
  syntax: "*";
  inherits: false;
}
@property --tw-saturate {
  syntax: "*";
  inherits: false;
}
@property --tw-sepia {
  syntax: "*";
  inherits: false;
}
@property --tw-drop-shadow {
  syntax: "*";
  inherits: false;
}
@property --tw-drop-shadow-color {
  syntax: "*";
  inherits: false;
}
@property --tw-drop-shadow-alpha {
  syntax: "<percentage>";
  inherits: false;
  initial-value: 100%;
}
@property --tw-drop-shadow-size {
  syntax: "*";
  inherits: false;
}
@property --tw-backdrop-blur {
  syntax: "*";
  inherits: false;
}
@property --tw-backdrop-brightness {
  syntax: "*";
  inherits: false;
}
@property --tw-backdrop-contrast {
  syntax: "*";
  inherits: false;
}
@property --tw-backdrop-grayscale {
  syntax: "*";
  inherits: false;
}
@property --tw-backdrop-hue-rotate {
  syntax: "*";
  inherits: false;
}
@property --tw-backdrop-invert {
  syntax: "*";
  inherits: false;
}
@property --tw-backdrop-opacity {
  syntax: "*";
  inherits: false;
}
@property --tw-backdrop-saturate {
  syntax: "*";
  inherits: false;
}
@property --tw-backdrop-sepia {
  syntax: "*";
  inherits: false;
}
@property --tw-duration {
  syntax: "*";
  inherits: false;
}
@property --tw-ease {
  syntax: "*";
  inherits: false;
}
@property --tw-content {
  syntax: "*";
  initial-value: "";
  inherits: false;
}
@keyframes spin {
  to {
    transform: rotate(360deg);
  }
}
@keyframes ping {
  75%, 100% {
    transform: scale(2);
    opacity: 0;
  }
}
@keyframes pulse {
  50% {
    opacity: 0.5;
  }
}
@keyframes bounce {
  0%, 100% {
    transform: translateY(-25%);
    animation-timing-function: cubic-bezier(0.8, 0, 1, 1);
  }
  50% {
    transform: none;
    animation-timing-function: cubic-bezier(0, 0, 0.2, 1);
  }
}
@layer properties {
  @supports ((-webkit-hyphens: none) and (not (margin-trim: inline))) or ((-moz-orient: inline) and (not (color:rgb(from red r g b)))) {
    *, ::before, ::after, ::backdrop {
      --tw-translate-x: 0;
      --tw-translate-y: 0;
      --tw-translate-z: 0;
      --tw-scale-x: 1;
      --tw-scale-y: 1;
      --tw-scale-z: 1;
      --tw-rotate-x: initial;
      --tw-rotate-y: initial;
      --tw-rotate-z: initial;
      --tw-skew-x: initial;
      --tw-skew-y: initial;
      --tw-pan-x: initial;
      --tw-pan-y: initial;
      --tw-pinch-zoom: 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-shadow: 0 0 #0000;
      --tw-shadow-color: initial;
      --tw-shadow-alpha: 100%;
      --tw-inset-shadow: 0 0 #0000;
      --tw-inset-shadow-color: initial;
      --tw-inset-shadow-alpha: 100%;
      --tw-ring-color: initial;
      --tw-ring-shadow: 0 0 #0000;
      --tw-inset-ring-color: initial;
      --tw-inset-ring-shadow: 0 0 #0000;
      --tw-ring-inset: initial;
      --tw-ring-offset-width: 0px;
      --tw-ring-offset-color: #fff;
      --tw-ring-offset-shadow: 0 0 #0000;
      --tw-outline-style: solid;
      --tw-blur: initial;
      --tw-brightness: initial;
      --tw-contrast: initial;
      --tw-grayscale: initial;
      --tw-hue-rotate: initial;
      --tw-invert: initial;
      --tw-opacity: initial;
      --tw-saturate: initial;
      --tw-sepia: initial;
      --tw-drop-shadow: initial;
      --tw-drop-shadow-color: initial;
      --tw-drop-shadow-alpha: 100%;
      --tw-drop-shadow-size: initial;
      --tw-backdrop-blur: initial;
      --tw-backdrop-brightness: initial;
      --tw-backdrop-contrast: initial;
      --tw-backdrop-grayscale: initial;
      --tw-backdrop-hue-rotate: initial;
      --tw-backdrop-invert: initial;
      --tw-backdrop-opacity: initial;
      --tw-backdrop-saturate: initial;
      --tw-backdrop-sepia: initial;
      --tw-duration: initial;
      --tw-ease: initial;
      --tw-content: "";
    }
  }
}
