@import "https://fonts.googleapis.com/css2?family=Geist:wght@300;400;500;600;700&family=Geist+Mono:wght@400;500;600&display=swap";

/* node_modules/tailwindcss/index.css */
@layer theme, base, components, utilities;
@layer theme {
  @theme default { --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-mauve-50: oklch(98.5% 0 0); --color-mauve-100: oklch(96% 0.003 325.6); --color-mauve-200: oklch(92.2% 0.005 325.62); --color-mauve-300: oklch(86.5% 0.012 325.68); --color-mauve-400: oklch(71.1% 0.019 323.02); --color-mauve-500: oklch(54.2% 0.034 322.5); --color-mauve-600: oklch(43.5% 0.029 321.78); --color-mauve-700: oklch(36.4% 0.029 323.89); --color-mauve-800: oklch(26.3% 0.024 320.12); --color-mauve-900: oklch(21.2% 0.019 322.12); --color-mauve-950: oklch(14.5% 0.008 326); --color-olive-50: oklch(98.8% 0.003 106.5); --color-olive-100: oklch(96.6% 0.005 106.5); --color-olive-200: oklch(93% 0.007 106.5); --color-olive-300: oklch(88% 0.011 106.6); --color-olive-400: oklch(73.7% 0.021 106.9); --color-olive-500: oklch(58% 0.031 107.3); --color-olive-600: oklch(46.6% 0.025 107.3); --color-olive-700: oklch(39.4% 0.023 107.4); --color-olive-800: oklch(28.6% 0.016 107.4); --color-olive-900: oklch(22.8% 0.013 107.4); --color-olive-950: oklch(15.3% 0.006 107.1); --color-mist-50: oklch(98.7% 0.002 197.1); --color-mist-100: oklch(96.3% 0.002 197.1); --color-mist-200: oklch(92.5% 0.005 214.3); --color-mist-300: oklch(87.2% 0.007 219.6); --color-mist-400: oklch(72.3% 0.014 214.4); --color-mist-500: oklch(56% 0.021 213.5); --color-mist-600: oklch(45% 0.017 213.2); --color-mist-700: oklch(37.8% 0.015 216); --color-mist-800: oklch(27.5% 0.011 216.9); --color-mist-900: oklch(21.8% 0.008 223.9); --color-mist-950: oklch(14.8% 0.004 228.8); --color-taupe-50: oklch(98.6% 0.002 67.8); --color-taupe-100: oklch(96% 0.002 17.2); --color-taupe-200: oklch(92.2% 0.005 34.3); --color-taupe-300: oklch(86.8% 0.007 39.5); --color-taupe-400: oklch(71.4% 0.014 41.2); --color-taupe-500: oklch(54.7% 0.021 43.1); --color-taupe-600: oklch(43.8% 0.017 39.3); --color-taupe-700: oklch(36.7% 0.016 35.7); --color-taupe-800: oklch(26.8% 0.011 36.5); --color-taupe-900: oklch(21.4% 0.009 43.1); --color-taupe-950: oklch(14.7% 0.004 49.3); --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); --text-shadow-2xs: 0px 1px 0px rgb(0 0 0 / 0.15); --text-shadow-xs: 0px 1px 1px rgb(0 0 0 / 0.2); --text-shadow-sm: 0px 1px 0px rgb(0 0 0 / 0.075), 0px 1px 1px rgb(0 0 0 / 0.075), 0px 2px 2px rgb(0 0 0 / 0.075); --text-shadow-md: 0px 1px 1px rgb(0 0 0 / 0.1), 0px 1px 2px rgb(0 0 0 / 0.1), 0px 2px 4px rgb(0 0 0 / 0.1); --text-shadow-lg: 0px 1px 2px rgb(0 0 0 / 0.1), 0px 3px 2px rgb(0 0 0 / 0.1), 0px 4px 8px rgb(0 0 0 / 0.1); --ease-in: cubic-bezier(0.4, 0, 1, 1); --ease-out: cubic-bezier(0, 0, 0.2, 1); --ease-in-out: cubic-bezier(0.4, 0, 0.2, 1); --animate-spin: spin 1s linear infinite; --animate-ping: ping 1s cubic-bezier(0, 0, 0.2, 1) infinite; --animate-pulse: pulse 2s cubic-bezier(0.4, 0, 0.6, 1) infinite; --animate-bounce: bounce 1s infinite; @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); } } --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: --theme(--font-sans, initial); --default-font-feature-settings: --theme( --font-sans--font-feature-settings, initial ); --default-font-variation-settings: --theme( --font-sans--font-variation-settings, initial ); --default-mono-font-family: --theme(--font-mono, initial); --default-mono-font-feature-settings: --theme( --font-mono--font-feature-settings, initial ); --default-mono-font-variation-settings: --theme( --font-mono--font-variation-settings, initial ); }
  @theme default inline reference { --blur: 8px; --shadow: 0 1px 3px 0 rgb(0 0 0 / 0.1), 0 1px 2px -1px rgb(0 0 0 / 0.1); --shadow-inner: inset 0 2px 4px 0 rgb(0 0 0 / 0.05); --drop-shadow: 0 1px 2px rgb(0 0 0 / 0.1), 0 1px 1px rgb(0 0 0 / 0.06); --radius: 0.25rem; --max-width-prose: 65ch; }
}
@layer base {
  *,
  ::after,
  ::before,
  ::backdrop,
  ::file-selector-button {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
    border: 0 solid;
  }
  html,
  :host {
    line-height: 1.5;
    -webkit-text-size-adjust: 100%;
    tab-size: 4;
    font-family: --theme(--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: --theme(--default-font-feature-settings, normal);
    font-variation-settings: --theme(--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: --theme(--default-mono-font-family, ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace);
    font-feature-settings: --theme(--default-mono-font-feature-settings, normal);
    font-variation-settings: --theme(--default-mono-font-variation-settings, normal);
    font-size: 1em;
  }
  small {
    font-size: 80%;
  }
  sub,
  sup {
    font-size: 75%;
    line-height: 0;
    position: relative;
    vertical-align: baseline;
  }
  sub {
    bottom: -0.25em;
  }
  sup {
    top: -0.5em;
  }
  table {
    text-indent: 0;
    border-color: inherit;
    border-collapse: collapse;
  }
  :-moz-focusring {
    outline: auto;
  }
  progress {
    vertical-align: baseline;
  }
  summary {
    display: list-item;
  }
  ol,
  ul,
  menu {
    list-style: none;
  }
  img,
  svg,
  video,
  canvas,
  audio,
  iframe,
  embed,
  object {
    display: block;
    vertical-align: middle;
  }
  img,
  video {
    max-width: 100%;
    height: auto;
  }
  button,
  input,
  select,
  optgroup,
  textarea,
  ::file-selector-button {
    font: inherit;
    font-feature-settings: inherit;
    font-variation-settings: inherit;
    letter-spacing: inherit;
    color: inherit;
    border-radius: 0;
    background-color: transparent;
    opacity: 1;
  }
  :where(select:is([multiple], [size])) optgroup {
    font-weight: bolder;
  }
  :where(select:is([multiple], [size])) optgroup option {
    padding-inline-start: 20px;
  }
  ::file-selector-button {
    margin-inline-end: 4px;
  }
  ::placeholder {
    opacity: 1;
  }
  @supports (not (-webkit-appearance: -apple-pay-button)) or (contain-intrinsic-size: 1px) {
    ::placeholder {
      color: color-mix(in oklab, currentcolor 50%, transparent);
    }
  }
  textarea {
    resize: vertical;
  }
  ::-webkit-search-decoration {
    -webkit-appearance: none;
  }
  ::-webkit-date-and-time-value {
    min-height: 1lh;
    text-align: inherit;
  }
  ::-webkit-datetime-edit {
    display: inline-flex;
  }
  ::-webkit-datetime-edit-fields-wrapper {
    padding: 0;
  }
  ::-webkit-datetime-edit,
  ::-webkit-datetime-edit-year-field,
  ::-webkit-datetime-edit-month-field,
  ::-webkit-datetime-edit-day-field,
  ::-webkit-datetime-edit-hour-field,
  ::-webkit-datetime-edit-minute-field,
  ::-webkit-datetime-edit-second-field,
  ::-webkit-datetime-edit-millisecond-field,
  ::-webkit-datetime-edit-meridiem-field {
    padding-block: 0;
  }
  ::-webkit-calendar-picker-indicator {
    line-height: 1;
  }
  :-moz-ui-invalid {
    box-shadow: none;
  }
  button,
  input:where([type=button], [type=reset], [type=submit]),
  ::file-selector-button {
    appearance: button;
  }
  ::-webkit-inner-spin-button,
  ::-webkit-outer-spin-button {
    height: auto;
  }
  [hidden]:where(:not([hidden=until-found])) {
    display: none !important;
  }
}
@layer utilities {
  @tailwind utilities;
}

/* src/styles/colors_and_type.css */
:root {
  --neutral-0: #FFFFFF;
  --neutral-25: #FBFCFD;
  --neutral-50: #F6F8FB;
  --neutral-100: #EEF2F7;
  --neutral-200: #E6EAF0;
  --neutral-300: #CED5DF;
  --neutral-400: #9BA6B6;
  --neutral-500: #6B7789;
  --neutral-600: #4A5568;
  --neutral-700: #2D3748;
  --neutral-800: #1A2233;
  --neutral-900: #0A1628;
  --navy-50: #EEF3FA;
  --navy-100: #D7E1F1;
  --navy-200: #A7BAD8;
  --navy-500: #3D5982;
  --navy-700: #152544;
  --navy-900: #0A1628;
  --accent-50: #EAF1FF;
  --accent-100: #CFDEFF;
  --accent-300: #7AA0FF;
  --accent-500: #4B83FF;
  --accent-600: #2E6BFF;
  --accent-700: #1F54D6;
  --accent-800: #1843A8;
  --success-50: #E7F6EE;
  --success-500: #16A34A;
  --success-700: #0F7A37;
  --warning-50: #FEF4E2;
  --warning-500: #E8A317;
  --warning-700: #A8740A;
  --danger-50: #FDECEC;
  --danger-500: #DC2626;
  --danger-700: #A81D1D;
  --info-50: #E4F2FD;
  --info-500: #0284C7;
  --info-700: #036092;
  --tenant-primary: var(--navy-900);
  --tenant-accent: var(--accent-600);
  --tenant-on-primary: #ffffff;
  --bg: var(--neutral-25);
  --bg-elevated: var(--neutral-0);
  --bg-subtle: var(--neutral-50);
  --bg-sunken: var(--neutral-100);
  --surface: var(--bg-elevated);
  --fg: var(--tenant-primary);
  --fg-muted: var(--neutral-500);
  --fg-subtle: var(--neutral-400);
  --fg-inverse: var(--neutral-0);
  --border: var(--neutral-200);
  --border-strong:var(--neutral-300);
  --divider: var(--neutral-100);
  --accent: var(--tenant-accent);
  --accent-hover: color-mix(in srgb, var(--tenant-accent) 80%, #000);
  --accent-press: color-mix(in srgb, var(--tenant-accent) 65%, #000);
  --accent-soft: color-mix(in srgb, var(--tenant-accent) 12%, transparent);
  --on-accent: var(--neutral-0);
  --font-sans:
    "Geist",
    ui-sans-serif,
    system-ui,
    -apple-system,
    "Segoe UI",
    sans-serif;
  --font-mono:
    "Geist Mono",
    ui-monospace,
    "SFMono-Regular",
    Menlo,
    monospace;
  --fs-xs: 12px;
  --fs-sm: 13px;
  --fs-base: 15px;
  --fs-md: 17px;
  --fs-lg: 20px;
  --fs-xl: 24px;
  --fs-2xl: 32px;
  --fs-3xl: 40px;
  --fs-4xl: 56px;
  --fs-5xl: 72px;
  --lh-tight: 1.1;
  --lh-snug: 1.25;
  --lh-normal: 1.5;
  --lh-relaxed: 1.65;
  --tracking-tighter: -0.03em;
  --tracking-tight: -0.015em;
  --tracking-normal: 0;
  --tracking-wide: 0.04em;
  --tracking-widest: 0.12em;
  --s-0: 0;
  --s-1: 4px;
  --s-2: 8px;
  --s-3: 12px;
  --s-4: 16px;
  --s-5: 20px;
  --s-6: 24px;
  --s-8: 32px;
  --s-10: 40px;
  --s-12: 48px;
  --s-16: 64px;
  --s-20: 80px;
  --s-24: 96px;
  --s-32: 128px;
  --r-sm: 6px;
  --r-md: 10px;
  --r-lg: 14px;
  --r-xl: 20px;
  --r-2xl: 28px;
  --r-full: 999px;
  --shadow-xs: 0 1px 2px rgba(10, 22, 40, 0.04);
  --shadow-sm: 0 1px 3px rgba(10, 22, 40, 0.06), 0 1px 2px rgba(10, 22, 40, 0.04);
  --shadow-md: 0 4px 12px rgba(10, 22, 40, 0.08), 0 2px 4px rgba(10, 22, 40, 0.04);
  --shadow-lg: 0 12px 32px rgba(10, 22, 40, 0.12), 0 4px 8px rgba(10, 22, 40, 0.06);
  --shadow-xl: 0 24px 60px rgba(10, 22, 40, 0.18), 0 8px 16px rgba(10, 22, 40, 0.08);
  --shadow-focus: 0 0 0 3px rgba(46, 107, 255, 0.28);
  --shadow-focus-danger: 0 0 0 3px rgba(220, 38, 38, 0.24);
  --ease: cubic-bezier(0.2, 0, 0, 1);
  --dur-fast: 120ms;
  --dur-base: 200ms;
  --dur-slow: 360ms;
  --container: 1200px;
  --page-max: 1400px;
  --sidebar: 240px;
  --mobile-nav-h: 64px;
}
html[data-theme=dark] {
  --bg: #060F1E;
  --bg-elevated: #0A1628;
  --bg-subtle: #0E1C33;
  --bg-sunken: #060F1E;
  --surface: var(--bg-elevated);
  --fg: #F5F7FB;
  --fg-muted: #8CA0C0;
  --fg-subtle: #5D708E;
  --border: rgba(255,255,255,0.07);
  --border-strong:rgba(255,255,255,0.14);
  --divider: rgba(255,255,255,0.05);
  color-scheme: dark;
}
html[data-theme=dark] app-tenant-shell-switcher,
html[data-theme=dark] app-tenant-shell {
  --neutral-0: #0A1628;
  --neutral-25: #0E1C33;
  --neutral-50: #0E1C33;
  --neutral-100: #142239;
  --neutral-200: #1E2A3D;
  --neutral-300: #2B3A52;
  --accent-50: rgba(75, 131, 255, 0.12);
  --accent-100: rgba(75, 131, 255, 0.20);
  --accent-200: rgba(75, 131, 255, 0.32);
  --success-50: rgba(52, 211, 153, 0.14);
  --warning-50: rgba(251, 191, 36, 0.16);
  --danger-50: rgba(248, 113, 113, 0.16);
  --info-50: rgba(56, 189, 248, 0.16);
  --accent-700: #7AA0FF;
  --success-700: #34D399;
  --warning-700: #FBBF24;
  --danger-700: #F87171;
  --info-700: #38BDF8;
  --on-accent: #FFFFFF;
  --fg-inverse: #0A1628;
}
.surface-dark {
  --bg: var(--navy-900);
  --bg-elevated: var(--navy-700);
  --bg-subtle: #0E1C33;
  --bg-sunken: #060F1E;
  --surface: var(--bg-elevated);
  --fg: var(--neutral-0);
  --fg-muted: #8CA0C0;
  --fg-subtle: #5D708E;
  --border: #1E2A3D;
  --border-strong: #2B3A52;
  --divider: #142138;
  background: var(--bg);
  color: var(--fg);
}
*,
*::before,
*::after {
  box-sizing: border-box;
}
html,
body {
  margin: 0;
  padding: 0;
  font-family: var(--font-sans);
  font-size: var(--fs-base);
  line-height: var(--lh-normal);
  color: var(--fg);
  background: var(--bg);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
}
h1,
h2,
h3,
h4,
h5,
h6 {
  margin: 0;
  font-weight: 600;
  letter-spacing: var(--tracking-tight);
  line-height: var(--lh-tight);
  color: var(--fg);
}
h1 {
  font-size: var(--fs-4xl);
  letter-spacing: var(--tracking-tighter);
}
h2 {
  font-size: var(--fs-3xl);
  letter-spacing: var(--tracking-tighter);
}
h3 {
  font-size: var(--fs-2xl);
}
h4 {
  font-size: var(--fs-xl);
}
h5 {
  font-size: var(--fs-lg);
}
h6 {
  font-size: var(--fs-md);
}
p {
  margin: 0;
  line-height: var(--lh-normal);
}
a {
  color: var(--accent);
  text-decoration: none;
  transition: color var(--dur-fast) var(--ease);
}
a:hover {
  color: var(--accent-hover);
}
code,
kbd,
samp,
pre {
  font-family: var(--font-mono);
  font-size: 0.92em;
}
.eyebrow {
  font-size: var(--fs-xs);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: var(--tracking-widest);
  color: var(--fg-muted);
}
.mono {
  font-family: var(--font-mono);
  font-feature-settings: "tnum";
}
.tabular {
  font-variant-numeric: tabular-nums;
}
.text-muted {
  color: var(--fg-muted);
}
.text-subtle {
  color: var(--fg-subtle);
}
.display {
  font-size: var(--fs-5xl);
  font-weight: 600;
  letter-spacing: -0.035em;
  line-height: 1.02;
}
:focus-visible {
  outline: none;
  box-shadow: var(--shadow-focus);
  border-radius: var(--r-sm);
}

/* src/styles/_shared.css */
html,
body {
  overflow-x: hidden;
  max-width: 100vw;
}
body {
  margin: 0;
  background: var(--bg);
  color: var(--fg);
  font-family: var(--font-sans);
}
#root {
  min-height: 100vh;
}
.btn {
  font-family: var(--font-sans);
  font-size: 14px;
  font-weight: 500;
  border-radius: var(--r-sm);
  padding: 10px 16px;
  border: 1px solid transparent;
  cursor: pointer;
  transition: all var(--dur-fast) var(--ease);
  letter-spacing: -0.005em;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  white-space: nowrap;
}
.btn-primary {
  background: var(--accent-600);
  color: #fff;
}
.btn-primary:hover {
  background: var(--accent-700);
}
.btn-secondary {
  background: var(--neutral-0);
  color: var(--fg);
  border-color: var(--border);
}
.btn-secondary:hover {
  background: var(--neutral-50);
  border-color: var(--border-strong);
}
.btn-ghost {
  background: transparent;
  color: var(--fg);
}
.btn-ghost:hover {
  background: var(--neutral-100);
}
.btn-sm {
  padding: 6px 12px;
  font-size: 13px;
}
.btn-lg {
  padding: 13px 22px;
  font-size: 16px;
}
.btn-dark {
  background: var(--neutral-0);
  color: var(--navy-900);
}
.btn-dark:hover {
  background: var(--neutral-100);
}
.badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 12px;
  font-weight: 500;
  padding: 3px 9px;
  border-radius: var(--r-full);
}
.badge-accent {
  background: var(--accent-50);
  color: var(--accent-700);
}
.badge-success {
  background: var(--success-50);
  color: var(--success-700);
}
.badge-warning {
  background: var(--warning-50);
  color: var(--warning-700);
}
.badge-danger {
  background: var(--danger-50);
  color: var(--danger-700);
}
.badge-neutral {
  background: var(--neutral-100);
  color: var(--fg);
}
.badge-outline {
  background: transparent;
  border: 1px solid var(--border);
  color: var(--fg-muted);
}
.dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  display: inline-block;
}
.avatar {
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  font-weight: 600;
  flex-shrink: 0;
  font-family: var(--font-sans);
}
.avatar-xs {
  width: 20px;
  height: 20px;
  font-size: 9px;
}
.avatar-sm {
  width: 28px;
  height: 28px;
  font-size: 11px;
}
.avatar-md {
  width: 36px;
  height: 36px;
  font-size: 13px;
}
.avatar-lg {
  width: 48px;
  height: 48px;
  font-size: 16px;
}
.input {
  font-family: var(--font-sans);
  font-size: 14px;
  padding: 10px 12px;
  border-radius: var(--r-md);
  border: 1px solid var(--border);
  background: var(--neutral-0);
  color: var(--fg);
  transition: all var(--dur-fast) var(--ease);
  width: 100%;
}
.input::placeholder {
  color: var(--fg-subtle);
}
.input:hover {
  border-color: var(--border-strong);
}
.input:focus {
  border-color: var(--accent-600);
  box-shadow: var(--shadow-focus);
  outline: none;
}
.card {
  background: var(--neutral-0);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
}
.card-marketing {
  background: var(--neutral-0);
  border-radius: var(--r-lg);
  box-shadow: var(--shadow-sm);
  transition: box-shadow var(--dur-base) var(--ease), transform var(--dur-base) var(--ease);
}
.card-marketing:hover {
  box-shadow: var(--shadow-md);
  transform: translateY(-2px);
}
.eyebrow {
  font-size: 12px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--fg-muted);
}
.lucide {
  stroke-width: 1.5;
}
.divider {
  height: 1px;
  background: var(--divider);
  border: 0;
  margin: 0;
}

/* src/styles/landing.css */
html,
body {
  scroll-behavior: smooth;
}
section {
  position: relative;
}
.container {
  max-width: var(--container);
  margin: 0 auto;
  padding: 0 24px;
}
.eyebrow {
  font-size: 11px;
}
.field-pattern {
  background-image:
    radial-gradient(
      circle at 1px 1px,
      rgba(10, 22, 40, 0.08) 1px,
      transparent 0);
  background-size: 24px 24px;
}
.hero-headline {
  font-size: clamp(56px, 7vw, 88px);
  line-height: 0.98;
  letter-spacing: -0.035em;
  font-weight: 600;
  margin: 0;
}
.hero-headline em {
  font-style: normal;
  color: var(--accent-600);
  position: relative;
}
.section-h2 {
  font-size: clamp(36px, 4vw, 52px);
  letter-spacing: -0.03em;
  line-height: 1.08;
  font-weight: 600;
}
.tab-active-bar {
  transition: transform var(--dur-base) var(--ease), width var(--dur-base) var(--ease);
}
.elev-card {
  background: var(--neutral-0);
  border: 1px solid var(--border);
  border-radius: var(--r-xl);
  box-shadow: var(--shadow-xl);
  overflow: hidden;
}
.mock {
  background: var(--neutral-0);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
}
.mock-dark {
  background: var(--navy-900);
  color: #fff;
  border-radius: var(--r-md);
}
@keyframes pulse-ring {
  0% {
    box-shadow: 0 0 0 0 rgba(46, 107, 255, 0.4);
  }
  100% {
    box-shadow: 0 0 0 10px rgba(46, 107, 255, 0);
  }
}
.pulse-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--accent-600);
  animation: pulse-ring 1.8s infinite var(--ease);
}
.nav-link {
  position: relative;
  padding: 4px 0;
}
.nav-link:hover {
  color: var(--accent-600);
}
@keyframes fadeUp {
  from {
    opacity: 0;
    transform: translateY(6px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}
.fade-up {
  animation: fadeUp var(--dur-base) var(--ease);
}
.tweaks-panel {
  position: fixed;
  bottom: 20px;
  right: 20px;
  z-index: 100;
  width: 280px;
  background: var(--neutral-0);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  box-shadow: var(--shadow-lg);
  padding: 16px;
  font-size: 13px;
}
.tweaks-panel h4 {
  font-size: 13px;
  font-weight: 600;
  margin: 0 0 4px;
}
.tweaks-row {
  display: flex;
  flex-direction: column;
  gap: 6px;
  margin-top: 12px;
}
.tweaks-row label {
  font-size: 11px;
  color: var(--fg-muted);
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}
.tweaks-chips {
  display: flex;
  gap: 4px;
  flex-wrap: wrap;
}
.tweaks-chip {
  font-size: 12px;
  padding: 5px 10px;
  border-radius: var(--r-full);
  border: 1px solid var(--border);
  background: var(--neutral-0);
  cursor: pointer;
  color: var(--fg);
}
.tweaks-chip.active {
  background: var(--navy-900);
  color: #fff;
  border-color: var(--navy-900);
}
.hero-product-frame {
  background: var(--neutral-0);
  border: 1px solid var(--border);
  border-radius: var(--r-xl);
  box-shadow:
    0 40px 100px -20px rgba(10, 22, 40, 0.25),
    0 20px 40px -10px rgba(10, 22, 40, 0.12),
    0 0 0 1px rgba(10, 22, 40, 0.04);
  overflow: hidden;
}
.tab-btn {
  font-family: var(--font-sans);
  font-size: 14px;
  font-weight: 500;
  padding: 8px 14px;
  border-radius: var(--r-full);
  border: 1px solid var(--border);
  background: var(--neutral-0);
  color: var(--fg-muted);
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  transition: all var(--dur-fast) var(--ease);
}
.tab-btn:hover {
  border-color: var(--border-strong);
  color: var(--fg);
}
.tab-btn.active {
  background: var(--navy-900);
  border-color: var(--navy-900);
  color: #fff;
}
.stat-num {
  font-family: var(--font-mono);
  font-variant-numeric: tabular-nums;
  font-weight: 600;
  letter-spacing: -0.02em;
}
.rule {
  height: 1px;
  background: var(--border);
  border: 0;
  margin: 0;
}
.checklist {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.checklist li {
  display: flex;
  gap: 12px;
  align-items: flex-start;
  font-size: 15px;
  line-height: 1.5;
}
.checklist .check {
  width: 22px;
  height: 22px;
  border-radius: 50%;
  background: var(--accent-50);
  color: var(--accent-700);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  margin-top: 1px;
}
.surface-dark .section-h2 {
  color: #fff;
}
@media (max-width: 900px) {
  .nav-links {
    display: none !important;
  }
  .hero-split {
    grid-template-columns: 1fr !important;
  }
}

/* src/styles/mobile-tokens.css */
.sd-screen,
.sd-screen[data-theme=light] {
  --bg: #F6F8FB;
  --bg-elev: #FFFFFF;
  --surface: #FFFFFF;
  --surface-2: #EEF2F7;
  --surface-3: #E6EAF0;
  --border: rgba(10, 22, 40, 0.07);
  --border-strong:rgba(10, 22, 40, 0.14);
  --text: #0A1628;
  --text-muted: #6B7789;
  --text-subtle: #9BA6B6;
  --accent: var(--tenant-accent, #2E6BFF);
  --accent-hover: #1F54D6;
  --accent-tint: rgba(46, 107, 255, 0.10);
  --accent-tint-strong: rgba(46, 107, 255, 0.18);
  --accent-on: #FFFFFF;
  --navy: #0A1628;
  --navy-soft: #152544;
  --success: #16A34A;
  --success-tint: rgba(22, 163, 74, 0.10);
  --warning: #E8A317;
  --warning-tint: rgba(232, 163, 23, 0.14);
  --danger: #DC2626;
  --danger-tint: rgba(220, 38, 38, 0.10);
  --info: #0284C7;
  --info-tint: rgba(2, 132, 199, 0.10);
  --shadow-card: 0 1px 0 rgba(255,255,255,0.6) inset, 0 1px 2px rgba(10,22,40,0.05);
  --shadow-fab: 0 8px 24px rgba(46,107,255,0.32), 0 2px 6px rgba(10,22,40,0.16);
  --nav-bg: rgba(255,255,255,0.86);
  --nav-border: rgba(10,22,40,0.06);
  --skeleton: rgba(10,22,40,0.04);
  --ease-out: cubic-bezier(0.2, 0, 0, 1);
  --fg: var(--text);
  --fg-muted: var(--text-muted);
  --on-accent:var(--accent-on);
}
.sd-screen[data-theme=dark] {
  --bg: #060F1E;
  --bg-elev: #0A1628;
  --surface: #0E1C33;
  --surface-2: #142239;
  --surface-3: #1B2B45;
  --border: rgba(255,255,255,0.07);
  --border-strong:rgba(255,255,255,0.14);
  --text: #F5F7FB;
  --text-muted: #8CA0C0;
  --text-subtle: #5D708E;
  --accent: var(--tenant-accent, #4B83FF);
  --accent-hover: #6A9EFF;
  --accent-tint: rgba(75, 131, 255, 0.16);
  --accent-tint-strong: rgba(75, 131, 255, 0.26);
  --accent-on: #FFFFFF;
  --navy: #F5F7FB;
  --navy-soft: #C7D2E5;
  --success: #34D399;
  --success-tint: rgba(52, 211, 153, 0.16);
  --warning: #FBBF24;
  --warning-tint: rgba(251, 191, 36, 0.16);
  --danger: #F87171;
  --danger-tint: rgba(248, 113, 113, 0.16);
  --info: #38BDF8;
  --info-tint: rgba(56, 189, 248, 0.16);
  --shadow-card: 0 1px 0 rgba(255,255,255,0.03) inset, 0 1px 2px rgba(0,0,0,0.4);
  --shadow-fab: 0 8px 24px rgba(75,131,255,0.42), 0 2px 6px rgba(0,0,0,0.3);
  --nav-bg: rgba(8,14,28,0.78);
  --nav-border: rgba(255,255,255,0.06);
  --skeleton: rgba(255,255,255,0.04);
}
.sd-screen {
  width: 100%;
  height: 100svh;
  height: 100dvh;
  background: var(--bg);
  color: var(--text);
  font-family:
    "Geist",
    -apple-system,
    BlinkMacSystemFont,
    "Segoe UI",
    system-ui,
    sans-serif;
  font-feature-settings: "ss01", "cv11";
  -webkit-font-smoothing: antialiased;
  display: flex;
  flex-direction: column;
  position: relative;
  overflow: hidden;
}
.sd-num {
  font-family:
    "Geist Mono",
    ui-monospace,
    "SF Mono",
    monospace;
  font-feature-settings: "tnum";
  letter-spacing: -0.01em;
}
.sd-header {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px 16px 8px;
  padding-top: max(12px, env(safe-area-inset-top));
}
.sd-header .title {
  font-size: 22px;
  font-weight: 600;
  letter-spacing: -0.02em;
  flex: 1;
}
.sd-header .title-lg {
  font-size: 28px;
  font-weight: 700;
  letter-spacing: -0.025em;
  flex: 1;
}
.sd-iconbtn {
  width: 38px;
  height: 38px;
  border-radius: 999px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--surface);
  border: 1px solid var(--border);
  color: var(--text);
  position: relative;
  flex-shrink: 0;
  cursor: pointer;
}
.sd-iconbtn .dot {
  position: absolute;
  top: 8px;
  right: 8px;
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: var(--accent);
  border: 2px solid var(--surface);
}
.sd-body {
  flex: 1;
  overflow-y: auto;
  padding: 0 16px;
  padding-bottom: calc(96px + env(safe-area-inset-bottom));
  scrollbar-width: none;
  overscroll-behavior-y: contain;
}
.sd-body::-webkit-scrollbar {
  display: none;
}
.sd-pull-indicator {
  position: absolute;
  top: 0;
  left: 50%;
  width: 36px;
  height: 36px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--surface);
  color: var(--text);
  border: 1px solid var(--border);
  box-shadow: 0 2px 6px rgba(0, 0, 0, 0.08);
  z-index: 5;
  pointer-events: none;
  will-change: transform, opacity;
  opacity: 0;
  transform: translate(-50%, -44px);
}
.sd-pull-indicator-spinner {
  display: inline-flex;
  transition: transform 0.05s linear;
}
.sd-pull-indicator-spinner.spinning {
  animation: sd-pull-spin 0.9s linear infinite;
}
@keyframes sd-pull-spin {
  to {
    transform: rotate(360deg);
  }
}
.sd-section-title {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  padding: 22px 4px 12px;
  gap: 12px;
}
.sd-section-title .label {
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--text-muted);
  white-space: nowrap;
}
.sd-section-title .action {
  font-size: 13px;
  color: var(--accent);
  font-weight: 500;
  white-space: nowrap;
  display: inline-flex;
  align-items: center;
  gap: 4px;
  text-decoration: none;
  cursor: pointer;
}
.sd-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 18px;
  padding: 16px;
  box-shadow: var(--shadow-card);
}
.sd-bottomnav {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  padding: 6px 14px 8px;
  padding-bottom: max(8px, env(safe-area-inset-bottom));
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  background:
    linear-gradient(
      to top,
      var(--bg) 60%,
      transparent);
  pointer-events: none;
  z-index: 5;
}
.sd-bottomnav-inner {
  flex: 1;
  background: var(--nav-bg);
  -webkit-backdrop-filter: blur(20px) saturate(180%);
  backdrop-filter: blur(20px) saturate(180%);
  border: 1px solid var(--border);
  border-radius: 24px;
  padding: 4px;
  display: grid;
  grid-template-columns: 1fr 1fr 56px 1fr 1fr;
  align-items: center;
  pointer-events: auto;
  box-shadow: 0 10px 30px rgba(10, 22, 40, 0.10);
}
.sd-bottomnav-inner.flat-5 {
  grid-template-columns: repeat(5, 1fr);
}
.sd-bottomnav-inner.flat-4 {
  grid-template-columns: repeat(4, 1fr);
}
.sd-navitem {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 3px;
  padding: 8px 4px 6px;
  border-radius: 18px;
  color: var(--text-subtle);
  font-size: 10.5px;
  font-weight: 500;
  letter-spacing: -0.01em;
  cursor: pointer;
  white-space: nowrap;
  background: transparent;
  border: 0;
  font-family: inherit;
}
.sd-navitem.active {
  color: var(--text);
}
.sd-navitem .dotind {
  width: 4px;
  height: 4px;
  border-radius: 50%;
  background: transparent;
  margin-top: 2px;
}
.sd-navitem.active .dotind {
  background: var(--accent);
}
.sd-fab {
  width: 46px;
  height: 46px;
  border-radius: 50%;
  background: var(--accent);
  color: var(--accent-on);
  border: none;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: var(--shadow-fab);
  margin: 0 auto;
  cursor: pointer;
  transition: transform .15s var(--ease-out), background-color .15s var(--ease-out);
}
.sd-fab:hover {
  transform: translateY(-1px);
  background: var(--accent-hover);
}
.sd-fab:active {
  transform: translateY(0);
}
.sd-pill {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 4px 10px;
  border-radius: 999px;
  font-size: 12px;
  font-weight: 500;
  background: var(--surface-2);
  color: var(--text-muted);
  border: 1px solid var(--border);
  white-space: nowrap;
}
.sd-pill.success {
  background: var(--success-tint);
  color: var(--success);
  border-color: transparent;
}
.sd-pill.warning {
  background: var(--warning-tint);
  color: var(--warning);
  border-color: transparent;
}
.sd-pill.danger {
  background: var(--danger-tint);
  color: var(--danger);
  border-color: transparent;
}
.sd-pill.accent {
  background: var(--accent-tint);
  color: var(--accent);
  border-color: transparent;
}
.sd-pill.info {
  background: var(--info-tint);
  color: var(--info);
  border-color: transparent;
}
.sd-pill.solid {
  background: var(--navy);
  color: #fff;
  border-color: transparent;
}
.sd-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  height: 48px;
  padding: 0 18px;
  border-radius: 14px;
  box-sizing: border-box;
  font-family: inherit;
  font-size: 15px;
  font-weight: 600;
  letter-spacing: -0.01em;
  background: var(--surface-2);
  color: var(--text);
  border: 1px solid var(--border);
  cursor: pointer;
  transition: background .12s var(--ease-out);
}
.sd-btn:hover {
  background: var(--surface-3);
}
.sd-btn.primary {
  background: var(--accent);
  color: var(--accent-on);
  border-color: transparent;
}
.sd-btn.primary:hover {
  background: var(--accent-hover);
}
.sd-btn.navy {
  background: var(--navy);
  color: #fff;
  border-color: transparent;
}
.sd-btn.ghost {
  background: transparent;
}
.sd-btn.danger {
  background: var(--danger-tint);
  color: var(--danger);
  border-color: transparent;
}
.sd-btn.full {
  width: 100%;
}
.sd-btn.sm {
  height: 36px;
  padding: 0 14px;
  font-size: 13px;
  border-radius: 10px;
}
.sd-btn:disabled {
  opacity: 0.55;
  cursor: not-allowed;
}
.sd-input {
  width: 100%;
  height: 48px;
  box-sizing: border-box;
  background: var(--surface-2);
  border: 1px solid var(--border);
  border-radius: 14px;
  padding: 0 14px;
  font-family: inherit;
  font-size: 15px;
  color: var(--text);
  outline: none;
}
.sd-input::placeholder {
  color: var(--text-subtle);
}
.sd-input:focus {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px var(--accent-tint);
}
.sd-input.search {
  padding-left: 40px;
}
.sd-textarea {
  composes: sd-input;
  height: auto;
  min-height: 96px;
  padding: 12px 14px;
  resize: vertical;
}
.sd-searchwrap {
  position: relative;
}
.sd-searchwrap .search-icon {
  position: absolute;
  left: 14px;
  top: 50%;
  transform: translateY(-50%);
  color: var(--text-subtle);
  pointer-events: none;
}
.sd-tabs {
  display: flex;
  gap: 4px;
  background: var(--surface-2);
  border-radius: 12px;
  padding: 4px;
}
.sd-tab {
  flex: 1;
  height: 32px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 13px;
  font-weight: 500;
  border-radius: 8px;
  color: var(--text-muted);
  cursor: pointer;
  white-space: nowrap;
  background: transparent;
  border: 0;
  font-family: inherit;
}
.sd-tab.active {
  background: var(--bg-elev);
  color: var(--text);
  box-shadow: 0 1px 2px rgba(10, 22, 40, 0.06);
}
.sd-filterchips {
  scrollbar-width: none;
  -ms-overflow-style: none;
  display: flex;
  gap: 8px;
  overflow-x: auto;
}
.sd-filterchips::-webkit-scrollbar {
  display: none;
}
.sd-chip {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 6px 12px;
  border-radius: 999px;
  background: var(--surface-2);
  border: 1px solid var(--border);
  font-size: 13px;
  color: var(--text-muted);
  cursor: pointer;
  white-space: nowrap;
  flex-shrink: 0;
  font-family: inherit;
}
.sd-chip.active {
  background: var(--accent);
  color: var(--accent-on);
  border-color: transparent;
}
.sd-quickgrid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
}
.sd-quicktile {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 16px;
  padding: 14px;
  display: flex;
  flex-direction: column;
  gap: 10px;
  min-height: 96px;
  text-decoration: none;
  color: inherit;
  cursor: pointer;
  font-family: inherit;
  text-align: left;
}
.sd-quicktile .icon-wrap {
  width: 36px;
  height: 36px;
  border-radius: 10px;
  background: var(--accent-tint);
  color: var(--accent);
  display: flex;
  align-items: center;
  justify-content: center;
}
.sd-quicktile .label {
  font-size: 14px;
  font-weight: 600;
  letter-spacing: -0.01em;
}
.sd-quicktile .sub {
  font-size: 12px;
  color: var(--text-muted);
}
.sd-avatar {
  width: 40px;
  height: 40px;
  border-radius: 12px;
  background: var(--surface-2);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 14px;
  font-weight: 600;
  color: var(--text);
  flex-shrink: 0;
}
.sd-switch {
  width: 44px;
  height: 26px;
  border-radius: 999px;
  background: var(--surface-3);
  position: relative;
  cursor: pointer;
  transition: background .15s;
  border: 1px solid var(--border);
}
.sd-switch.on {
  background: var(--accent);
  border-color: transparent;
}
.sd-switch::after {
  content: "";
  position: absolute;
  top: 2px;
  left: 2px;
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background: #fff;
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.25);
  transition: transform .15s;
}
.sd-switch.on::after {
  transform: translateX(18px);
}
@keyframes sd-sheet-up {
  from {
    transform: translateY(100%);
    opacity: 0;
  }
  to {
    transform: translateY(0);
    opacity: 1;
  }
}
.sd-sheet-backdrop {
  position: absolute;
  inset: 0;
  z-index: 30;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
}
.sd-sheet-scrim {
  position: absolute;
  inset: 0;
  background: rgba(10, 22, 40, 0.5);
  -webkit-backdrop-filter: blur(3px);
  backdrop-filter: blur(3px);
}
.sd-sheet {
  position: relative;
  background: var(--bg-elev);
  border-top-left-radius: 24px;
  border-top-right-radius: 24px;
  padding: 14px 14px 28px;
  padding-bottom: calc(28px + env(safe-area-inset-bottom));
  box-shadow: 0 -20px 50px rgba(10, 22, 40, 0.20);
  animation: sd-sheet-up .25s var(--ease-out);
  max-height: 85%;
  overflow-y: auto;
}
.sd-sheet-grip {
  width: 40px;
  height: 4px;
  border-radius: 2px;
  background: var(--surface-3);
  margin: 0 auto 12px;
}
.sd-notice {
  background: var(--accent-tint);
  border: 1px solid var(--accent-tint-strong);
  border-radius: 14px;
  padding: 12px 14px;
  color: var(--text);
  font-size: 13px;
  display: flex;
  gap: 10px;
  align-items: flex-start;
}
.sd-notice.success {
  background: var(--success-tint);
  border-color: transparent;
}
.sd-notice.warning {
  background: var(--warning-tint);
  border-color: transparent;
}
.sd-notice.danger {
  background: var(--danger-tint);
  border-color: transparent;
}
.sd-empty {
  text-align: center;
  padding: 48px 16px;
  color: var(--text-muted);
  font-size: 14px;
}
.sd-tenant-pill {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 6px 12px 6px 6px;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 999px;
  font-size: 13px;
  font-weight: 600;
  color: var(--text);
  max-width: 220px;
  cursor: pointer;
  font-family: inherit;
}
.sd-tenant-pill .swatch {
  width: 26px;
  height: 26px;
  border-radius: 8px;
  background: var(--accent);
  color: #fff;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-weight: 700;
  font-size: 12px;
  flex-shrink: 0;
}
.sd-tenant-pill .label {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  flex: 1;
  min-width: 0;
}
.sd-col {
  display: flex;
  flex-direction: column;
}
.sd-row {
  display: flex;
  align-items: center;
}
.sd-divider {
  height: 1px;
  background: var(--border);
  margin: 12px 0;
}
.sd-progress {
  width: 100%;
  height: 6px;
  border-radius: 3px;
  background: var(--surface-2);
  overflow: hidden;
}
.sd-progress > span {
  display: block;
  height: 100%;
  background: var(--accent);
  transition: width .35s var(--ease-out);
}
.sd-screen:has(.chat-layout.show-thread) .sd-bottomnav,
.sd-screen:has(.immersive-mobile) .sd-bottomnav {
  display: none;
}
.sd-screen .sticky-bar,
.sd-screen .mobile-floats-above-nav {
  bottom: calc(82px + env(safe-area-inset-bottom, 0px)) !important;
}
.sd-screen .chat-layout:not(.show-thread) {
  height: 100%;
}
.sd-screen .chat-layout:not(.show-thread) .sidebar {
  padding-bottom: 90px;
}
.sd-screen > router-outlet + * {
  position: absolute;
  inset: 0;
  overflow-y: auto;
  overscroll-behavior-y: contain;
  padding-top: env(safe-area-inset-top);
  padding-bottom: env(safe-area-inset-bottom);
}
.sd-screen > router-outlet + *:has(.sd-header) {
  padding-top: 0;
}
.sd-screen > router-outlet + *:has(.sd-body) {
  padding-bottom: 0;
}
.sd-screen .page-fab {
  position: fixed;
  right: 16px;
  bottom: calc(86px + env(safe-area-inset-bottom));
  z-index: 4;
}
.sd-screen > router-outlet + *:not(:has(.sd-body)) > :first-child {
  padding-bottom: 100px;
}
@media (max-width: 767px) {
  html:has(.sd-screen),
  body:has(.sd-screen) {
    height: 100%;
    overflow: hidden;
    overscroll-behavior: none;
  }
  app-root:has(.sd-screen),
  app-tenant-shell-switcher:has(.sd-screen) {
    height: 100%;
    overflow: hidden;
  }
}

/* src/styles/page-transitions.css */
@media (max-width: 767px) {
  .sd-screen > router-outlet + * {
    view-transition-name: sd-page;
  }
  .sd-screen .sd-bottomnav {
    view-transition-name: sd-bottomnav;
  }
}
::view-transition-group(sd-bottomnav) {
  animation: none;
}
::view-transition-group(sd-page) {
  animation-duration: 320ms;
}
::view-transition-old(sd-page),
::view-transition-new(sd-page) {
  animation-duration: 320ms;
  animation-timing-function: cubic-bezier(0.2, 0, 0, 1);
  mix-blend-mode: normal;
}
::view-transition-old(sd-page) {
  animation-name: sd-vt-fade-out;
}
::view-transition-new(sd-page) {
  animation-name: sd-vt-fade-in;
}
html[data-vt=forward]::view-transition-old(sd-page) {
  animation-name: sd-vt-exit-left;
}
html[data-vt=forward]::view-transition-new(sd-page) {
  animation-name: sd-vt-enter-right;
}
html[data-vt=back]::view-transition-old(sd-page) {
  animation-name: sd-vt-exit-right;
}
html[data-vt=back]::view-transition-new(sd-page) {
  animation-name: sd-vt-enter-left;
}
@keyframes sd-vt-enter-right {
  from {
    opacity: 0;
    transform: translateX(28px);
  }
  to {
    opacity: 1;
    transform: translateX(0);
  }
}
@keyframes sd-vt-exit-left {
  from {
    opacity: 1;
    transform: translateX(0);
  }
  to {
    opacity: 0;
    transform: translateX(-22px);
  }
}
@keyframes sd-vt-enter-left {
  from {
    opacity: 0;
    transform: translateX(-28px);
  }
  to {
    opacity: 1;
    transform: translateX(0);
  }
}
@keyframes sd-vt-exit-right {
  from {
    opacity: 1;
    transform: translateX(0);
  }
  to {
    opacity: 0;
    transform: translateX(22px);
  }
}
@keyframes sd-vt-fade-in {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}
@keyframes sd-vt-fade-out {
  from {
    opacity: 1;
  }
  to {
    opacity: 0;
  }
}
@media (prefers-reduced-motion: reduce) {
  ::view-transition-group(*),
  ::view-transition-old(*),
  ::view-transition-new(*) {
    animation-duration: 1ms !important;
    animation-delay: 0ms !important;
  }
}

/* src/styles.css */

/* angular:styles/global:styles */
/*# sourceMappingURL=styles.css.map */
