/* 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% .013 17.38); --color-red-100: oklch(93.6% .032 17.717); --color-red-200: oklch(88.5% .062 18.334); --color-red-300: oklch(80.8% .114 19.571); --color-red-400: oklch(70.4% .191 22.216); --color-red-500: oklch(63.7% .237 25.331); --color-red-600: oklch(57.7% .245 27.325); --color-red-700: oklch(50.5% .213 27.518); --color-red-800: oklch(44.4% .177 26.899); --color-red-900: oklch(39.6% .141 25.723); --color-red-950: oklch(25.8% .092 26.042); --color-orange-50: oklch(98% .016 73.684); --color-orange-100: oklch(95.4% .038 75.164); --color-orange-200: oklch(90.1% .076 70.697); --color-orange-300: oklch(83.7% .128 66.29); --color-orange-400: oklch(75% .183 55.934); --color-orange-500: oklch(70.5% .213 47.604); --color-orange-600: oklch(64.6% .222 41.116); --color-orange-700: oklch(55.3% .195 38.402); --color-orange-800: oklch(47% .157 37.304); --color-orange-900: oklch(40.8% .123 38.172); --color-orange-950: oklch(26.6% .079 36.259); --color-amber-50: oklch(98.7% .022 95.277); --color-amber-100: oklch(96.2% .059 95.617); --color-amber-200: oklch(92.4% .12 95.746); --color-amber-300: oklch(87.9% .169 91.605); --color-amber-400: oklch(82.8% .189 84.429); --color-amber-500: oklch(76.9% .188 70.08); --color-amber-600: oklch(66.6% .179 58.318); --color-amber-700: oklch(55.5% .163 48.998); --color-amber-800: oklch(47.3% .137 46.201); --color-amber-900: oklch(41.4% .112 45.904); --color-amber-950: oklch(27.9% .077 45.635); --color-yellow-50: oklch(98.7% .026 102.212); --color-yellow-100: oklch(97.3% .071 103.193); --color-yellow-200: oklch(94.5% .129 101.54); --color-yellow-300: oklch(90.5% .182 98.111); --color-yellow-400: oklch(85.2% .199 91.936); --color-yellow-500: oklch(79.5% .184 86.047); --color-yellow-600: oklch(68.1% .162 75.834); --color-yellow-700: oklch(55.4% .135 66.442); --color-yellow-800: oklch(47.6% .114 61.907); --color-yellow-900: oklch(42.1% .095 57.708); --color-yellow-950: oklch(28.6% .066 53.813); --color-lime-50: oklch(98.6% .031 120.757); --color-lime-100: oklch(96.7% .067 122.328); --color-lime-200: oklch(93.8% .127 124.321); --color-lime-300: oklch(89.7% .196 126.665); --color-lime-400: oklch(84.1% .238 128.85); --color-lime-500: oklch(76.8% .233 130.85); --color-lime-600: oklch(64.8% .2 131.684); --color-lime-700: oklch(53.2% .157 131.589); --color-lime-800: oklch(45.3% .124 130.933); --color-lime-900: oklch(40.5% .101 131.063); --color-lime-950: oklch(27.4% .072 132.109); --color-green-50: oklch(98.2% .018 155.826); --color-green-100: oklch(96.2% .044 156.743); --color-green-200: oklch(92.5% .084 155.995); --color-green-300: oklch(87.1% .15 154.449); --color-green-400: oklch(79.2% .209 151.711); --color-green-500: oklch(72.3% .219 149.579); --color-green-600: oklch(62.7% .194 149.214); --color-green-700: oklch(52.7% .154 150.069); --color-green-800: oklch(44.8% .119 151.328); --color-green-900: oklch(39.3% .095 152.535); --color-green-950: oklch(26.6% .065 152.934); --color-emerald-50: oklch(97.9% .021 166.113); --color-emerald-100: oklch(95% .052 163.051); --color-emerald-200: oklch(90.5% .093 164.15); --color-emerald-300: oklch(84.5% .143 164.978); --color-emerald-400: oklch(76.5% .177 163.223); --color-emerald-500: oklch(69.6% .17 162.48); --color-emerald-600: oklch(59.6% .145 163.225); --color-emerald-700: oklch(50.8% .118 165.612); --color-emerald-800: oklch(43.2% .095 166.913); --color-emerald-900: oklch(37.8% .077 168.94); --color-emerald-950: oklch(26.2% .051 172.552); --color-teal-50: oklch(98.4% .014 180.72); --color-teal-100: oklch(95.3% .051 180.801); --color-teal-200: oklch(91% .096 180.426); --color-teal-300: oklch(85.5% .138 181.071); --color-teal-400: oklch(77.7% .152 181.912); --color-teal-500: oklch(70.4% .14 182.503); --color-teal-600: oklch(60% .118 184.704); --color-teal-700: oklch(51.1% .096 186.391); --color-teal-800: oklch(43.7% .078 188.216); --color-teal-900: oklch(38.6% .063 188.416); --color-teal-950: oklch(27.7% .046 192.524); --color-cyan-50: oklch(98.4% .019 200.873); --color-cyan-100: oklch(95.6% .045 203.388); --color-cyan-200: oklch(91.7% .08 205.041); --color-cyan-300: oklch(86.5% .127 207.078); --color-cyan-400: oklch(78.9% .154 211.53); --color-cyan-500: oklch(71.5% .143 215.221); --color-cyan-600: oklch(60.9% .126 221.723); --color-cyan-700: oklch(52% .105 223.128); --color-cyan-800: oklch(45% .085 224.283); --color-cyan-900: oklch(39.8% .07 227.392); --color-cyan-950: oklch(30.2% .056 229.695); --color-sky-50: oklch(97.7% .013 236.62); --color-sky-100: oklch(95.1% .026 236.824); --color-sky-200: oklch(90.1% .058 230.902); --color-sky-300: oklch(82.8% .111 230.318); --color-sky-400: oklch(74.6% .16 232.661); --color-sky-500: oklch(68.5% .169 237.323); --color-sky-600: oklch(58.8% .158 241.966); --color-sky-700: oklch(50% .134 242.749); --color-sky-800: oklch(44.3% .11 240.79); --color-sky-900: oklch(39.1% .09 240.876); --color-sky-950: oklch(29.3% .066 243.157); --color-blue-50: oklch(97% .014 254.604); --color-blue-100: oklch(93.2% .032 255.585); --color-blue-200: oklch(88.2% .059 254.128); --color-blue-300: oklch(80.9% .105 251.813); --color-blue-400: oklch(70.7% .165 254.624); --color-blue-500: oklch(62.3% .214 259.815); --color-blue-600: oklch(54.6% .245 262.881); --color-blue-700: oklch(48.8% .243 264.376); --color-blue-800: oklch(42.4% .199 265.638); --color-blue-900: oklch(37.9% .146 265.522); --color-blue-950: oklch(28.2% .091 267.935); --color-indigo-50: oklch(96.2% .018 272.314); --color-indigo-100: oklch(93% .034 272.788); --color-indigo-200: oklch(87% .065 274.039); --color-indigo-300: oklch(78.5% .115 274.713); --color-indigo-400: oklch(67.3% .182 276.935); --color-indigo-500: oklch(58.5% .233 277.117); --color-indigo-600: oklch(51.1% .262 276.966); --color-indigo-700: oklch(45.7% .24 277.023); --color-indigo-800: oklch(39.8% .195 277.366); --color-indigo-900: oklch(35.9% .144 278.697); --color-indigo-950: oklch(25.7% .09 281.288); --color-violet-50: oklch(96.9% .016 293.756); --color-violet-100: oklch(94.3% .029 294.588); --color-violet-200: oklch(89.4% .057 293.283); --color-violet-300: oklch(81.1% .111 293.571); --color-violet-400: oklch(70.2% .183 293.541); --color-violet-500: oklch(60.6% .25 292.717); --color-violet-600: oklch(54.1% .281 293.009); --color-violet-700: oklch(49.1% .27 292.581); --color-violet-800: oklch(43.2% .232 292.759); --color-violet-900: oklch(38% .189 293.745); --color-violet-950: oklch(28.3% .141 291.089); --color-purple-50: oklch(97.7% .014 308.299); --color-purple-100: oklch(94.6% .033 307.174); --color-purple-200: oklch(90.2% .063 306.703); --color-purple-300: oklch(82.7% .119 306.383); --color-purple-400: oklch(71.4% .203 305.504); --color-purple-500: oklch(62.7% .265 303.9); --color-purple-600: oklch(55.8% .288 302.321); --color-purple-700: oklch(49.6% .265 301.924); --color-purple-800: oklch(43.8% .218 303.724); --color-purple-900: oklch(38.1% .176 304.987); --color-purple-950: oklch(29.1% .149 302.717); --color-fuchsia-50: oklch(97.7% .017 320.058); --color-fuchsia-100: oklch(95.2% .037 318.852); --color-fuchsia-200: oklch(90.3% .076 319.62); --color-fuchsia-300: oklch(83.3% .145 321.434); --color-fuchsia-400: oklch(74% .238 322.16); --color-fuchsia-500: oklch(66.7% .295 322.15); --color-fuchsia-600: oklch(59.1% .293 322.896); --color-fuchsia-700: oklch(51.8% .253 323.949); --color-fuchsia-800: oklch(45.2% .211 324.591); --color-fuchsia-900: oklch(40.1% .17 325.612); --color-fuchsia-950: oklch(29.3% .136 325.661); --color-pink-50: oklch(97.1% .014 343.198); --color-pink-100: oklch(94.8% .028 342.258); --color-pink-200: oklch(89.9% .061 343.231); --color-pink-300: oklch(82.3% .12 346.018); --color-pink-400: oklch(71.8% .202 349.761); --color-pink-500: oklch(65.6% .241 354.308); --color-pink-600: oklch(59.2% .249 .584); --color-pink-700: oklch(52.5% .223 3.958); --color-pink-800: oklch(45.9% .187 3.815); --color-pink-900: oklch(40.8% .153 2.432); --color-pink-950: oklch(28.4% .109 3.907); --color-rose-50: oklch(96.9% .015 12.422); --color-rose-100: oklch(94.1% .03 12.58); --color-rose-200: oklch(89.2% .058 10.001); --color-rose-300: oklch(81% .117 11.638); --color-rose-400: oklch(71.2% .194 13.428); --color-rose-500: oklch(64.5% .246 16.439); --color-rose-600: oklch(58.6% .253 17.585); --color-rose-700: oklch(51.4% .222 16.935); --color-rose-800: oklch(45.5% .188 13.697); --color-rose-900: oklch(41% .159 10.272); --color-rose-950: oklch(27.1% .105 12.094); --color-slate-50: oklch(98.4% .003 247.858); --color-slate-100: oklch(96.8% .007 247.896); --color-slate-200: oklch(92.9% .013 255.508); --color-slate-300: oklch(86.9% .022 252.894); --color-slate-400: oklch(70.4% .04 256.788); --color-slate-500: oklch(55.4% .046 257.417); --color-slate-600: oklch(44.6% .043 257.281); --color-slate-700: oklch(37.2% .044 257.287); --color-slate-800: oklch(27.9% .041 260.031); --color-slate-900: oklch(20.8% .042 265.755); --color-slate-950: oklch(12.9% .042 264.695); --color-gray-50: oklch(98.5% .002 247.839); --color-gray-100: oklch(96.7% .003 264.542); --color-gray-200: oklch(92.8% .006 264.531); --color-gray-300: oklch(87.2% .01 258.338); --color-gray-400: oklch(70.7% .022 261.325); --color-gray-500: oklch(55.1% .027 264.364); --color-gray-600: oklch(44.6% .03 256.802); --color-gray-700: oklch(37.3% .034 259.733); --color-gray-800: oklch(27.8% .033 256.848); --color-gray-900: oklch(21% .034 264.665); --color-gray-950: oklch(13% .028 261.692); --color-zinc-50: oklch(98.5% 0 0); --color-zinc-100: oklch(96.7% .001 286.375); --color-zinc-200: oklch(92% .004 286.32); --color-zinc-300: oklch(87.1% .006 286.286); --color-zinc-400: oklch(70.5% .015 286.067); --color-zinc-500: oklch(55.2% .016 285.938); --color-zinc-600: oklch(44.2% .017 285.786); --color-zinc-700: oklch(37% .013 285.805); --color-zinc-800: oklch(27.4% .006 286.033); --color-zinc-900: oklch(21% .006 285.885); --color-zinc-950: oklch(14.1% .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% .001 106.423); --color-stone-100: oklch(97% .001 106.424); --color-stone-200: oklch(92.3% .003 48.717); --color-stone-300: oklch(86.9% .005 56.366); --color-stone-400: oklch(70.9% .01 56.259); --color-stone-500: oklch(55.3% .013 58.071); --color-stone-600: oklch(44.4% .011 73.639); --color-stone-700: oklch(37.4% .01 67.558); --color-stone-800: oklch(26.8% .007 34.298); --color-stone-900: oklch(21.6% .006 56.043); --color-stone-950: oklch(14.7% .004 49.25); --color-mauve-50: oklch(98.5% 0 0); --color-mauve-100: oklch(96% .003 325.6); --color-mauve-200: oklch(92.2% .005 325.62); --color-mauve-300: oklch(86.5% .012 325.68); --color-mauve-400: oklch(71.1% .019 323.02); --color-mauve-500: oklch(54.2% .034 322.5); --color-mauve-600: oklch(43.5% .029 321.78); --color-mauve-700: oklch(36.4% .029 323.89); --color-mauve-800: oklch(26.3% .024 320.12); --color-mauve-900: oklch(21.2% .019 322.12); --color-mauve-950: oklch(14.5% .008 326); --color-olive-50: oklch(98.8% .003 106.5); --color-olive-100: oklch(96.6% .005 106.5); --color-olive-200: oklch(93% .007 106.5); --color-olive-300: oklch(88% .011 106.6); --color-olive-400: oklch(73.7% .021 106.9); --color-olive-500: oklch(58% .031 107.3); --color-olive-600: oklch(46.6% .025 107.3); --color-olive-700: oklch(39.4% .023 107.4); --color-olive-800: oklch(28.6% .016 107.4); --color-olive-900: oklch(22.8% .013 107.4); --color-olive-950: oklch(15.3% .006 107.1); --color-mist-50: oklch(98.7% .002 197.1); --color-mist-100: oklch(96.3% .002 197.1); --color-mist-200: oklch(92.5% .005 214.3); --color-mist-300: oklch(87.2% .007 219.6); --color-mist-400: oklch(72.3% .014 214.4); --color-mist-500: oklch(56% .021 213.5); --color-mist-600: oklch(45% .017 213.2); --color-mist-700: oklch(37.8% .015 216); --color-mist-800: oklch(27.5% .011 216.9); --color-mist-900: oklch(21.8% .008 223.9); --color-mist-950: oklch(14.8% .004 228.8); --color-taupe-50: oklch(98.6% .002 67.8); --color-taupe-100: oklch(96% .002 17.2); --color-taupe-200: oklch(92.2% .005 34.3); --color-taupe-300: oklch(86.8% .007 39.5); --color-taupe-400: oklch(71.4% .014 41.2); --color-taupe-500: oklch(54.7% .021 43.1); --color-taupe-600: oklch(43.8% .017 39.3); --color-taupe-700: oklch(36.7% .016 35.7); --color-taupe-800: oklch(26.8% .011 36.5); --color-taupe-900: oklch(21.4% .009 43.1); --color-taupe-950: oklch(14.7% .004 49.3); --color-black: #000; --color-white: #fff; --spacing: .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: .75rem; --text-xs--line-height: calc(1 / .75) ; --text-sm: .875rem; --text-sm--line-height: calc(1.25 / .875) ; --text-base: 1rem; --text-base--line-height: calc(1.5 / 1) ; --text-lg: 1.125rem; --text-lg--line-height: calc(1.75 / 1.125) ; --text-xl: 1.25rem; --text-xl--line-height: calc(1.75 / 1.25) ; --text-2xl: 1.5rem; --text-2xl--line-height: calc(2 / 1.5) ; --text-3xl: 1.875rem; --text-3xl--line-height: calc(2.25 / 1.875) ; --text-4xl: 2.25rem; --text-4xl--line-height: calc(2.5 / 2.25) ; --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: -.05em; --tracking-tight: -.025em; --tracking-normal: 0em; --tracking-wide: .025em; --tracking-wider: .05em; --tracking-widest: .1em; --leading-tight: 1.25; --leading-snug: 1.375; --leading-normal: 1.5; --leading-relaxed: 1.625; --leading-loose: 2; --radius-xs: .125rem; --radius-sm: .25rem; --radius-md: .375rem; --radius-lg: .5rem; --radius-xl: .75rem; --radius-2xl: 1rem; --radius-3xl: 1.5rem; --radius-4xl: 2rem; --shadow-2xs: 0 1px #0000000d; --shadow-xs: 0 1px 2px 0 #0000000d; --shadow-sm: 0 1px 3px 0 #0000001a, 0 1px 2px -1px #0000001a; --shadow-md: 0 4px 6px -1px #0000001a, 0 2px 4px -2px #0000001a; --shadow-lg: 0 10px 15px -3px #0000001a, 0 4px 6px -4px #0000001a; --shadow-xl: 0 20px 25px -5px #0000001a, 0 8px 10px -6px #0000001a; --shadow-2xl: 0 25px 50px -12px #00000040; --inset-shadow-2xs: inset 0 1px #0000000d; --inset-shadow-xs: inset 0 1px 1px #0000000d; --inset-shadow-sm: inset 0 2px 4px #0000000d; --drop-shadow-xs: 0 1px 1px #0000000d; --drop-shadow-sm: 0 1px 2px #00000026; --drop-shadow-md: 0 3px 3px #0000001f; --drop-shadow-lg: 0 4px 4px #00000026; --drop-shadow-xl: 0 9px 7px #0000001a; --drop-shadow-2xl: 0 25px 25px #00000026; --text-shadow-2xs: 0px 1px 0px #00000026; --text-shadow-xs: 0px 1px 1px #0003; --text-shadow-sm: 0px 1px 0px #00000013, 0px 1px 1px #00000013, 0px 2px 2px #00000013; --text-shadow-md: 0px 1px 1px #0000001a, 0px 1px 2px #0000001a, 0px 2px 4px #0000001a; --text-shadow-lg: 0px 1px 2px #0000001a, 0px 3px 2px #0000001a, 0px 4px 8px #0000001a; --ease-in: cubic-bezier(.4, 0, 1, 1) ; --ease-out: cubic-bezier(0, 0, .2, 1) ; --ease-in-out: cubic-bezier(.4, 0, .2, 1) ; --animate-spin: spin 1s linear infinite; --animate-ping: ping 1s cubic-bezier(0, 0, .2, 1) infinite; --animate-pulse: pulse 2s cubic-bezier(.4, 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: .5; } } @keyframes bounce { 0%, 100% { transform: translateY(-25%) ; animation-timing-function: cubic-bezier(.8, 0, 1, 1) ; } 50% { transform: none; animation-timing-function: cubic-bezier(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: .15s; --default-transition-timing-function: cubic-bezier(.4, 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 #0000001a, 0 1px 2px -1px #0000001a; --shadow-inner: inset 0 2px 4px 0 #0000000d; --drop-shadow: 0 1px 2px #0000001a, 0 1px 1px #0000000f; --radius: .25rem; --max-width-prose: 65ch;
  }
}

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

  ::backdrop {
    box-sizing: border-box;
    border: 0 solid;
    margin: 0;
    padding: 0;
  }

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

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

  html, :host {
    -webkit-text-size-adjust: 100%;
    tab-size: 4;
    line-height: 1.5;
    font-family: --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 {
    color: inherit;
    border-top-width: 1px;
    height: 0;
  }

  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 {
    position: relative;
    vertical-align: baseline;
    font-size: 75%;
    line-height: 0;
  }

  sub {
    bottom: -.25em;
  }

  sup {
    top: -.5em;
  }

  table {
    text-indent: 0;
    border-color: inherit;
    border-collapse: collapse;
  }

  :-moz-focusring {
    outline: auto;
  }

  progress {
    vertical-align: baseline;
  }

  summary {
    display: list-item;
  }

  ol, ul, menu {
    list-style: none;
  }

  img, svg, video, canvas, audio, iframe, embed, object {
    display: block;
    vertical-align: middle;
  }

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

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

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

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

  :where(select:-webkit-any([multiple], [size])) optgroup {
    font-weight: bolder;
  }

  :where(select:-moz-any([multiple], [size])) optgroup {
    font-weight: bolder;
  }

  :where(select:is([multiple], [size])) optgroup {
    font-weight: bolder;
  }

  :where(select:-webkit-any([multiple], [size])) optgroup option {
    padding-inline-start: 20px;
  }

  :where(select:-moz-any([multiple], [size])) optgroup option {
    padding-inline-start: 20px;
  }

  :where(select:is([multiple], [size])) optgroup option {
    padding-inline-start: 20px;
  }

  ::-webkit-file-upload-button {
    margin-inline-end: 4px;
  }

  ::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 {
    text-align: inherit;
    min-height: 1lh;
  }

  ::-webkit-datetime-edit {
    display: inline-flex;
  }

  ::-webkit-datetime-edit-fields-wrapper {
    padding: 0;
  }

  ::-webkit-datetime-edit {
    padding-block-start: 0;
    padding-block-end: 0;
  }

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

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

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

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

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

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

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

  ::-webkit-datetime-edit-meridiem-field {
    padding-block-start: 0;
    padding-block-end: 0;
  }

  ::-webkit-calendar-picker-indicator {
    line-height: 1;
  }

  :-moz-ui-invalid {
    box-shadow: none;
  }

  button {
    appearance: button;
  }

  input:where([type="button"], [type="reset"], [type="submit"]) {
    appearance: button;
  }

  ::-webkit-file-upload-button {
    appearance: button;
  }

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

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

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

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

@layer utilities {
  @tailwind utilities;
}

/* ui/src/styles/tokens.css */
:root {
  --paper: #f5f2eb;
  --paper-2: #eee9dc;
  --paper-3: #e3dcc8;
  --rule: #cbc3b2;
  --rule-soft: #dfd9cc;
  --rule-bold: #1a1a1a;
  --ink: #1a1a1a;
  --ink-2: #4a4a46;
  --ink-3: #6a6760;
  --accent: #c23a2a;
  --accent-ink: #fff;
  --ok: #2e5e3a;
  --warn: #8a6a1f;
  --font-sans: "Inter Tight", "Helvetica Neue", system-ui, sans-serif;
  --font-mono: "JetBrains Mono", ui-monospace, "SF Mono", monospace;
  --font-display: "Fraunces", "Inter Tight", serif;
  --text-xs: 11px;
  --text-sm: 13px;
  --text-md: 15px;
  --text-lg: 18px;
  --text-xl: 24px;
  --text-2xl: 34px;
  --text-3xl: 48px;
  --lh-tight: 1.15;
  --lh-body: 1.45;
  --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;
  --r-0: 0;
  --r-1: 2px;
  --r-2: 4px;
  --r-pill: 999px;
  --hair: 1px solid var(--rule);
  --hair-soft: 1px solid var(--rule-soft);
  --hair-2: 2px solid var(--rule);
  --ease-out: cubic-bezier(.2, .7, .2, 1);
  --dur-fast: .12s;
  --dur-med: .22s;
  --dur-slow: .36s;
  --z-rail: 10;
  --z-palette: 50;
  --z-room: 60;
  --z-toast: 70;
  --v2-rail-width: 260px;
  --v2-header-height: 52px;
}

/* ui/src/styles/globals.css */
:root {
  --j-bg: #07070a;
  --j-surface: #0c0c12;
  --j-surface-hover: #1a1a22;
  --j-border: #ffffff0a;
  --j-border-bright: #ffffff12;
  --j-accent: #8b5cf6;
  --j-accent-dim: #6d28d9;
  --j-accent2: #a78bfa;
  --j-success: #34d399;
  --j-warning: #fbbf24;
  --j-error: #fb7185;
  --j-text: #ffffffe0;
  --j-text-dim: #ffffff7a;
  --j-text-muted: #ffffff40;
  --j-glow: 0 0 20px #8b5cf626;
  --j-glow-strong: 0 0 30px #8b5cf64d;
}

* {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

body {
  background: var(--j-bg);
  color: var(--j-text);
  overflow: hidden;
  min-height: 100vh;
  font-family: Inter, SF Pro Display, -apple-system, BlinkMacSystemFont, system-ui, Segoe UI, Roboto, Noto Sans, Ubuntu, Cantarell, Helvetica Neue, sans-serif;
}

#root {
  width: 100vw;
  height: 100vh;
}

::-webkit-scrollbar {
  width: 6px;
  height: 6px;
}

::-webkit-scrollbar-track {
  background: none;
}

::-webkit-scrollbar-thumb {
  background: var(--j-border-bright);
  border-radius: 3px;
}

::-webkit-scrollbar-thumb:hover {
  background: var(--j-text-muted);
}

::selection {
  color: #fff;
  background: #8b5cf64d;
}

.markdown-content {
  word-break: break-word;
  line-height: 1.6;
}

.markdown-content > :first-child {
  margin-top: 0;
}

.markdown-content > :last-child {
  margin-bottom: 0;
}

.markdown-content h1, .markdown-content h2, .markdown-content h3, .markdown-content h4, .markdown-content h5, .markdown-content h6 {
  color: var(--j-text);
  margin: 16px 0 8px;
  font-weight: 600;
  line-height: 1.3;
}

.markdown-content h1 {
  border-bottom: 1px solid var(--j-border);
  padding-bottom: 4px;
  font-size: 1.4em;
}

.markdown-content h2 {
  font-size: 1.25em;
}

.markdown-content h3 {
  font-size: 1.1em;
}

.markdown-content h4 {
  color: var(--j-text-dim);
  font-size: 1em;
}

.markdown-content p {
  margin: 6px 0;
}

.markdown-content ul, .markdown-content ol {
  margin: 6px 0;
  padding-left: 20px;
}

.markdown-content li, .markdown-content li > p {
  margin: 2px 0;
}

.markdown-content li::marker {
  color: var(--j-text-muted);
}

.markdown-content li:has( > input[type="checkbox"]) {
  list-style: none;
  margin-left: -20px;
}

.markdown-content strong {
  color: var(--j-text);
  font-weight: 600;
}

.markdown-content em {
  color: var(--j-text-dim);
  font-style: italic;
}

.markdown-content del {
  color: var(--j-text-muted);
  text-decoration: line-through;
}

.markdown-content a:hover {
  border-bottom-color: var(--j-accent) !important;
}

.hljs {
  color: var(--j-text);
}

.hljs-keyword, .hljs-selector-tag, .hljs-built_in, .hljs-name {
  color: #c792ea;
}

.hljs-string, .hljs-attr, .hljs-template-tag, .hljs-template-variable {
  color: #c3e88d;
}

.hljs-comment, .hljs-quote {
  color: #546e7a;
  font-style: italic;
}

.hljs-number, .hljs-literal, .hljs-boolean {
  color: #f78c6c;
}

.hljs-function, .hljs-title {
  color: #82aaff;
}

.hljs-type, .hljs-class .hljs-title {
  color: #ffcb6b;
}

.hljs-variable, .hljs-params {
  color: var(--j-text);
}

.hljs-regexp {
  color: #89ddff;
}

.hljs-symbol, .hljs-bullet {
  color: #f07178;
}

.hljs-meta {
  color: #89ddff;
}

.hljs-addition {
  color: #c3e88d;
  background: #c3e88d14;
}

.hljs-deletion {
  color: #f07178;
  background: #f0717814;
}

.hljs-emphasis {
  font-style: italic;
}

.hljs-strong {
  font-weight: bold;
}

@keyframes taskPulse {
  0% {
    box-shadow: 0 0 #00d4ff66;
  }

  50% {
    box-shadow: 0 0 16px 4px #00d4ff26;
  }

  100% {
    box-shadow: 0 0 #00d4ff00;
  }
}

/* ui/src/v2/shell/Composer.css */
.v2-composer {
  display: flex;
  align-items:  center;
  gap: var(--s-3);
  background: var(--paper);
  border-top: var(--hair);
  padding: 16px 28px 22px;
}

.v2-composer__wrap {
  display: flex;
  align-items:  center;
  gap: var(--s-3);
  background: var(--paper-2);
  border: 1px solid var(--rule);
  transition: background var(--dur-fast) var(--ease-out), border-color var(--dur-fast) var(--ease-out), box-shadow var(--dur-fast) var(--ease-out);
  border-radius: 14px;
  flex: 1;
  width: 100%;
  max-width: 720px;
  margin: 0 auto;
  padding: 10px 14px;
  box-shadow: 0 1px 3px #2c282208;
}

.v2-composer__wrap:focus-within {
  background: var(--paper);
  border-color: var(--ink);
  box-shadow: 0 1px 4px #2c28220f;
}

.v2-composer__input {
  outline: none;
  font-family: var(--font-display);
  font-size: var(--text-md);
  color: var(--ink);
  background: none;
  border: 0;
  flex: 1;
  min-width: 0;
  padding: 4px 0;
  line-height: 1.4;
}

.v2-composer__input::placeholder {
  color: var(--ink-3);
  font-style: italic;
}

.v2-composer__slash {
  font-family: var(--font-mono);
  color: var(--ink-3);
  background: var(--paper-3);
  border-radius: var(--r-2);
  cursor: pointer;
  letter-spacing: .04em;
  transition: background var(--dur-fast) var(--ease-out);
  border: 0;
  flex-shrink: 0;
  padding: 4px 9px;
  font-size: 11px;
  line-height: 1.2;
}

.v2-composer__slash:hover {
  background: var(--rule-soft);
}

.v2-composer__slash:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 2px;
}

.v2-composer__send {
  background: var(--accent);
  color: var(--accent-ink);
  display: inline-flex;
  cursor: pointer;
  transition: background var(--dur-fast) var(--ease-out), transform var(--dur-fast) var(--ease-out);
  border: 0;
  border-radius: 14px;
  flex-shrink: 0;
  justify-content: center;
  align-items:  center;
  width: 28px;
  height: 28px;
}

.v2-composer__send:hover:not(:disabled) {
  background: #a62f22;
}

.v2-composer__send:active:not(:disabled) {
  transform: scale(.92);
}

.v2-composer__send:disabled {
  opacity: .35;
  cursor: not-allowed;
}

.v2-composer__send:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 2px;
}

/* ui/src/v2/shell/Header.css */
.v2-header {
  display: flex;
  justify-content: space-between;
  align-items:  center;
  gap: var(--s-5);
  padding: var(--s-3) var(--s-6);
  background: var(--paper);
  min-height: 52px;
}

.v2-header__left {
  display: flex;
  align-items:  center;
  gap: var(--s-3);
  min-width: 0;
}

.v2-header__connection {
  display: inline-flex;
  align-items:  center;
  gap: var(--s-2);
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--ink-3);
}

.v2-header__conn-dot {
  border-radius: var(--r-pill);
  width: 6px;
  height: 6px;
}

.v2-header__conn-dot--live {
  background: var(--ok);
}

.v2-header__conn-dot--degraded {
  background: var(--warn);
}

.v2-header__conn-dot--offline {
  background: var(--ink-3);
}

.v2-header__right {
  display: flex;
  align-items:  center;
  gap: var(--s-2);
}

.v2-header__palette {
  display: inline-flex;
  align-items:  center;
  gap: var(--s-3);
  background: var(--paper-2);
  border: 1px solid var(--rule);
  border-radius: var(--r-pill);
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  color: var(--ink-3);
  cursor: pointer;
  transition: background var(--dur-fast) var(--ease-out);
  min-width: 180px;
  padding: 6px 10px 6px 12px;
}

.v2-header__palette:hover {
  background: var(--paper-3);
}

.v2-header__palette:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 2px;
}

.v2-header__palette-icon {
  color: var(--ink-3);
  display: inline-flex;
}

.v2-header__palette-label {
  text-align: left;
  flex: 1;
}

.v2-header__iconbtn {
  display: inline-flex;
  color: var(--ink-2);
  cursor: pointer;
  border-radius: var(--r-pill);
  position: relative;
  transition: background var(--dur-fast) var(--ease-out);
  background: none;
  border: 0;
  justify-content: center;
  align-items:  center;
  width: 32px;
  height: 32px;
}

.v2-header__iconbtn:hover {
  background: var(--paper-3);
}

.v2-header__iconbtn:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 2px;
}

.v2-header__iconbtn[data-active="true"] {
  background: var(--paper-3);
  color: var(--ink);
}

.v2-header__notif-dot {
  position: absolute;
  border-radius: var(--r-pill);
  background: var(--accent);
  width: 6px;
  height: 6px;
  top: 6px;
  right: 6px;
}

.v2-header__notif-anchor {
  position: relative;
  display: inline-flex;
}

.v2-header__notif-badge {
  position: absolute;
  border-radius: var(--r-pill);
  background: var(--accent);
  color: var(--accent-ink);
  font-family: var(--font-mono);
  text-align: center;
  pointer-events: none;
  letter-spacing: 0;
  box-shadow: 0 0 0 2px var(--paper);
  min-width: 16px;
  height: 16px;
  padding: 0 4px;
  font-size: 10px;
  font-weight: 600;
  line-height: 16px;
  top: -2px;
  right: -2px;
}

.v2-header__legacy {
  margin-left: var(--s-3);
  padding-left: var(--s-3);
  border-left: var(--hair);
}

/* ui/src/v2/thread/ApprovalCard.css */
.v2-approval {
  position: relative;
  background: var(--paper);
  border: 1.5px solid var(--accent);
  display: flex;
  gap: var(--s-3);
  border-radius: 10px;
  flex-direction: column;
  padding: 14px 16px;
  box-shadow: 4px 4px #c23a2a14;
}

.v2-approval__attribution {
  display: flex;
  align-items:  center;
  gap: var(--s-2);
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--accent);
  font-weight: 700;
}

.v2-approval__attribution-dot {
  background: var(--accent);
  border-radius: 2px;
  flex-shrink: 0;
  width: 4px;
  height: 4px;
}

.v2-approval__attribution-tag {
  color: var(--ink-3);
  font-weight: 400;
}

.v2-approval__impact {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--accent);
  border: 1px solid var(--accent);
  border-radius: var(--r-pill);
  margin-left: auto;
  padding: 2px 8px;
  line-height: 1.3;
}

.v2-approval__impact--read {
  color: var(--ok);
  border-color: var(--ok);
}

.v2-approval__impact--external {
  color: var(--ink);
  border-color: var(--rule);
}

.v2-approval__intent {
  font-family: var(--font-display);
  color: var(--ink);
  margin: 0;
  font-size: 16px;
  font-weight: 400;
  line-height: 1.45;
}

.v2-approval__intent mark {
  color: var(--accent);
  background: none;
  font-weight: 500;
}

.v2-approval__category {
  font-family: var(--font-mono);
  color: var(--ink-3);
  letter-spacing: .1em;
  font-size: 10.5px;
}

.v2-approval__actions {
  display: flex;
  align-items:  center;
  gap: var(--s-2);
  flex-wrap: wrap;
}

.v2-approval__voice-hint {
  display: inline-flex;
  font-family: var(--font-mono);
  letter-spacing: .08em;
  color: var(--ink-3);
  align-items:  center;
  gap: 4px;
  margin-left: auto;
  font-size: 10.5px;
}

.v2-approval__voice-hint-text {
  letter-spacing: .08em;
}

/* ui/src/v2/thread/ClarifierCard.css */
.v2-clarifier {
  position: relative;
  background: var(--paper);
  border: 1.5px solid var(--warn);
  display: flex;
  gap: var(--s-3);
  border-left-width: 4px;
  border-radius: 10px;
  flex-direction: column;
  padding: 14px 16px;
  box-shadow: 4px 4px #8a6a1f14;
}

.v2-clarifier__attribution {
  display: flex;
  align-items:  center;
  gap: var(--s-2);
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--warn);
  font-weight: 700;
}

.v2-clarifier__attribution-dot {
  background: var(--warn);
  border-radius: 2px;
  flex-shrink: 0;
  width: 4px;
  height: 4px;
}

.v2-clarifier__attribution-tag {
  color: var(--ink-3);
  font-weight: 400;
}

.v2-clarifier__transcript {
  display: inline-flex;
  align-items:  center;
  gap: var(--s-2);
  font-family: var(--font-display);
  font-style: italic;
  font-size: var(--text-sm);
  color: var(--ink-2);
  line-height: 1.4;
}

.v2-clarifier__primary {
  font-family: var(--font-display);
  color: var(--ink);
  margin: 0;
  font-size: 16px;
  font-weight: 400;
  line-height: 1.45;
}

.v2-clarifier__primary em {
  color: var(--accent);
  font-style: normal;
  font-weight: 500;
}

.v2-clarifier__alts {
  list-style: none;
  display: flex;
  gap: var(--s-1);
  border-top: var(--hair-soft);
  padding: 0;
  padding-top: var(--s-3);
  flex-direction: column;
  margin: 0;
}

.v2-clarifier__alt {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: var(--s-3);
}

.v2-clarifier__alt-label {
  font-family: var(--font-display);
  font-size: var(--text-sm);
  color: var(--ink-2);
}

.v2-clarifier__alt-meta {
  font-family: var(--font-mono);
  color: var(--ink-3);
  letter-spacing: .08em;
  text-transform: uppercase;
  font-size: 10.5px;
}

.v2-clarifier__actions {
  display: flex;
  align-items:  center;
  gap: var(--s-2);
  flex-wrap: wrap;
}

.v2-clarifier__hint {
  font-family: var(--font-mono);
  letter-spacing: .08em;
  color: var(--ink-3);
  margin-left: auto;
  font-size: 10.5px;
}

/* ui/src/v2/thread/RepeatBackCard.css */
.v2-repeatback {
  position: relative;
  background: var(--paper-2);
  border: 1px solid var(--rule);
  border-left: 4px solid var(--ink);
  border-radius: var(--r-2);
  display: flex;
  gap: var(--s-3);
  flex-direction: column;
  padding: 14px 16px;
}

.v2-repeatback__attribution {
  display: flex;
  align-items:  center;
  gap: var(--s-2);
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--ink-2);
  font-weight: 700;
}

.v2-repeatback__attribution-dot {
  background: var(--ink);
  border-radius: 2px;
  flex-shrink: 0;
  width: 4px;
  height: 4px;
}

.v2-repeatback__attribution-tag {
  color: var(--ink-3);
  font-weight: 400;
}

.v2-repeatback__conf {
  font-family: var(--font-mono);
  color: var(--ink-3);
  letter-spacing: .08em;
  margin-left: auto;
  font-size: 10.5px;
}

.v2-repeatback__heard {
  display: flex;
  align-items:  flex-start;
  gap: var(--s-2);
}

.v2-repeatback__heard-text {
  font-family: var(--font-display);
  color: var(--ink);
  font-size: 16px;
  line-height: 1.45;
}

.v2-repeatback__heard-text em {
  color: var(--ink-2);
  font-style: italic;
}

.v2-repeatback__actions {
  display: flex;
  gap: var(--s-2);
  flex-wrap: wrap;
}

/* ui/src/v2/thread/InlineCard.css */
.v2-card {
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items:  flex-start;
  gap: var(--s-4);
  padding: var(--s-4) var(--s-5);
  background: var(--paper-2);
  border: var(--hair);
  border-radius: var(--r-2);
  transition: background var(--dur-fast) var(--ease-out);
}

.v2-card:hover {
  background: var(--paper-3);
}

.v2-card__icon {
  border-radius: var(--r-1);
  background: var(--paper);
  border: var(--hair);
  display: flex;
  color: var(--ink);
  flex-shrink: 0;
  justify-content: center;
  align-items:  center;
  width: 36px;
  height: 36px;
}

.v2-card__body {
  display: flex;
  gap: var(--s-1);
  flex-direction: column;
  min-width: 0;
}

.v2-card__head {
  display: flex;
  align-items: baseline;
  gap: var(--s-3);
  flex-wrap: wrap;
}

.v2-card__type {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--ink-3);
  font-weight: 600;
}

.v2-card__title {
  font-family: var(--font-display);
  font-size: var(--text-lg);
  font-weight: 500;
  line-height: var(--lh-tight);
  color: var(--ink);
  display: inline;
  margin: 0;
}

.v2-card__summary {
  font-size: var(--text-sm);
  color: var(--ink-2);
  line-height: var(--lh-body);
}

.v2-card__meta {
  display: flex;
  align-items:  center;
  gap: var(--s-3);
  margin-top: var(--s-1);
  flex-wrap: wrap;
}

.v2-card__meta-text {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  letter-spacing: .08em;
  color: var(--ink-3);
}

.v2-card__actions {
  display: flex;
  align-items:  center;
  gap: var(--s-2);
  flex-shrink: 0;
}

/* ui/src/v2/rooms/RoomShell.css */
.v2-room-overlay {
  position: fixed;
  top: var(--v2-header-height);
  left: 0;
  right: var(--v2-rail-width);
  z-index: var(--z-room);
  display: flex;
  animation: v2-room-scrim-in var(--dur-med) var(--ease-out);
  background: #1a1a1a52;
  justify-content: stretch;
  align-items: stretch;
  bottom: 0;
}

.v2-room {
  background: var(--paper);
  display: flex;
  overflow: hidden;
  outline: none;
  animation: v2-room-slide-in var(--dur-slow) var(--ease-out);
  flex-direction: column;
  flex: 1;
}

.v2-room__header {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items:  center;
  gap: var(--s-4);
  padding: var(--s-4) var(--s-6);
  border-bottom: var(--hair);
  background: var(--paper);
  flex-shrink: 0;
}

.v2-room__header-left {
  display: flex;
  align-items:  center;
  gap: var(--s-3);
  min-width: 0;
}

.v2-room__back {
  display: inline-flex;
  align-items:  center;
  gap: var(--s-2);
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--ink-3);
  cursor: pointer;
  border-radius: var(--r-1);
  transition: background var(--dur-fast) var(--ease-out), color var(--dur-fast) var(--ease-out);
  background: none;
  border: 0;
  padding: 6px 10px;
}

.v2-room__back:hover {
  background: var(--paper-2);
  color: var(--ink);
}

.v2-room__back:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 2px;
}

.v2-room__breadcrumb {
  display: inline-flex;
  align-items:  center;
  gap: var(--s-2);
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--ink-3);
  padding-left: var(--s-3);
  border-left: var(--hair-soft);
}

.v2-room__breadcrumb-sep {
  color: var(--ink-3);
  opacity: .6;
}

.v2-room__breadcrumb-item[data-segment="source"] {
  opacity: .7;
}

.v2-room__breadcrumb-item[data-segment="context"] {
  text-transform: none;
  letter-spacing: .02em;
  color: var(--ink-2);
}

.v2-room__breadcrumb-item[data-segment="room"] {
  color: var(--ink-2);
}

.v2-room__header-center {
  display: flex;
  text-align: center;
  flex-direction: column;
  align-items:  center;
  min-width: 0;
}

.v2-room__title {
  font-family: var(--font-display);
  font-size: var(--text-xl);
  letter-spacing: -.01em;
  color: var(--ink);
  margin: 0;
  font-weight: 500;
  line-height: 1.1;
}

.v2-room__subtitle {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--ink-3);
  margin-top: 2px;
}

.v2-room__header-right {
  display: flex;
  justify-content: flex-end;
  align-items:  center;
  gap: var(--s-2);
  min-width: 0;
}

.v2-room__close {
  display: inline-flex;
  cursor: pointer;
  color: var(--ink-2);
  border-radius: var(--r-pill);
  margin-left: var(--s-2);
  transition: background var(--dur-fast) var(--ease-out), color var(--dur-fast) var(--ease-out);
  background: none;
  border: 0;
  justify-content: center;
  align-items:  center;
  width: 32px;
  height: 32px;
}

.v2-room__close:hover {
  background: var(--paper-2);
  color: var(--ink);
}

.v2-room__close:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 2px;
}

.v2-room__body {
  overflow: auto;
  background: var(--paper);
  flex: 1;
}

@keyframes v2-room-scrim-in {
  from {
    background: #1a1a1a00;
  }

  to {
    background: #1a1a1a52;
  }
}

@keyframes v2-room-slide-in {
  from {
    transform: translateY(100%);
  }

  to {
    transform: translateY(0);
  }
}

@media (prefers-reduced-motion: reduce) {
  .v2-room-overlay, .v2-room {
    animation: none;
  }
}

/* ui/src/v2/rooms/tools/ToolsRoom.css */
.v2-tools {
  display: grid;
  grid-template-columns: minmax(360px, 460px) 1fr;
  overflow: hidden;
  width: 100%;
  height: 100%;
}

.v2-tools__list-pane {
  display: flex;
  border-right: var(--hair-soft);
  background: var(--paper);
  overflow: hidden;
  flex-direction: column;
}

.v2-tools__filters {
  display: flex;
  gap: var(--s-3);
  padding: var(--s-4) var(--s-5) var(--s-3);
  border-bottom: var(--hair-soft);
  flex-direction: column;
}

.v2-tools__search {
  display: flex;
  align-items:  center;
  gap: var(--s-2);
  background: var(--paper-2);
  border: 1px solid var(--rule);
  border-radius: var(--r-2);
  color: var(--ink-3);
  transition: border-color var(--dur-fast) var(--ease-out), background var(--dur-fast) var(--ease-out);
  padding: 8px 12px;
}

.v2-tools__search:focus-within {
  background: var(--paper);
  border-color: var(--ink);
}

.v2-tools__search-input {
  outline: none;
  font-family: var(--font-display);
  font-size: var(--text-md);
  color: var(--ink);
  background: none;
  border: 0;
  flex: 1;
}

.v2-tools__search-input::placeholder {
  color: var(--ink-3);
  font-style: italic;
}

.v2-tools__filter-row {
  display: flex;
  gap: var(--s-1);
  flex-wrap: wrap;
}

.v2-tools__filter-btn {
  border: 1px solid var(--rule-soft);
  border-radius: var(--r-pill);
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--ink-3);
  cursor: pointer;
  transition: background var(--dur-fast) var(--ease-out), color var(--dur-fast) var(--ease-out), border-color var(--dur-fast) var(--ease-out);
  background: none;
  padding: 4px 10px;
}

.v2-tools__filter-btn:hover {
  background: var(--paper-2);
  color: var(--ink);
}

.v2-tools__filter-btn[data-active="true"] {
  background: var(--ink);
  color: var(--paper);
  border-color: var(--ink);
}

.v2-tools__filter-btn:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 2px;
}

.v2-tools__list {
  list-style: none;
  padding: var(--s-2) 0;
  overflow-y: auto;
  flex: 1;
  margin: 0;
}

.v2-tools__row {
  display: grid;
  grid-template-columns: 28px 1fr;
  gap: var(--s-3);
  cursor: pointer;
  transition: background var(--dur-fast) var(--ease-out);
  border-left: 2px solid #0000;
  padding: 10px 16px;
}

.v2-tools__row:hover {
  background: var(--paper-2);
}

.v2-tools__row[data-active="true"] {
  background: var(--paper-2);
  border-left-color: var(--accent);
}

.v2-tools__row-icon {
  display: flex;
  background: var(--paper-2);
  border: var(--hair-soft);
  border-radius: var(--r-1);
  color: var(--ink-2);
  justify-content: center;
  align-items:  center;
  width: 28px;
  height: 28px;
}

.v2-tools__row[data-active="true"] .v2-tools__row-icon {
  background: var(--paper);
  color: var(--ink);
}

.v2-tools__row-body {
  display: flex;
  flex-direction: column;
  gap: 2px;
  min-width: 0;
}

.v2-tools__row-head {
  display: flex;
  align-items:  center;
  gap: var(--s-2);
  flex-wrap: wrap;
}

.v2-tools__row-name {
  font-family: var(--font-mono);
  font-size: var(--text-sm);
  color: var(--ink);
  word-break: break-word;
}

.v2-tools__row-summary {
  font-family: var(--font-display);
  font-size: var(--text-sm);
  color: var(--ink-2);
  display: -webkit-box;
  -webkit-line-clamp: 2;
  overflow: hidden;
  -webkit-box-orient: vertical;
  line-height: 1.4;
}

.v2-tools__row-meta {
  display: inline-flex;
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  letter-spacing: .08em;
  color: var(--ink-3);
  align-items:  center;
  gap: 6px;
  margin-top: 2px;
}

.v2-tools__error, .v2-tools__empty {
  padding: var(--s-6) var(--s-5);
  text-align: center;
  font-family: var(--font-display);
  color: var(--ink-3);
  font-style: italic;
}

.v2-tools__error {
  color: var(--warn);
}

.v2-tools__detail-pane {
  background: var(--paper);
  overflow-y: auto;
  padding: var(--s-8) var(--s-10);
}

.v2-tools__detail-empty {
  display: flex;
  font-family: var(--font-display);
  color: var(--ink-3);
  justify-content: center;
  align-items:  center;
  height: 100%;
  font-style: italic;
}

.v2-tools__detail {
  display: flex;
  gap: var(--s-6);
  flex-direction: column;
  max-width: 720px;
  margin: 0 auto;
}

.v2-tools__detail-head {
  display: flex;
  gap: var(--s-2);
  flex-direction: column;
}

.v2-tools__detail-title-row {
  display: flex;
  align-items:  center;
  gap: var(--s-3);
  flex-wrap: wrap;
}

.v2-tools__detail-title {
  font-family: var(--font-mono);
  font-size: var(--text-xl);
  color: var(--ink);
  word-break: break-word;
  margin: 0;
}

.v2-tools__detail-meta {
  display: inline-flex;
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  letter-spacing: .1em;
  color: var(--ink-3);
  align-items:  center;
  gap: 6px;
}

.v2-tools__detail-desc {
  font-family: var(--font-display);
  font-size: var(--text-md);
  line-height: var(--lh-body);
  color: var(--ink);
  margin: 0;
}

.v2-tools__detail-section {
  display: flex;
  gap: var(--s-3);
  flex-direction: column;
}

.v2-tools__detail-section-label {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--ink-3);
  padding-bottom: var(--s-2);
  border-bottom: var(--hair-soft);
  font-weight: 600;
}

.v2-tools__detail-empty-line {
  font-family: var(--font-display);
  color: var(--ink-3);
  font-style: italic;
}

.v2-tools__params {
  list-style: none;
  display: flex;
  gap: var(--s-3);
  flex-direction: column;
  margin: 0;
  padding: 0;
}

.v2-tools__param {
  padding: var(--s-3) var(--s-4);
  background: var(--paper-2);
  border: var(--hair-soft);
  border-radius: var(--r-2);
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.v2-tools__param-head {
  display: inline-flex;
  align-items:  center;
  gap: var(--s-2);
  flex-wrap: wrap;
}

.v2-tools__param-name {
  font-family: var(--font-mono);
  font-size: var(--text-sm);
  color: var(--ink);
}

.v2-tools__param-type {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  letter-spacing: .06em;
  color: var(--ink-3);
  border: var(--hair-soft);
  border-radius: var(--r-1);
  padding: 1px 6px;
}

.v2-tools__param-req {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--accent);
}

.v2-tools__param-desc {
  font-family: var(--font-display);
  font-size: var(--text-sm);
  color: var(--ink-2);
  line-height: 1.5;
}

@media (max-width: 900px) {
  .v2-tools--expanded {
    grid-template-columns: 1fr;
    grid-template-rows: minmax(240px, 50%) 1fr;
  }

  .v2-tools--expanded .v2-tools__list-pane {
    border-right: 0;
    border-bottom: var(--hair-soft);
  }
}

.v2-tools--inline {
  grid-template-columns: 1fr;
}

.v2-tools--inline .v2-tools__list-pane {
  border-right: 0;
}

.v2-tools--inline .v2-tools__filters {
  padding: var(--s-3) var(--s-4) var(--s-2);
}

.v2-tools__row-params {
  margin-top: var(--s-3);
  padding-top: var(--s-3);
  border-top: var(--hair-soft);
}

/* ui/src/v2/rooms/logs/LogsRoom.css */
.v2-logs {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: 0;
  height: 100%;
  min-height: 0;
}

.v2-logs--expanded {
  grid-template-columns: minmax(0, 1.1fr) minmax(0, 1fr);
}

@media (max-width: 900px) {
  .v2-logs--expanded {
    grid-template-columns: minmax(0, 1fr);
    grid-template-rows: minmax(0, 1fr) minmax(0, 1fr);
  }
}

.v2-logs__list-pane {
  display: flex;
  border-right: var(--hair-soft);
  flex-direction: column;
  min-height: 0;
}

.v2-logs--inline .v2-logs__list-pane {
  border-right: 0;
}

@media (max-width: 900px) {
  .v2-logs__list-pane {
    border-right: 0;
    border-bottom: var(--hair-soft);
  }
}

.v2-logs__filters {
  display: flex;
  gap: var(--s-3);
  padding: var(--s-3) var(--s-4);
  border-bottom: var(--hair-soft);
  background: var(--paper);
  flex-direction: column;
}

.v2-logs__filter-row {
  display: flex;
  gap: var(--s-2);
  flex-wrap: wrap;
}

.v2-logs__filter-btn {
  display: inline-flex;
  align-items:  center;
  gap: var(--s-2);
  background: var(--paper-2);
  border: 1px solid var(--rule);
  border-radius: var(--r-pill);
  color: var(--ink-2);
  font-family: var(--font-sans);
  font-size: var(--text-xs);
  cursor: pointer;
  transition: background var(--dur-fast) var(--ease-out), color var(--dur-fast) var(--ease-out), border-color var(--dur-fast) var(--ease-out);
  padding: 4px 10px;
}

.v2-logs__filter-btn:hover {
  background: var(--paper-3);
  color: var(--ink);
}

.v2-logs__filter-btn[data-active="true"] {
  background: var(--ink);
  color: var(--paper);
  border-color: var(--ink);
}

.v2-logs__filter-btn:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 2px;
}

.v2-logs__filter-count {
  font-family: var(--font-mono);
  border-radius: var(--r-pill);
  background: color-mix(in srgb, currentColor 14%, transparent);
  padding: 0 4px;
  font-size: 10px;
}

.v2-logs__filter-btn[data-active="true"] .v2-logs__filter-count {
  background: color-mix(in srgb, var(--paper) 22%, transparent);
}

.v2-logs__bottom-row {
  display: flex;
  justify-content: space-between;
  align-items:  center;
  gap: var(--s-3);
  flex-wrap: wrap;
}

.v2-logs__time-row {
  display: inline-flex;
  border: 1px solid var(--rule);
  border-radius: var(--r-pill);
  overflow: hidden;
  background: var(--paper);
  align-items:  center;
}

.v2-logs__time-btn {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  letter-spacing: .05em;
  color: var(--ink-3);
  cursor: pointer;
  transition: background var(--dur-fast) var(--ease-out), color var(--dur-fast) var(--ease-out);
  background: none;
  border: 0;
  padding: 4px 10px;
}

.v2-logs__time-btn:hover {
  background: var(--paper-3);
  color: var(--ink);
}

.v2-logs__time-btn[data-active="true"] {
  background: var(--ink);
  color: var(--paper);
}

.v2-logs__time-btn:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: -2px;
}

.v2-logs__actions {
  display: inline-flex;
  align-items:  center;
  gap: var(--s-2);
}

.v2-logs__live-toggle {
  display: inline-flex;
  align-items:  center;
  gap: var(--s-2);
  border: 1px solid var(--rule);
  border-radius: var(--r-pill);
  background: var(--paper);
  color: var(--ink-3);
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  letter-spacing: .05em;
  cursor: pointer;
  transition: background var(--dur-fast) var(--ease-out), color var(--dur-fast) var(--ease-out), border-color var(--dur-fast) var(--ease-out);
  padding: 4px 10px;
}

.v2-logs__live-toggle:hover {
  background: var(--paper-3);
  color: var(--ink);
}

.v2-logs__live-toggle[data-active="true"] {
  border-color: var(--accent);
  color: var(--accent);
  background: color-mix(in srgb, var(--accent) 6%, transparent);
}

.v2-logs__live-toggle:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 2px;
}

.v2-logs__live-dot {
  border-radius: var(--r-pill);
  background: var(--ink-3);
  width: 8px;
  height: 8px;
}

.v2-logs__live-dot[data-active="true"] {
  background: var(--accent);
  box-shadow: 0 0 0 0 color-mix(in srgb, var(--accent) 50%, transparent);
  animation: v2-logs-pulse 1.6s ease-in-out infinite;
}

@keyframes v2-logs-pulse {
  0%, 100% {
    box-shadow: 0 0 0 0 color-mix(in srgb, var(--accent) 50%, transparent);
  }

  50% {
    box-shadow: 0 0 0 5px color-mix(in srgb, var(--accent) 0%, transparent);
  }
}

@media (prefers-reduced-motion: reduce) {
  .v2-logs__live-dot[data-active="true"] {
    animation: none;
  }
}

.v2-logs__refresh {
  display: inline-flex;
  border: 1px solid var(--rule);
  border-radius: var(--r-pill);
  background: var(--paper);
  color: var(--ink-2);
  cursor: pointer;
  transition: background var(--dur-fast) var(--ease-out), color var(--dur-fast) var(--ease-out);
  justify-content: center;
  align-items:  center;
  width: 28px;
  height: 28px;
}

.v2-logs__refresh:hover {
  background: var(--paper-3);
  color: var(--ink);
}

.v2-logs__refresh:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 2px;
}

.v2-logs__list {
  list-style: none;
  overflow-y: auto;
  flex: 1;
  margin: 0;
  padding: 0;
}

.v2-logs__list li + li {
  border-top: var(--hair-soft);
}

.v2-logs__row {
  display: grid;
  grid-template-columns: 28px 1fr;
  gap: var(--s-3);
  padding: var(--s-3) var(--s-4);
  cursor: pointer;
  transition: background var(--dur-fast) var(--ease-out);
  align-items:  flex-start;
}

.v2-logs__row:hover {
  background: var(--paper-2);
}

.v2-logs__row[data-active="true"] {
  background: var(--paper-3);
}

.v2-logs__row-icon {
  display: inline-flex;
  border-radius: var(--r-pill);
  background: var(--paper-3);
  color: var(--ink-2);
  flex-shrink: 0;
  justify-content: center;
  align-items:  center;
  width: 28px;
  height: 28px;
}

.v2-logs__row[data-tone="warn"] .v2-logs__row-icon {
  background: color-mix(in srgb, var(--warn) 14%, transparent);
  color: var(--warn);
}

.v2-logs__row[data-tone="ok"] .v2-logs__row-icon {
  background: color-mix(in srgb, var(--ok) 14%, transparent);
  color: var(--ok);
}

.v2-logs__row[data-tone="accent"] .v2-logs__row-icon {
  background: color-mix(in srgb, var(--accent) 14%, transparent);
  color: var(--accent);
}

.v2-logs__row-body {
  display: flex;
  flex-direction: column;
  gap: 2px;
  min-width: 0;
}

.v2-logs__row-head {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: var(--s-3);
}

.v2-logs__row-title {
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  color: var(--ink);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  flex: 1;
  min-width: 0;
}

.v2-logs__row-time {
  font-family: var(--font-mono);
  color: var(--ink-3);
  flex-shrink: 0;
  font-size: 10px;
}

.v2-logs__row-summary {
  font-family: var(--font-sans);
  font-size: var(--text-xs);
  color: var(--ink-3);
  display: -webkit-box;
  -webkit-line-clamp: 2;
  overflow: hidden;
  -webkit-box-orient: vertical;
}

.v2-logs__row-tags {
  display: flex;
  gap: var(--s-1);
  flex-wrap: wrap;
  margin-top: 2px;
}

.v2-logs__tag {
  font-family: var(--font-mono);
  letter-spacing: .05em;
  text-transform: uppercase;
  border-radius: var(--r-pill);
  background: var(--paper-3);
  color: var(--ink-3);
  padding: 1px 6px;
  font-size: 10px;
}

.v2-logs__detail-pane {
  overflow-y: auto;
  padding: var(--s-5) var(--s-6);
}

.v2-logs__detail {
  display: flex;
  gap: var(--s-4);
  flex-direction: column;
}

.v2-logs__detail-head {
  display: flex;
  gap: var(--s-2);
  flex-direction: column;
}

.v2-logs__detail-title-row {
  display: flex;
  justify-content: space-between;
  align-items:  center;
  gap: var(--s-3);
}

.v2-logs__detail-title {
  font-family: var(--font-display);
  font-size: var(--text-xl);
  color: var(--ink);
  line-height: var(--lh-tight);
  margin: 0;
}

.v2-logs__detail-meta {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: var(--ink-3);
}

.v2-logs__detail-desc {
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  color: var(--ink-2);
  line-height: var(--lh-body);
  margin: 0;
}

.v2-logs__detail-section {
  display: flex;
  gap: var(--s-2);
  padding-top: var(--s-3);
  border-top: var(--hair-soft);
  flex-direction: column;
}

.v2-logs__detail-section-label {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--ink-3);
}

.v2-logs__detail-tags {
  display: flex;
  gap: var(--s-1);
  flex-wrap: wrap;
}

.v2-logs__detail-raw {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  background: var(--paper-2);
  border: 1px solid var(--rule-soft);
  border-radius: var(--r-1);
  padding: var(--s-3);
  overflow-x: auto;
  white-space: pre-wrap;
  color: var(--ink-2);
  overflow-y: auto;
  max-height: 280px;
  margin: 0;
}

.v2-logs__detail-empty {
  display: flex;
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  color: var(--ink-3);
  padding: var(--s-8);
  text-align: center;
  justify-content: center;
  align-items:  center;
  height: 100%;
}

.v2-logs__empty {
  padding: var(--s-8) var(--s-4);
  text-align: center;
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  color: var(--ink-3);
}

.v2-logs__error {
  padding: var(--s-3) var(--s-4);
  background: color-mix(in srgb, var(--accent) 8%, transparent);
  color: var(--accent);
  font-family: var(--font-sans);
  font-size: var(--text-xs);
  border-bottom: var(--hair-soft);
}

/* ui/src/v2/rooms/agents/AgentsRoom.css */
.v2-agents {
  display: flex;
  position: relative;
  flex-direction: column;
  height: 100%;
  min-height: 0;
}

.v2-agents__stats {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: var(--s-3);
  padding: var(--s-4) var(--s-6) var(--s-3);
}

@media (max-width: 720px) {
  .v2-agents__stats {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

.v2-agents__stat {
  background: var(--paper-2);
  border: 1px solid var(--rule-soft);
  border-radius: var(--r-2);
  padding: var(--s-3) var(--s-4);
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.v2-agents__stat-label {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--ink-3);
}

.v2-agents__stat-value {
  font-family: var(--font-display);
  font-size: var(--text-xl);
  color: var(--ink);
  line-height: 1.1;
}

.v2-agents__stat-sub {
  font-family: var(--font-sans);
  font-size: var(--text-xs);
  color: var(--ink-3);
}

.v2-agents__tabs {
  display: flex;
  gap: var(--s-1);
  padding: 0 var(--s-6);
  border-bottom: var(--hair-soft);
}

.v2-agents__tab {
  display: inline-flex;
  align-items:  center;
  gap: var(--s-2);
  padding: var(--s-3) var(--s-3);
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  color: var(--ink-3);
  cursor: pointer;
  transition: color var(--dur-fast) var(--ease-out), border-color var(--dur-fast) var(--ease-out);
  background: none;
  border: 0;
  border-bottom: 2px solid #0000;
  margin-bottom: -1px;
}

.v2-agents__tab:hover {
  color: var(--ink);
}

.v2-agents__tab[data-active="true"] {
  color: var(--ink);
  border-bottom-color: var(--accent);
}

.v2-agents__tab:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 2px;
  border-radius: var(--r-1);
}

.v2-agents__tab-badge {
  font-family: var(--font-mono);
  border-radius: var(--r-pill);
  background: var(--paper-3);
  color: var(--ink-3);
  letter-spacing: 0;
  padding: 1px 6px;
  font-size: 10px;
}

.v2-agents__tab[data-active="true"] .v2-agents__tab-badge {
  background: color-mix(in srgb, var(--accent) 14%, transparent);
  color: var(--accent);
}

.v2-agents__toolbar {
  display: flex;
  align-items:  center;
  gap: var(--s-3);
  padding: var(--s-3) var(--s-6);
  border-bottom: var(--hair-soft);
}

.v2-agents__search {
  display: inline-flex;
  align-items:  center;
  gap: var(--s-2);
  background: var(--paper-2);
  border: 1px solid var(--rule);
  border-radius: var(--r-pill);
  color: var(--ink-3);
  flex: 1;
  max-width: 360px;
  padding: 6px 10px;
}

.v2-agents__search:focus-within {
  border-color: var(--ink-3);
  color: var(--ink-2);
}

.v2-agents__search-input {
  outline: 0;
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  color: var(--ink);
  background: none;
  border: 0;
  flex: 1;
}

.v2-agents__search-input::placeholder {
  color: var(--ink-3);
}

.v2-agents__spawn-btn {
  display: inline-flex;
  align-items:  center;
  gap: var(--s-2);
  background: var(--ink);
  color: var(--paper);
  border-radius: var(--r-pill);
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  cursor: pointer;
  transition: background var(--dur-fast) var(--ease-out);
  border: 0;
  padding: 6px 12px;
}

.v2-agents__spawn-btn:hover {
  background: var(--ink-2);
}

.v2-agents__spawn-btn:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 2px;
}

.v2-agents__command {
  overflow-y: auto;
  padding: var(--s-4) var(--s-6) var(--s-6);
  flex: 1;
}

.v2-agents__section {
  display: flex;
  gap: var(--s-3);
  margin-bottom: var(--s-5);
  flex-direction: column;
}

.v2-agents__section-label {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--ink-3);
}

.v2-agents__grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: var(--s-3);
}

.v2-agents__card {
  background: var(--paper-2);
  border: 1px solid var(--rule-soft);
  border-radius: var(--r-2);
  padding: var(--s-3) var(--s-4);
  display: flex;
  gap: var(--s-3);
  transition: border-color var(--dur-fast) var(--ease-out), background var(--dur-fast) var(--ease-out);
  flex-direction: column;
}

.v2-agents__card[data-active="true"] {
  border-color: var(--rule);
  background: var(--paper);
}

.v2-agents__card-head {
  display: grid;
  grid-template-columns: 36px 1fr auto;
  gap: var(--s-3);
  align-items:  flex-start;
}

.v2-agents__card-icon {
  border-radius: var(--r-2);
  background: var(--paper-3);
  color: var(--ink-2);
  display: inline-flex;
  justify-content: center;
  align-items:  center;
  width: 36px;
  height: 36px;
}

.v2-agents__card[data-active="true"] .v2-agents__card-icon {
  background: color-mix(in srgb, var(--accent) 10%, transparent);
  color: var(--accent);
}

.v2-agents__card-id {
  display: flex;
  flex-direction: column;
  gap: 2px;
  min-width: 0;
}

.v2-agents__card-name {
  font-family: var(--font-sans);
  font-size: var(--text-md);
  color: var(--ink);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  font-weight: 500;
}

.v2-agents__card-task {
  font-family: var(--font-sans);
  font-size: var(--text-xs);
  color: var(--ink-2);
  display: -webkit-box;
  -webkit-line-clamp: 2;
  overflow: hidden;
  -webkit-box-orient: vertical;
}

.v2-agents__card-task[data-empty="true"] {
  color: var(--ink-3);
  font-style: italic;
}

.v2-agents__card-foot {
  display: flex;
  align-items:  center;
  gap: var(--s-3);
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: var(--ink-3);
}

.v2-agents__card-foot-spacer {
  flex: 1;
}

.v2-agents__authority {
  display: inline-flex;
  align-items:  center;
  gap: 3px;
}

.v2-agents__pip {
  background: var(--rule);
  border-radius: 1px;
  width: 4px;
  height: 10px;
}

.v2-agents__pip[data-filled="true"] {
  background: var(--ink-2);
}

.v2-agents__pip[data-filled="true"][data-active="true"] {
  background: var(--accent);
}

.v2-agents__authority-label {
  margin-left: var(--s-2);
  color: var(--ink-3);
}

.v2-agents__tools, .v2-agents__since {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: var(--ink-3);
}

.v2-agents__orbital {
  display: flex;
  flex-direction: column;
  flex: 1;
  min-height: 0;
}

.v2-agents__orbital-stage {
  position: relative;
  margin: var(--s-4) var(--s-6);
  border: 1px solid var(--rule-soft);
  border-radius: var(--r-2);
  background: var(--paper-2);
  overflow: hidden;
  flex: 1;
  min-height: 360px;
}

.v2-agents__orbital-viewport {
  position: absolute;
  overflow: auto;
  display: flex;
  justify-content: center;
  align-items:  center;
  inset: 0;
}

.v2-agents__orbital-canvas {
  position: relative;
  aspect-ratio: 1;
  flex-shrink: 0;
  width: 100%;
  min-width: 720px;
  height: 100%;
  min-height: 720px;
}

.v2-agents__ring {
  position: absolute;
  border: 1px dashed var(--rule);
  pointer-events: none;
  border-radius: 50%;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}

.v2-agents__ring--inner {
  aspect-ratio: 1;
  width: 44%;
}

.v2-agents__ring--outer {
  aspect-ratio: 1;
  width: 76%;
}

.v2-agents__orb {
  position: absolute;
  display: inline-flex;
  padding: var(--s-2) var(--s-3);
  background: var(--paper);
  border: 1px solid var(--rule);
  border-radius: var(--r-2);
  color: var(--ink-2);
  cursor: pointer;
  transition: background var(--dur-fast) var(--ease-out), border-color var(--dur-fast) var(--ease-out), color var(--dur-fast) var(--ease-out);
  font-family: var(--font-sans);
  text-align: center;
  flex-direction: column;
  align-items:  center;
  gap: 4px;
  max-width: 110px;
  font-size: 10px;
  line-height: 1.2;
  transform: translate(-50%, -50%);
}

.v2-agents__orb:hover {
  background: var(--paper-3);
  color: var(--ink);
}

.v2-agents__orb[data-active="true"] {
  border-color: var(--accent);
  color: var(--accent);
  background: color-mix(in srgb, var(--accent) 6%, var(--paper));
}

.v2-agents__orb[data-selected="true"] {
  outline: 2px solid var(--accent);
  outline-offset: 2px;
}

.v2-agents__orb--center {
  background: var(--ink);
  color: var(--paper);
  border-color: var(--ink);
  padding: var(--s-3) var(--s-4);
}

.v2-agents__orb--center:hover {
  background: var(--ink-2);
}

.v2-agents__orb-name {
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  max-width: 100px;
  font-size: 10px;
}

.v2-agents__orbital-detail {
  position: absolute;
  bottom: var(--s-3);
  right: var(--s-3);
  background: var(--paper);
  border: 1px solid var(--rule);
  border-radius: var(--r-2);
  padding: var(--s-3) var(--s-4);
  display: flex;
  gap: var(--s-2);
  z-index: 2;
  pointer-events: auto;
  flex-direction: column;
  max-width: 280px;
  box-shadow: 0 4px 16px -8px #1a1a1a2e;
}

.v2-agents__orbital-detail-head {
  display: flex;
  justify-content: space-between;
  align-items:  center;
  gap: var(--s-2);
}

.v2-agents__orbital-detail-name {
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  color: var(--ink);
  font-weight: 500;
}

.v2-agents__orbital-detail-task {
  font-family: var(--font-sans);
  font-size: var(--text-xs);
  color: var(--ink-2);
  line-height: var(--lh-body);
}

.v2-agents__orbital-detail-meta {
  font-family: var(--font-mono);
  color: var(--ink-3);
  font-size: 10px;
}

.v2-agents__ticker {
  display: flex;
  align-items:  center;
  gap: var(--s-3);
  padding: var(--s-2) var(--s-6);
  border-top: var(--hair-soft);
  background: var(--paper);
  overflow: hidden;
}

.v2-agents__ticker-label {
  font-family: var(--font-mono);
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--accent);
  display: inline-flex;
  align-items:  center;
  gap: var(--s-2);
  flex-shrink: 0;
  font-size: 10px;
}

.v2-agents__ticker-label:before {
  content: "";
  border-radius: var(--r-pill);
  background: var(--accent);
  width: 6px;
  height: 6px;
}

.v2-agents__ticker-track {
  overflow: hidden;
  position: relative;
  flex: 1;
  height: 24px;
}

.v2-agents__ticker-scroll {
  display: flex;
  gap: var(--s-5);
  white-space: nowrap;
  animation: v2-agents-ticker 40s linear infinite;
}

@keyframes v2-agents-ticker {
  from {
    transform: translateX(0);
  }

  to {
    transform: translateX(-50%);
  }
}

@media (prefers-reduced-motion: reduce) {
  .v2-agents__ticker-scroll {
    animation: none;
  }
}

.v2-agents__ticker-event {
  display: inline-flex;
  align-items:  center;
  gap: var(--s-2);
  font-family: var(--font-sans);
  font-size: var(--text-xs);
  color: var(--ink-2);
}

.v2-agents__ticker-dot {
  border-radius: var(--r-pill);
  background: var(--ink-3);
  width: 6px;
  height: 6px;
}

.v2-agents__ticker-dot[data-event="done"] {
  background: var(--ok);
}

.v2-agents__ticker-dot[data-event="tool_call"] {
  background: var(--accent);
}

.v2-agents__ticker-dot[data-event="text"] {
  background: var(--ink-3);
}

.v2-agents__ticker-time {
  font-family: var(--font-mono);
  color: var(--ink-3);
  font-size: 10px;
}

.v2-agents__ticker-agent {
  color: var(--ink);
  font-weight: 500;
}

.v2-agents__ticker-empty {
  font-family: var(--font-sans);
  font-size: var(--text-xs);
  color: var(--ink-3);
  font-style: italic;
}

.v2-agents__builder-redirect {
  display: flex;
  justify-content: center;
  align-items:  center;
  gap: var(--s-3);
  padding: var(--s-8);
  text-align: center;
  flex-direction: column;
  flex: 1;
  max-width: 480px;
  margin: 0 auto;
}

.v2-agents__builder-title {
  font-family: var(--font-display);
  font-size: var(--text-xl);
  color: var(--ink);
  margin: 0;
}

.v2-agents__builder-body {
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  color: var(--ink-2);
  line-height: var(--lh-body);
  margin: 0;
}

.v2-agents__builder-cta {
  display: inline-flex;
  align-items:  center;
  gap: var(--s-2);
  background: var(--ink);
  color: var(--paper);
  border-radius: var(--r-pill);
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  cursor: pointer;
  margin-top: var(--s-2);
  transition: background var(--dur-fast) var(--ease-out);
  border: 0;
  padding: 8px 16px;
}

.v2-agents__builder-cta:hover {
  background: var(--ink-2);
}

.v2-agents__empty {
  padding: var(--s-8) var(--s-4);
  text-align: center;
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  color: var(--ink-3);
}

.v2-agents__error {
  padding: var(--s-3) var(--s-6);
  background: color-mix(in srgb, var(--accent) 8%, transparent);
  color: var(--accent);
  font-family: var(--font-sans);
  font-size: var(--text-xs);
  border-bottom: var(--hair-soft);
}

.v2-agents__toast {
  position: absolute;
  right: var(--s-4);
  bottom: var(--s-4);
  padding: var(--s-3) var(--s-4);
  background: var(--ink);
  color: var(--paper);
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  border-radius: var(--r-2);
  z-index: 5;
  max-width: 360px;
  box-shadow: 0 6px 20px -10px #1a1a1a66;
}

.v2-agents__toast[data-tone="warn"] {
  background: var(--accent);
}

.v2-agents__overlay {
  position: fixed;
  display: flex;
  padding: var(--s-4);
  z-index: 65;
  background: #1a1a1a66;
  justify-content: center;
  align-items:  center;
  inset: 0;
}

.v2-agents__dialog {
  background: var(--paper);
  border: 1px solid var(--rule);
  border-radius: var(--r-2);
  display: flex;
  outline: none;
  overflow: hidden;
  flex-direction: column;
  width: 100%;
  max-width: 520px;
  max-height: 90vh;
}

.v2-agents__dialog-head {
  display: flex;
  padding: var(--s-4) var(--s-5);
  border-bottom: var(--hair-soft);
  background: var(--paper-2);
  justify-content: space-between;
  align-items:  flex-start;
}

.v2-agents__dialog-title {
  font-family: var(--font-display);
  font-size: var(--text-lg);
  color: var(--ink);
}

.v2-agents__dialog-subtitle {
  font-family: var(--font-sans);
  font-size: var(--text-xs);
  color: var(--ink-3);
  margin-top: 2px;
}

.v2-agents__dialog-close {
  display: inline-flex;
  color: var(--ink-3);
  border-radius: var(--r-pill);
  cursor: pointer;
  transition: background var(--dur-fast) var(--ease-out), color var(--dur-fast) var(--ease-out);
  background: none;
  border: 0;
  justify-content: center;
  align-items:  center;
  width: 28px;
  height: 28px;
}

.v2-agents__dialog-close:hover {
  background: var(--paper-3);
  color: var(--ink);
}

.v2-agents__dialog-body {
  display: flex;
  gap: var(--s-4);
  padding: var(--s-5);
  overflow-y: auto;
  flex-direction: column;
}

.v2-agents__field {
  display: flex;
  gap: var(--s-2);
  flex-direction: column;
}

.v2-agents__field-label {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--ink-3);
}

.v2-agents__specialist-list {
  display: flex;
  gap: var(--s-2);
  flex-wrap: wrap;
}

.v2-agents__specialist-btn {
  background: var(--paper-2);
  border: 1px solid var(--rule);
  border-radius: var(--r-pill);
  font-family: var(--font-sans);
  font-size: var(--text-xs);
  color: var(--ink-2);
  cursor: pointer;
  transition: background var(--dur-fast) var(--ease-out), color var(--dur-fast) var(--ease-out), border-color var(--dur-fast) var(--ease-out);
  padding: 4px 12px;
}

.v2-agents__specialist-btn:hover {
  background: var(--paper-3);
  color: var(--ink);
}

.v2-agents__specialist-btn[data-active="true"] {
  background: var(--ink);
  color: var(--paper);
  border-color: var(--ink);
}

.v2-agents__specialist-meta {
  font-family: var(--font-sans);
  font-size: var(--text-xs);
  color: var(--ink-3);
  line-height: var(--lh-body);
  padding: var(--s-2) var(--s-3);
  background: var(--paper-2);
  border-radius: var(--r-1);
}

.v2-agents__textarea {
  padding: var(--s-2) var(--s-3);
  background: var(--paper);
  border: 1px solid var(--rule);
  border-radius: var(--r-1);
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  color: var(--ink);
  resize: vertical;
  width: 100%;
  min-height: 56px;
}

.v2-agents__textarea:focus {
  outline: 2px solid var(--accent);
  outline-offset: -2px;
}

.v2-agents__dialog-foot {
  display: flex;
  justify-content: flex-end;
  gap: var(--s-2);
  padding: var(--s-3) var(--s-5);
  border-top: var(--hair-soft);
  background: var(--paper-2);
}

.v2-agents__btn-secondary, .v2-agents__btn-primary {
  border-radius: var(--r-pill);
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  cursor: pointer;
  border: 1px solid var(--rule);
  transition: background var(--dur-fast) var(--ease-out), color var(--dur-fast) var(--ease-out);
  padding: 6px 14px;
}

.v2-agents__btn-secondary {
  color: var(--ink-2);
  background: none;
}

.v2-agents__btn-secondary:hover {
  background: var(--paper-3);
  color: var(--ink);
}

.v2-agents__btn-primary {
  background: var(--ink);
  color: var(--paper);
  border-color: var(--ink);
}

.v2-agents__btn-primary:hover {
  background: var(--ink-2);
}

.v2-agents__btn-primary:disabled, .v2-agents__btn-secondary:disabled {
  opacity: .5;
  cursor: default;
}

.v2-agents__empty-line {
  font-family: var(--font-sans);
  font-size: var(--text-xs);
  color: var(--ink-3);
  font-style: italic;
}

.v2-agents--inline .v2-agents__stats {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  padding: var(--s-3) var(--s-4) var(--s-2);
}

.v2-agents--inline .v2-agents__toolbar {
  padding: var(--s-2) var(--s-4);
}

.v2-agents--inline .v2-agents__command {
  padding: var(--s-3) var(--s-4) var(--s-4);
}

.v2-agents--inline .v2-agents__grid {
  grid-template-columns: 1fr;
}

/* node_modules/@xyflow/react/dist/style.css */
.react-flow {
  direction: ltr;
  --xy-edge-stroke-default: #b1b1b7;
  --xy-edge-stroke-width-default: 1;
  --xy-edge-stroke-selected-default: #555;
  --xy-connectionline-stroke-default: #b1b1b7;
  --xy-connectionline-stroke-width-default: 1;
  --xy-attribution-background-color-default: #ffffff80;
  --xy-minimap-background-color-default: #fff;
  --xy-minimap-mask-background-color-default: #f0f0f099;
  --xy-minimap-mask-stroke-color-default: transparent;
  --xy-minimap-mask-stroke-width-default: 1;
  --xy-minimap-node-background-color-default: #e2e2e2;
  --xy-minimap-node-stroke-color-default: transparent;
  --xy-minimap-node-stroke-width-default: 2;
  --xy-background-color-default: transparent;
  --xy-background-pattern-dots-color-default: #91919a;
  --xy-background-pattern-lines-color-default: #eee;
  --xy-background-pattern-cross-color-default: #e2e2e2;
  background-color: var(--xy-background-color, var(--xy-background-color-default));
  --xy-node-color-default: inherit;
  --xy-node-border-default: 1px solid #1a192b;
  --xy-node-background-color-default: #fff;
  --xy-node-group-background-color-default: #f0f0f040;
  --xy-node-boxshadow-hover-default: 0 1px 4px 1px #00000014;
  --xy-node-boxshadow-selected-default: 0 0 0 .5px #1a192b;
  --xy-node-border-radius-default: 3px;
  --xy-handle-background-color-default: #1a192b;
  --xy-handle-border-color-default: #fff;
  --xy-selection-background-color-default: #0059dc14;
  --xy-selection-border-default: 1px dotted #0059dccc;
  --xy-controls-button-background-color-default: #fefefe;
  --xy-controls-button-background-color-hover-default: #f4f4f4;
  --xy-controls-button-color-default: inherit;
  --xy-controls-button-color-hover-default: inherit;
  --xy-controls-button-border-color-default: #eee;
  --xy-controls-box-shadow-default: 0 0 2px 1px #00000014;
  --xy-edge-label-background-color-default: #fff;
  --xy-edge-label-color-default: inherit;
  --xy-resize-background-color-default: #3367d9;
}

.react-flow.dark {
  --xy-edge-stroke-default: #3e3e3e;
  --xy-edge-stroke-width-default: 1;
  --xy-edge-stroke-selected-default: #727272;
  --xy-connectionline-stroke-default: #b1b1b7;
  --xy-connectionline-stroke-width-default: 1;
  --xy-attribution-background-color-default: #96969640;
  --xy-minimap-background-color-default: #141414;
  --xy-minimap-mask-background-color-default: #3c3c3c99;
  --xy-minimap-mask-stroke-color-default: transparent;
  --xy-minimap-mask-stroke-width-default: 1;
  --xy-minimap-node-background-color-default: #2b2b2b;
  --xy-minimap-node-stroke-color-default: transparent;
  --xy-minimap-node-stroke-width-default: 2;
  --xy-background-color-default: #141414;
  --xy-background-pattern-dots-color-default: #777;
  --xy-background-pattern-lines-color-default: #777;
  --xy-background-pattern-cross-color-default: #777;
  --xy-node-color-default: #f8f8f8;
  --xy-node-border-default: 1px solid #3c3c3c;
  --xy-node-background-color-default: #1e1e1e;
  --xy-node-group-background-color-default: #f0f0f040;
  --xy-node-boxshadow-hover-default: 0 1px 4px 1px #ffffff14;
  --xy-node-boxshadow-selected-default: 0 0 0 .5px #999;
  --xy-handle-background-color-default: #bebebe;
  --xy-handle-border-color-default: #1e1e1e;
  --xy-selection-background-color-default: #c8c8dc14;
  --xy-selection-border-default: 1px dotted #c8c8dccc;
  --xy-controls-button-background-color-default: #2b2b2b;
  --xy-controls-button-background-color-hover-default: #3e3e3e;
  --xy-controls-button-color-default: #f8f8f8;
  --xy-controls-button-color-hover-default: #fff;
  --xy-controls-button-border-color-default: #5b5b5b;
  --xy-controls-box-shadow-default: 0 0 2px 1px #00000014;
  --xy-edge-label-background-color-default: #141414;
  --xy-edge-label-color-default: #f8f8f8;
}

.react-flow__background {
  background-color: var(--xy-background-color-props, var(--xy-background-color, var(--xy-background-color-default)));
  pointer-events: none;
  z-index: -1;
}

.react-flow__container {
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
}

.react-flow__pane {
  z-index: 1;
}

.react-flow__pane.draggable {
  cursor: grab;
}

.react-flow__pane.dragging {
  cursor: grabbing;
}

.react-flow__pane.selection {
  cursor: pointer;
}

.react-flow__viewport {
  transform-origin: 0 0;
  z-index: 2;
  pointer-events: none;
}

.react-flow__renderer {
  z-index: 4;
}

.react-flow__selection {
  z-index: 6;
}

.react-flow__nodesselection-rect:focus {
  outline: none;
}

.react-flow__nodesselection-rect:focus-visible {
  outline: none;
}

.react-flow__edge-path {
  stroke: var(--xy-edge-stroke, var(--xy-edge-stroke-default));
  stroke-width: var(--xy-edge-stroke-width, var(--xy-edge-stroke-width-default));
  fill: none;
}

.react-flow__connection-path {
  stroke: var(--xy-connectionline-stroke, var(--xy-connectionline-stroke-default));
  stroke-width: var(--xy-connectionline-stroke-width, var(--xy-connectionline-stroke-width-default));
  fill: none;
}

.react-flow .react-flow__edges {
  position: absolute;
}

.react-flow .react-flow__edges svg {
  overflow: visible;
  position: absolute;
  pointer-events: none;
}

.react-flow__edge {
  pointer-events: visibleStroke;
}

.react-flow__edge.selectable {
  cursor: pointer;
}

.react-flow__edge.animated path {
  stroke-dasharray: 5;
  animation: dashdraw .5s linear infinite;
}

.react-flow__edge.animated path.react-flow__edge-interaction {
  stroke-dasharray: none;
  animation: none;
}

.react-flow__edge.inactive {
  pointer-events: none;
}

.react-flow__edge.selected, .react-flow__edge:focus {
  outline: none;
}

.react-flow__edge:focus-visible {
  outline: none;
}

.react-flow__edge.selected .react-flow__edge-path, .react-flow__edge.selectable:focus .react-flow__edge-path {
  stroke: var(--xy-edge-stroke-selected, var(--xy-edge-stroke-selected-default));
}

.react-flow__edge.selectable:focus-visible .react-flow__edge-path {
  stroke: var(--xy-edge-stroke-selected, var(--xy-edge-stroke-selected-default));
}

.react-flow__edge-textwrapper {
  pointer-events: all;
}

.react-flow__edge .react-flow__edge-text {
  pointer-events: none;
  -webkit-user-select: none;
  -moz-user-select: none;
  user-select: none;
}

.react-flow__arrowhead polyline {
  stroke: var(--xy-edge-stroke, var(--xy-edge-stroke-default));
}

.react-flow__arrowhead polyline.arrowclosed {
  fill: var(--xy-edge-stroke, var(--xy-edge-stroke-default));
}

.react-flow__connection {
  pointer-events: none;
}

.react-flow__connection .animated {
  stroke-dasharray: 5;
  animation: dashdraw .5s linear infinite;
}

svg.react-flow__connectionline {
  z-index: 1001;
  overflow: visible;
  position: absolute;
}

.react-flow__nodes {
  pointer-events: none;
  transform-origin: 0 0;
}

.react-flow__node {
  position: absolute;
  -webkit-user-select: none;
  -moz-user-select: none;
  user-select: none;
  pointer-events: all;
  transform-origin: 0 0;
  box-sizing: border-box;
  cursor: default;
}

.react-flow__node.selectable {
  cursor: pointer;
}

.react-flow__node.draggable {
  cursor: grab;
  pointer-events: all;
}

.react-flow__node.draggable.dragging {
  cursor: grabbing;
}

.react-flow__nodesselection {
  z-index: 3;
  transform-origin: left top;
  pointer-events: none;
}

.react-flow__nodesselection-rect {
  position: absolute;
  pointer-events: all;
  cursor: grab;
}

.react-flow__handle {
  position: absolute;
  pointer-events: none;
  background-color: var(--xy-handle-background-color, var(--xy-handle-background-color-default));
  border: 1px solid var(--xy-handle-border-color, var(--xy-handle-border-color-default));
  border-radius: 100%;
  width: 6px;
  min-width: 5px;
  height: 6px;
  min-height: 5px;
}

.react-flow__handle.connectingfrom {
  pointer-events: all;
}

.react-flow__handle.connectionindicator {
  pointer-events: all;
  cursor: crosshair;
}

.react-flow__handle-bottom {
  top: auto;
  bottom: 0;
  left: 50%;
  transform: translate(-50%, 50%);
}

.react-flow__handle-top {
  top: 0;
  left: 50%;
  transform: translate(-50%, -50%);
}

.react-flow__handle-left {
  top: 50%;
  left: 0;
  transform: translate(-50%, -50%);
}

.react-flow__handle-right {
  top: 50%;
  right: 0;
  transform: translate(50%, -50%);
}

.react-flow__edgeupdater {
  cursor: move;
  pointer-events: all;
}

.react-flow__pane.selection .react-flow__panel {
  pointer-events: none;
}

.react-flow__panel {
  position: absolute;
  z-index: 5;
  margin: 15px;
}

.react-flow__panel.top {
  top: 0;
}

.react-flow__panel.bottom {
  bottom: 0;
}

.react-flow__panel.top.center, .react-flow__panel.bottom.center {
  left: 50%;
  transform: translateX(-15px)translateX(-50%);
}

.react-flow__panel.left {
  left: 0;
}

.react-flow__panel.right {
  right: 0;
}

.react-flow__panel.left.center, .react-flow__panel.right.center {
  top: 50%;
  transform: translateY(-15px)translateY(-50%);
}

.react-flow__attribution {
  background: var(--xy-attribution-background-color, var(--xy-attribution-background-color-default));
  margin: 0;
  padding: 2px 3px;
  font-size: 10px;
}

.react-flow__attribution a {
  text-decoration: none;
  color: #999;
}

@keyframes dashdraw {
  from {
    stroke-dashoffset: 10;
  }
}

.react-flow__edgelabel-renderer {
  position: absolute;
  pointer-events: none;
  -webkit-user-select: none;
  -moz-user-select: none;
  user-select: none;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
}

.react-flow__viewport-portal {
  position: absolute;
  -webkit-user-select: none;
  -moz-user-select: none;
  user-select: none;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
}

.react-flow__minimap {
  background: var(--xy-minimap-background-color-props, var(--xy-minimap-background-color, var(--xy-minimap-background-color-default)));
}

.react-flow__minimap-svg {
  display: block;
}

.react-flow__minimap-mask {
  fill: var(--xy-minimap-mask-background-color-props, var(--xy-minimap-mask-background-color, var(--xy-minimap-mask-background-color-default)));
  stroke: var(--xy-minimap-mask-stroke-color-props, var(--xy-minimap-mask-stroke-color, var(--xy-minimap-mask-stroke-color-default)));
  stroke-width: var(--xy-minimap-mask-stroke-width-props, var(--xy-minimap-mask-stroke-width, var(--xy-minimap-mask-stroke-width-default)));
}

.react-flow__minimap-node {
  fill: var(--xy-minimap-node-background-color-props, var(--xy-minimap-node-background-color, var(--xy-minimap-node-background-color-default)));
  stroke: var(--xy-minimap-node-stroke-color-props, var(--xy-minimap-node-stroke-color, var(--xy-minimap-node-stroke-color-default)));
  stroke-width: var(--xy-minimap-node-stroke-width-props, var(--xy-minimap-node-stroke-width, var(--xy-minimap-node-stroke-width-default)));
}

.react-flow__background-pattern.dots {
  fill: var(--xy-background-pattern-color-props, var(--xy-background-pattern-color, var(--xy-background-pattern-dots-color-default)));
}

.react-flow__background-pattern.lines {
  stroke: var(--xy-background-pattern-color-props, var(--xy-background-pattern-color, var(--xy-background-pattern-lines-color-default)));
}

.react-flow__background-pattern.cross {
  stroke: var(--xy-background-pattern-color-props, var(--xy-background-pattern-color, var(--xy-background-pattern-cross-color-default)));
}

.react-flow__controls {
  display: flex;
  box-shadow: var(--xy-controls-box-shadow, var(--xy-controls-box-shadow-default));
  flex-direction: column;
}

.react-flow__controls.horizontal {
  flex-direction: row;
}

.react-flow__controls-button {
  display: flex;
  background: var(--xy-controls-button-background-color, var(--xy-controls-button-background-color-default));
  border: none;
  border-bottom: 1px solid var(--xy-controls-button-border-color-props, var(--xy-controls-button-border-color, var(--xy-controls-button-border-color-default)));
  color: var(--xy-controls-button-color-props, var(--xy-controls-button-color, var(--xy-controls-button-color-default)));
  cursor: pointer;
  -webkit-user-select: none;
  -moz-user-select: none;
  user-select: none;
  justify-content: center;
  align-items:  center;
  width: 26px;
  height: 26px;
  padding: 4px;
}

.react-flow__controls-button svg {
  fill: currentColor;
  width: 100%;
  max-width: 12px;
  max-height: 12px;
}

.react-flow__edge.updating .react-flow__edge-path {
  stroke: #777;
}

.react-flow__edge-text {
  font-size: 10px;
}

.react-flow__node.selectable:focus {
  outline: none;
}

.react-flow__node.selectable:focus-visible {
  outline: none;
}

.react-flow__node-input, .react-flow__node-default, .react-flow__node-output, .react-flow__node-group {
  border-radius: var(--xy-node-border-radius, var(--xy-node-border-radius-default));
  color: var(--xy-node-color, var(--xy-node-color-default));
  text-align: center;
  border: var(--xy-node-border, var(--xy-node-border-default));
  background-color: var(--xy-node-background-color, var(--xy-node-background-color-default));
  width: 150px;
  padding: 10px;
  font-size: 12px;
}

.react-flow__node-input.selectable:hover, .react-flow__node-default.selectable:hover, .react-flow__node-output.selectable:hover, .react-flow__node-group.selectable:hover {
  box-shadow: var(--xy-node-boxshadow-hover, var(--xy-node-boxshadow-hover-default));
}

.react-flow__node-input.selectable.selected, .react-flow__node-input.selectable:focus, .react-flow__node-default.selectable.selected, .react-flow__node-default.selectable:focus, .react-flow__node-output.selectable.selected, .react-flow__node-output.selectable:focus, .react-flow__node-group.selectable.selected, .react-flow__node-group.selectable:focus {
  box-shadow: var(--xy-node-boxshadow-selected, var(--xy-node-boxshadow-selected-default));
}

.react-flow__node-input.selectable:focus-visible {
  box-shadow: var(--xy-node-boxshadow-selected, var(--xy-node-boxshadow-selected-default));
}

.react-flow__node-default.selectable:focus-visible {
  box-shadow: var(--xy-node-boxshadow-selected, var(--xy-node-boxshadow-selected-default));
}

.react-flow__node-output.selectable:focus-visible {
  box-shadow: var(--xy-node-boxshadow-selected, var(--xy-node-boxshadow-selected-default));
}

.react-flow__node-group.selectable:focus-visible {
  box-shadow: var(--xy-node-boxshadow-selected, var(--xy-node-boxshadow-selected-default));
}

.react-flow__node-group {
  background-color: var(--xy-node-group-background-color, var(--xy-node-group-background-color-default));
}

.react-flow__nodesselection-rect, .react-flow__selection {
  background: var(--xy-selection-background-color, var(--xy-selection-background-color-default));
  border: var(--xy-selection-border, var(--xy-selection-border-default));
}

.react-flow__nodesselection-rect:focus, .react-flow__selection:focus {
  outline: none;
}

.react-flow__nodesselection-rect:focus-visible {
  outline: none;
}

.react-flow__selection:focus-visible {
  outline: none;
}

.react-flow__controls-button:hover {
  background: var(--xy-controls-button-background-color-hover-props, var(--xy-controls-button-background-color-hover, var(--xy-controls-button-background-color-hover-default)));
  color: var(--xy-controls-button-color-hover-props, var(--xy-controls-button-color-hover, var(--xy-controls-button-color-hover-default)));
}

.react-flow__controls-button:disabled {
  pointer-events: none;
}

.react-flow__controls-button:disabled svg {
  fill-opacity: .4;
}

.react-flow__controls-button:last-child {
  border-bottom: none;
}

.react-flow__controls.horizontal .react-flow__controls-button {
  border-bottom: none;
  border-right: 1px solid var(--xy-controls-button-border-color-props, var(--xy-controls-button-border-color, var(--xy-controls-button-border-color-default)));
}

.react-flow__controls.horizontal .react-flow__controls-button:last-child {
  border-right: none;
}

.react-flow__resize-control {
  position: absolute;
}

.react-flow__resize-control.left, .react-flow__resize-control.right {
  cursor: ew-resize;
}

.react-flow__resize-control.top, .react-flow__resize-control.bottom {
  cursor: ns-resize;
}

.react-flow__resize-control.top.left, .react-flow__resize-control.bottom.right {
  cursor: nwse-resize;
}

.react-flow__resize-control.bottom.left, .react-flow__resize-control.top.right {
  cursor: nesw-resize;
}

.react-flow__resize-control.handle {
  background-color: var(--xy-resize-background-color, var(--xy-resize-background-color-default));
  border: 1px solid #fff;
  border-radius: 1px;
  width: 5px;
  height: 5px;
  translate: -50% -50%;
}

.react-flow__resize-control.handle.left {
  top: 50%;
  left: 0;
}

.react-flow__resize-control.handle.right {
  top: 50%;
  left: 100%;
}

.react-flow__resize-control.handle.top {
  top: 0;
  left: 50%;
}

.react-flow__resize-control.handle.bottom {
  top: 100%;
  left: 50%;
}

.react-flow__resize-control.handle.top.left, .react-flow__resize-control.handle.bottom.left {
  left: 0;
}

.react-flow__resize-control.handle.top.right, .react-flow__resize-control.handle.bottom.right {
  left: 100%;
}

.react-flow__resize-control.line {
  border-color: var(--xy-resize-background-color, var(--xy-resize-background-color-default));
  border-style: solid;
  border-width: 0;
}

.react-flow__resize-control.line.left, .react-flow__resize-control.line.right {
  width: 1px;
  height: 100%;
  top: 0;
  transform: translate(-50%);
}

.react-flow__resize-control.line.left {
  border-left-width: 1px;
  left: 0;
}

.react-flow__resize-control.line.right {
  border-right-width: 1px;
  left: 100%;
}

.react-flow__resize-control.line.top, .react-flow__resize-control.line.bottom {
  width: 100%;
  height: 1px;
  left: 0;
  transform: translate(0, -50%);
}

.react-flow__resize-control.line.top {
  border-top-width: 1px;
  top: 0;
}

.react-flow__resize-control.line.bottom {
  border-bottom-width: 1px;
  top: 100%;
}

.react-flow__edge-textbg {
  fill: var(--xy-edge-label-background-color, var(--xy-edge-label-background-color-default));
}

.react-flow__edge-text {
  fill: var(--xy-edge-label-color, var(--xy-edge-label-color-default));
}

/* ui/src/styles/workflows.css */
.wf-page {
  --surface-1: #07070a;
  --surface-2: #0d0d14;
  --surface-3: #12121c;
  --surface-4: #1a1a28;
  --border-1: #ffffff0a;
  --border-2: #ffffff14;
  --border-3: #ffffff1f;
  --violet: #8b5cf6;
  --violet-bright: #a78bfa;
  --violet-dim: #8b5cf626;
  --blue: #60a5fa;
  --blue-dim: #60a5fa1f;
  --emerald: #34d399;
  --emerald-dim: #34d3991f;
  --amber: #fbbf24;
  --amber-dim: #fbbf241f;
  --rose: #fb7185;
  --rose-dim: #fb71851f;
  --cyan: #22d3ee;
  --cyan-dim: #22d3ee1a;
  --text-1: #ffffffeb;
  --text-2: #ffffff8c;
  --text-3: #ffffff4d;
  --font-sans: "Inter", system-ui, -apple-system, sans-serif;
  --font-mono: "JetBrains Mono", monospace;
  display: flex;
  overflow: hidden;
  background: var(--surface-1);
  color: var(--text-1);
  font-family: var(--font-sans);
  flex-direction: column;
  height: 100%;
}

.wf-header {
  display: flex;
  border-bottom: 1px solid var(--border-1);
  flex-shrink: 0;
  align-items:  center;
  gap: 16px;
  padding: 16px 28px;
}

.wf-header-title {
  letter-spacing: -.02em;
  font-size: 16px;
  font-weight: 700;
}

.wf-header-count {
  color: var(--text-3);
  background: var(--surface-3);
  border-radius: 10px;
  padding: 2px 8px;
  font-size: 12px;
}

.wf-header-spacer {
  flex: 1;
}

.wf-search-wrap {
  position: relative;
}

.wf-search-wrap svg {
  position: absolute;
  opacity: .3;
  pointer-events: none;
  top: 50%;
  left: 10px;
  transform: translateY(-50%);
}

.wf-search {
  background: var(--surface-2);
  border: 1px solid var(--border-1);
  color: var(--text-1);
  outline: none;
  font-size: 12px;
  font-family: var(--font-sans);
  border-radius: 8px;
  width: 220px;
  padding: 7px 12px 7px 32px;
  transition: border-color .15s;
}

.wf-search:focus {
  border-color: #8b5cf64d;
}

.wf-filter-btn {
  background: var(--surface-2);
  border: 1px solid var(--border-1);
  color: var(--text-2);
  cursor: pointer;
  display: flex;
  font-size: 12px;
  font-family: var(--font-sans);
  border-radius: 8px;
  align-items:  center;
  gap: 6px;
  padding: 7px 14px;
  transition: border-color .15s, color .15s;
}

.wf-filter-btn:hover {
  border-color: var(--border-2);
  color: var(--text-1);
}

.wf-filter-btn.active {
  color: var(--violet);
  background: var(--violet-dim);
  border-color: #8b5cf64d;
}

.wf-new-btn {
  color: var(--violet);
  cursor: pointer;
  display: flex;
  font-size: 12px;
  font-weight: 600;
  font-family: var(--font-sans);
  background: #8b5cf62e;
  border: 1px solid #8b5cf64d;
  border-radius: 8px;
  align-items:  center;
  gap: 6px;
  padding: 7px 16px;
  transition: background .15s, border-color .15s;
}

.wf-new-btn:hover {
  background: #8b5cf640;
  border-color: #8b5cf666;
}

.wf-stats-bar {
  display: flex;
  background: var(--border-1);
  flex-shrink: 0;
  gap: 1px;
  padding: 0 28px;
}

.wf-stat-card {
  background: var(--surface-2);
  display: flex;
  flex-direction: column;
  flex: 1;
  gap: 4px;
  padding: 16px 20px;
}

.wf-stat-label {
  text-transform: uppercase;
  letter-spacing: .08em;
  color: var(--text-3);
  font-size: 10px;
  font-weight: 600;
}

.wf-stat-value {
  letter-spacing: -.03em;
  font-size: 22px;
  font-weight: 700;
}

.wf-stat-value.violet {
  color: var(--violet);
}

.wf-stat-value.emerald {
  color: var(--emerald);
}

.wf-stat-value.blue {
  color: var(--blue);
}

.wf-stat-value.amber {
  color: var(--amber);
}

.wf-stat-sub {
  color: var(--text-3);
  font-size: 10px;
}

.wf-filter-tabs {
  display: flex;
  flex-shrink: 0;
  gap: 2px;
  padding: 12px 28px 0;
}

.wf-filter-tab {
  color: var(--text-3);
  cursor: pointer;
  font-size: 11px;
  font-weight: 500;
  font-family: var(--font-sans);
  background: none;
  border: none;
  border-bottom: 2px solid #0000;
  padding: 6px 14px;
  transition: color .15s, border-color .15s;
}

.wf-filter-tab:hover {
  color: var(--text-2);
}

.wf-filter-tab.active {
  color: var(--violet);
  border-bottom-color: var(--violet);
}

.wf-grid-area {
  overflow-y: auto;
  flex: 1;
  padding: 20px 28px;
}

.wf-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(340px, 1fr));
  gap: 12px;
}

.wf-card {
  background: var(--surface-2);
  border: 1px solid var(--border-1);
  overflow: hidden;
  cursor: pointer;
  border-radius: 12px;
  transition: border-color .15s, box-shadow .15s;
}

.wf-card:hover {
  border-color: #8b5cf640;
  box-shadow: 0 0 20px #8b5cf60f;
}

.wf-card-top {
  display: flex;
  align-items:  flex-start;
  gap: 12px;
  padding: 16px 18px 12px;
}

.wf-card-icon {
  display: flex;
  border-radius: 10px;
  flex-shrink: 0;
  justify-content: center;
  align-items:  center;
  width: 36px;
  height: 36px;
  font-size: 16px;
}

.wf-card-info {
  flex: 1;
  min-width: 0;
}

.wf-card-name {
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  margin-bottom: 3px;
  font-size: 14px;
  font-weight: 600;
}

.wf-card-desc {
  color: var(--text-2);
  display: -webkit-box;
  -webkit-line-clamp: 2;
  overflow: hidden;
  -webkit-box-orient: vertical;
  font-size: 11px;
  line-height: 1.45;
}

.wf-card-status {
  display: flex;
  text-transform: uppercase;
  letter-spacing: .05em;
  flex-shrink: 0;
  align-items:  center;
  gap: 5px;
  padding-top: 2px;
  font-size: 10px;
  font-weight: 600;
}

.wf-card-status .wf-status-dot {
  border-radius: 50%;
  width: 6px;
  height: 6px;
}

.wf-card-status.active .wf-status-dot {
  background: var(--emerald);
  box-shadow: 0 0 6px var(--emerald);
}

.wf-card-status.active {
  color: var(--emerald);
}

.wf-card-status.paused .wf-status-dot {
  background: var(--amber);
}

.wf-card-status.paused {
  color: var(--amber);
}

.wf-card-status.disabled .wf-status-dot {
  background: var(--text-3);
}

.wf-card-status.disabled {
  color: var(--text-3);
}

.wf-card-status.running .wf-status-dot {
  background: var(--violet);
  box-shadow: 0 0 6px var(--violet);
  animation: wf-pulse 1.5s infinite;
}

.wf-card-status.running {
  color: var(--violet);
}

.wf-card-preview {
  display: flex;
  overflow-x: hidden;
  align-items:  center;
  gap: 4px;
  padding: 8px 18px 10px;
}

.wf-preview-node {
  display: flex;
  white-space: nowrap;
  color: #fffc;
  border-radius: 4px;
  flex-shrink: 0;
  align-items:  center;
  height: 22px;
  padding: 0 8px;
  font-size: 9px;
  font-weight: 600;
}

.wf-preview-arrow {
  color: var(--text-3);
  flex-shrink: 0;
  font-size: 10px;
}

.wf-preview-more {
  color: var(--text-3);
  flex-shrink: 0;
  padding: 0 4px;
  font-size: 9px;
}

.wf-card-footer {
  border-top: 1px solid var(--border-1);
  display: flex;
  align-items:  center;
  gap: 12px;
  padding: 10px 18px;
}

.wf-card-tags {
  display: flex;
  gap: 4px;
}

.wf-card-tag {
  background: var(--violet-dim);
  color: #8b5cf6b3;
  border-radius: 4px;
  padding: 2px 6px;
  font-size: 9px;
  font-weight: 500;
}

.wf-card-meta {
  color: var(--text-3);
  display: flex;
  align-items:  center;
  gap: 4px;
  font-size: 10px;
}

.wf-card-meta svg {
  opacity: .4;
}

.wf-card-footer-spacer {
  flex: 1;
}

.wf-card-action {
  border: 1px solid var(--border-1);
  background: var(--surface-3);
  display: flex;
  cursor: pointer;
  color: var(--text-2);
  border-radius: 6px;
  justify-content: center;
  align-items:  center;
  width: 28px;
  height: 28px;
  padding: 0;
  transition: all .15s;
}

.wf-card-action:hover {
  border-color: var(--border-2);
  color: var(--text-1);
  background: var(--surface-4);
}

.wf-card-action.run:hover {
  color: var(--emerald);
  border-color: #34d3994d;
}

.wf-card-action.danger:hover {
  color: var(--rose);
  border-color: #fb71854d;
}

.wf-empty {
  display: flex;
  color: var(--text-2);
  position: relative;
  flex-direction: column;
  flex: 1;
  justify-content: center;
  align-items:  center;
  gap: 16px;
}

.wf-empty-icon {
  background: var(--violet-dim);
  display: flex;
  animation: wf-breathe 3s ease-in-out infinite;
  border-radius: 16px;
  justify-content: center;
  align-items:  center;
  width: 64px;
  height: 64px;
  font-size: 28px;
}

.wf-empty-title {
  color: var(--text-1);
  margin: 0;
  font-size: 16px;
  font-weight: 600;
}

.wf-empty-desc {
  color: var(--text-3);
  margin: 0;
  font-size: 12px;
}

.wf-empty-cta {
  color: var(--violet);
  cursor: pointer;
  display: flex;
  font-size: 13px;
  font-weight: 600;
  font-family: var(--font-sans);
  background: #8b5cf62e;
  border: 1px solid #8b5cf64d;
  border-radius: 8px;
  align-items:  center;
  gap: 8px;
  margin-top: 8px;
  padding: 10px 24px;
  transition: background .15s;
}

.wf-empty-cta:hover {
  background: #8b5cf640;
}

.wf-loading {
  display: flex;
  flex-direction: column;
  flex: 1;
  justify-content: center;
  align-items:  center;
  gap: 12px;
}

.wf-loading-orb {
  background: var(--violet-dim);
  animation: wf-pulse 1.5s ease-in-out infinite;
  border-radius: 50%;
  width: 32px;
  height: 32px;
}

.wf-loading-text {
  color: var(--text-3);
  font-size: 12px;
}

.wf-canvas-header {
  display: flex;
  border-bottom: 1px solid var(--border-1);
  flex-shrink: 0;
  align-items:  center;
  gap: 12px;
  padding: 12px 20px;
}

.wf-back-btn {
  color: var(--text-2);
  cursor: pointer;
  display: flex;
  font-size: 12px;
  font-family: var(--font-sans);
  background: none;
  border: none;
  border-radius: 6px;
  align-items:  center;
  gap: 4px;
  padding: 4px 8px;
  transition: background .15s, color .15s;
}

.wf-back-btn:hover {
  background: var(--surface-3);
  color: var(--text-1);
}

.wf-canvas-divider {
  background: var(--border-2);
  width: 1px;
  height: 16px;
}

.wf-canvas-title {
  font-size: 15px;
  font-weight: 700;
}

.wf-canvas-badge {
  border-radius: 10px;
  padding: 2px 8px;
  font-size: 10px;
  font-weight: 600;
}

.wf-canvas-badge.active {
  background: var(--emerald-dim);
  color: var(--emerald);
}

.wf-canvas-badge.paused {
  background: var(--amber-dim);
  color: var(--amber);
}

.wf-canvas-badge.disabled {
  color: var(--text-3);
  background: #ffffff0d;
}

.wf-canvas-spacer {
  flex: 1;
}

.wf-canvas-actions {
  display: flex;
  gap: 6px;
}

.wf-canvas-btn {
  border: 1px solid var(--border-2);
  background: var(--surface-3);
  color: var(--text-2);
  cursor: pointer;
  display: flex;
  font-size: 11px;
  font-weight: 500;
  font-family: var(--font-sans);
  border-radius: 7px;
  align-items:  center;
  gap: 5px;
  padding: 6px 14px;
  transition: color .15s, border-color .15s;
}

.wf-canvas-btn:hover {
  color: var(--text-1);
  border-color: var(--border-3);
}

.wf-canvas-btn.primary {
  color: var(--violet);
  background: #8b5cf62e;
  border-color: #8b5cf64d;
}

.wf-canvas-btn.primary:hover {
  background: #8b5cf640;
}

.wf-canvas-layout {
  display: flex;
  overflow: hidden;
  flex: 1;
}

.wf-palette {
  border-right: 1px solid var(--border-1);
  background: var(--surface-2);
  display: flex;
  flex-direction: column;
  width: 240px;
  min-width: 240px;
}

.wf-palette-header {
  display: flex;
  border-bottom: 1px solid var(--border-1);
  justify-content: space-between;
  align-items:  center;
  padding: 12px 14px;
}

.wf-palette-label {
  text-transform: uppercase;
  letter-spacing: .08em;
  color: var(--text-3);
  font-size: 10px;
  font-weight: 700;
}

.wf-palette-collapse {
  border: 1px solid var(--border-1);
  color: var(--text-3);
  cursor: pointer;
  display: flex;
  background: none;
  border-radius: 4px;
  justify-content: center;
  align-items:  center;
  width: 22px;
  height: 22px;
  padding: 0;
  transition: color .15s, border-color .15s;
  font-size: 10px;
}

.wf-palette-collapse:hover {
  color: var(--text-2);
  border-color: var(--border-2);
}

.wf-palette-search {
  background: var(--surface-3);
  border: 1px solid var(--border-1);
  color: var(--text-1);
  outline: none;
  font-size: 11px;
  font-family: var(--font-sans);
  border-radius: 6px;
  margin: 10px 12px;
  padding: 6px 10px;
  transition: border-color .15s;
}

.wf-palette-search:focus {
  border-color: #8b5cf64d;
}

.wf-palette-scroll {
  overflow-y: auto;
  flex: 1;
  padding: 0 0 12px;
}

.wf-palette-category {
  text-transform: uppercase;
  letter-spacing: .1em;
  color: var(--text-3);
  display: flex;
  cursor: pointer;
  user-select: none;
  justify-content: space-between;
  align-items:  center;
  padding: 8px 14px 4px;
  font-size: 9px;
  font-weight: 700;
}

.wf-palette-category:hover {
  color: var(--text-2);
}

.wf-palette-node {
  display: flex;
  cursor: grab;
  align-items:  center;
  gap: 10px;
  padding: 7px 14px;
  transition: background .1s;
}

.wf-palette-node:hover {
  background: #ffffff08;
}

.wf-palette-node:active {
  cursor: grabbing;
}

.wf-palette-node-icon {
  display: flex;
  border-radius: 7px;
  flex-shrink: 0;
  justify-content: center;
  align-items:  center;
  width: 28px;
  height: 28px;
  font-size: 13px;
}

.wf-palette-node-name {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  font-size: 12px;
  font-weight: 500;
}

.wf-palette-empty {
  text-align: center;
  color: var(--text-3);
  padding: 20px;
  font-size: 12px;
}

.wf-palette-collapsed {
  border-right: 1px solid var(--border-1);
  background: var(--surface-2);
  display: flex;
  flex-direction: column;
  align-items:  center;
  width: 32px;
  min-width: 32px;
  padding-top: 8px;
}

.wf-palette-expand {
  background: var(--surface-3);
  border: 1px solid var(--border-1);
  color: var(--text-3);
  cursor: pointer;
  display: flex;
  border-radius: 4px;
  justify-content: center;
  align-items:  center;
  width: 24px;
  height: 24px;
  padding: 0;
  transition: color .15s, border-color .15s;
  font-size: 10px;
}

.wf-palette-expand:hover {
  color: var(--text-2);
  border-color: var(--border-2);
}

.wf-canvas-center {
  position: relative;
  overflow: hidden;
  flex: 1;
}

.wf-canvas-center .react-flow__controls {
  background: var(--surface-2) !important;
  border: 1px solid var(--border-1) !important;
  box-shadow: none !important;
  border-radius: 8px !important;
}

.wf-canvas-center .react-flow__controls-button {
  background: var(--surface-2) !important;
  border-color: var(--border-1) !important;
  fill: var(--text-2) !important;
}

.wf-canvas-center .react-flow__controls-button:hover {
  background: var(--surface-3) !important;
  fill: var(--text-1) !important;
}

.wf-canvas-center .react-flow__minimap {
  background: var(--surface-2) !important;
  border: 1px solid var(--border-1) !important;
  border-radius: 8px !important;
}

.wf-right-panel {
  border-left: 1px solid var(--border-1);
  background: var(--surface-2);
  display: flex;
  flex-direction: column;
  width: 300px;
  min-width: 300px;
}

.wf-panel-tabs {
  display: flex;
  border-bottom: 1px solid var(--border-1);
  flex-shrink: 0;
  align-items:  center;
}

.wf-panel-tab {
  text-align: center;
  color: var(--text-3);
  cursor: pointer;
  font-size: 11px;
  font-weight: 500;
  font-family: var(--font-sans);
  background: none;
  border: none;
  border-bottom: 2px solid #0000;
  flex: 1;
  padding: 10px 0;
  transition: all .15s;
}

.wf-panel-tab:hover {
  color: var(--text-2);
}

.wf-panel-tab.active {
  color: var(--violet);
  border-bottom-color: var(--violet);
}

.wf-panel-collapse {
  background: var(--surface-3);
  border: 1px solid var(--border-1);
  color: var(--text-3);
  cursor: pointer;
  display: flex;
  border-radius: 4px;
  flex-shrink: 0;
  justify-content: center;
  align-items:  center;
  width: 22px;
  height: 22px;
  margin: 4px;
  padding: 0;
  transition: color .15s;
  font-size: 10px;
}

.wf-panel-collapse:hover {
  color: var(--text-2);
}

.wf-panel-body {
  overflow-y: auto;
  flex: 1;
  padding: 16px;
}

.wf-panel-section {
  margin-bottom: 16px;
}

.wf-panel-section-label {
  text-transform: uppercase;
  letter-spacing: .07em;
  color: var(--text-3);
  margin-bottom: 8px;
  font-size: 10px;
  font-weight: 600;
}

.wf-panel-field {
  display: flex;
  flex-direction: column;
  gap: 4px;
  margin-bottom: 12px;
}

.wf-panel-field label {
  color: var(--text-2);
  font-size: 11px;
  font-weight: 500;
}

.wf-panel-input {
  background: var(--surface-3);
  border: 1px solid var(--border-1);
  color: var(--text-1);
  outline: none;
  font-size: 12px;
  font-family: var(--font-sans);
  box-sizing: border-box;
  border-radius: 6px;
  width: 100%;
  padding: 7px 10px;
  transition: border-color .15s;
}

.wf-panel-input:focus {
  border-color: #8b5cf64d;
}

.wf-panel-input.mono {
  font-family: var(--font-mono);
  font-size: 11px;
}

.wf-panel-placeholder {
  color: var(--text-3);
  text-align: center;
  padding: 20px;
  font-size: 12px;
}

.wf-panel-node-header {
  display: flex;
  align-items:  center;
  gap: 8px;
  margin-bottom: 16px;
}

.wf-panel-node-icon {
  display: flex;
  border-radius: 7px;
  justify-content: center;
  align-items:  center;
  width: 28px;
  height: 28px;
  font-size: 13px;
}

.wf-panel-node-name {
  font-size: 13px;
  font-weight: 600;
}

.wf-panel-node-type {
  color: var(--text-3);
  font-size: 10px;
}

.wf-panel-divider {
  background: var(--border-1);
  height: 1px;
  margin-bottom: 16px;
}

.wf-panel-node-id {
  color: var(--text-3);
  margin-top: 8px;
  font-size: 9px;
}

.wf-panel-collapsed {
  border-left: 1px solid var(--border-1);
  background: var(--surface-2);
  display: flex;
  flex-direction: column;
  align-items:  center;
  width: 32px;
  min-width: 32px;
  padding-top: 8px;
}

.wf-exec-card {
  background: var(--surface-3);
  border: 1px solid var(--border-1);
  overflow: hidden;
  border-radius: 6px;
}

.wf-exec-header {
  display: flex;
  cursor: pointer;
  justify-content: space-between;
  align-items:  center;
  padding: 8px 12px;
  transition: background .1s;
  font-size: 12px;
}

.wf-exec-header:hover {
  background: #ffffff05;
}

.wf-exec-header-left, .wf-exec-header-right {
  display: flex;
  align-items:  center;
  gap: 8px;
}

.wf-exec-status-dot {
  border-radius: 50%;
  flex-shrink: 0;
  width: 8px;
  height: 8px;
}

.wf-exec-status-dot.running {
  animation: wf-pulse 1.5s infinite;
}

.wf-exec-version {
  color: var(--text-1);
  font-weight: 500;
}

.wf-exec-trigger, .wf-exec-duration {
  color: var(--text-3);
  font-size: 11px;
}

.wf-exec-expand-icon {
  color: var(--text-3);
  font-size: 10px;
}

.wf-exec-steps {
  border-top: 1px solid var(--border-1);
  padding: 8px 12px;
}

.wf-exec-step {
  display: flex;
  align-items:  center;
  gap: 8px;
  padding: 4px 0;
  font-size: 11px;
}

.wf-exec-step-dot {
  border-radius: 50%;
  flex-shrink: 0;
  width: 6px;
  height: 6px;
}

.wf-exec-step-name {
  color: var(--text-1);
  flex: 1;
}

.wf-exec-step-type {
  color: var(--text-3);
}

.wf-exec-step-retry {
  color: var(--amber);
  font-size: 10px;
}

.wf-exec-step-error {
  color: var(--rose);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  max-width: 120px;
  font-size: 10px;
}

.wf-exec-error-banner {
  border-top: 1px solid var(--border-1);
  color: var(--rose);
  background: #fb71850d;
  padding: 6px 12px;
  font-size: 11px;
}

.wf-version-card {
  background: var(--surface-3);
  border: 1px solid var(--border-1);
  border-radius: 6px;
  padding: 10px 12px;
}

.wf-version-header {
  display: flex;
  justify-content: space-between;
  align-items:  center;
}

.wf-version-badge {
  color: var(--text-1);
  font-size: 12px;
  font-weight: 600;
}

.wf-version-badge.latest {
  background: var(--violet-dim);
  border-radius: 4px;
  padding: 1px 6px;
}

.wf-version-latest-label {
  color: var(--violet);
  margin-left: 4px;
  font-size: 10px;
}

.wf-version-date {
  color: var(--text-3);
  font-size: 10px;
}

.wf-version-changelog {
  color: var(--text-2);
  margin-top: 4px;
  font-size: 11px;
}

.wf-version-stats {
  color: var(--text-3);
  margin-top: 4px;
  font-size: 10px;
}

.wf-version-diff-btn {
  border: 1px solid var(--border-1);
  color: var(--violet);
  cursor: pointer;
  font-size: 10px;
  font-family: var(--font-sans);
  background: none;
  border-radius: 4px;
  margin-top: 6px;
  padding: 2px 8px;
  transition: border-color .15s;
}

.wf-version-diff-btn:hover {
  border-color: #8b5cf64d;
}

.wf-chat {
  display: flex;
  flex-direction: column;
  height: 100%;
}

.wf-chat-header {
  border-bottom: 1px solid var(--border-1);
  color: var(--text-1);
  padding: 10px 12px;
  font-size: 12px;
  font-weight: 600;
}

.wf-chat-messages {
  overflow-y: auto;
  display: flex;
  flex-direction: column;
  flex: 1;
  gap: 8px;
  padding: 8px;
}

.wf-chat-empty {
  text-align: center;
  color: var(--text-3);
  padding: 16px;
  font-size: 11px;
}

.wf-chat-hint-btn {
  background: var(--surface-3);
  border: 1px solid var(--border-1);
  color: var(--text-2);
  cursor: pointer;
  text-align: left;
  font-size: 10px;
  font-family: var(--font-sans);
  border-radius: 4px;
  width: 100%;
  padding: 4px 8px;
  transition: border-color .15s;
}

.wf-chat-hint-btn:hover {
  border-color: var(--border-2);
}

.wf-chat-msg {
  border-radius: 8px;
  max-width: 85%;
  padding: 6px 10px;
  font-size: 11px;
  line-height: 1.4;
}

.wf-chat-msg.user {
  background: var(--violet-dim);
  color: var(--violet-bright);
  border: 1px solid #8b5cf633;
  align-self:  flex-end;
}

.wf-chat-msg.assistant {
  background: var(--surface-3);
  color: var(--text-1);
  border: 1px solid var(--border-1);
  align-self:  flex-start;
}

.wf-chat-msg.thinking {
  background: var(--surface-3);
  color: var(--text-3);
  border: 1px solid var(--border-1);
  align-self:  flex-start;
}

.wf-chat-input-area {
  border-top: 1px solid var(--border-1);
  display: flex;
  gap: 6px;
  padding: 8px;
}

.wf-chat-input {
  border: 1px solid var(--border-1);
  background: var(--surface-3);
  color: var(--text-1);
  outline: none;
  font-size: 11px;
  font-family: var(--font-sans);
  border-radius: 6px;
  flex: 1;
  padding: 6px 10px;
  transition: border-color .15s;
}

.wf-chat-input:focus {
  border-color: #8b5cf64d;
}

.wf-chat-send {
  background: var(--violet);
  color: #fff;
  cursor: pointer;
  font-size: 11px;
  font-family: var(--font-sans);
  border: none;
  border-radius: 6px;
  padding: 6px 12px;
  transition: opacity .15s;
}

.wf-chat-send:disabled {
  opacity: .5;
  cursor: not-allowed;
}

.wf-node {
  background: var(--surface-2, #0d0d14);
  border: 1.5px solid var(--border-2, #ffffff14);
  overflow: hidden;
  border-radius: 10px;
  min-width: 170px;
  transition: border-color .15s, box-shadow .15s;
}

.wf-node.selected {
  border-color: #8b5cf680;
  box-shadow: 0 0 0 3px #8b5cf61f;
}

.wf-node-header {
  display: flex;
  border-bottom: 1px solid var(--border-1, #ffffff0a);
  align-items:  center;
  gap: 8px;
  padding: 8px 12px;
}

.wf-node-header-icon {
  display: flex;
  border-radius: 6px;
  justify-content: center;
  align-items:  center;
  width: 22px;
  height: 22px;
  font-size: 11px;
}

.wf-node-header-label {
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  color: var(--text-1, #ffffffeb);
  flex: 1;
  font-size: 12px;
  font-weight: 600;
}

.wf-node-header-status {
  border-radius: 50%;
  width: 7px;
  height: 7px;
}

.wf-node-header-status.running {
  animation: wf-pulse 1.5s infinite;
}

.wf-node-body {
  padding: 8px 12px 10px;
}

.wf-node-field {
  color: var(--text-2, #ffffff8c);
  display: flex;
  gap: 6px;
  font-size: 10px;
  line-height: 1.4;
}

.wf-node-field-key {
  color: var(--text-3, #ffffff4d);
  min-width: 40px;
}

.wf-node-field-overflow {
  color: var(--text-3, #ffffff4d);
  font-size: 10px;
  font-style: italic;
}

@keyframes wf-pulse {
  0%, 100% {
    opacity: 1;
  }

  50% {
    opacity: .4;
  }
}

@keyframes wf-breathe {
  0%, 100% {
    transform: scale(1);
    opacity: .8;
  }

  50% {
    transform: scale(1.05);
    opacity: 1;
  }
}

/* ui/src/styles/agents.css */
.ag-page {
  --bg: #07070a;
  --surface-1: #0d0d14;
  --surface-2: #12121c;
  --surface-3: #1a1a28;
  --border-1: #ffffff0a;
  --border-2: #ffffff14;
  --text-1: #ffffffeb;
  --text-2: #ffffff8c;
  --text-3: #ffffff4d;
  --violet: #8b5cf6;
  --violet-dim: #8b5cf626;
  --blue: #60a5fa;
  --blue-dim: #60a5fa1f;
  --emerald: #34d399;
  --emerald-dim: #34d3991f;
  --amber: #fbbf24;
  --amber-dim: #fbbf241f;
  --rose: #fb7185;
  --rose-dim: #fb71851f;
  --cyan: #22d3ee;
  --cyan-dim: #22d3ee1a;
  display: flex;
  overflow: hidden;
  background: var(--surface-1);
  color: var(--text-1);
  -webkit-font-smoothing: antialiased;
  flex-direction: column;
  height: 100%;
  font-family: Inter, system-ui, -apple-system, BlinkMacSystemFont, Segoe UI, Roboto, Noto Sans, Ubuntu, Cantarell, Helvetica Neue, sans-serif;
}

.ag-header {
  display: flex;
  border-bottom: 1px solid var(--border-1);
  background: var(--surface-1);
  z-index: 200;
  position: relative;
  flex-shrink: 0;
  align-items:  center;
  gap: 14px;
  padding: 13px 28px;
}

.ag-header-title {
  letter-spacing: -.02em;
  font-size: 15px;
  font-weight: 700;
}

.ag-header-count {
  color: var(--text-3);
  background: var(--surface-3);
  border: 1px solid var(--border-2);
  border-radius: 20px;
  padding: 2px 9px;
  font-size: 11px;
  font-weight: 600;
}

.ag-header-spacer {
  flex: 1;
}

.ag-header-search-wrap {
  position: relative;
}

.ag-header-search-wrap svg {
  position: absolute;
  pointer-events: none;
  top: 50%;
  left: 10px;
  transform: translateY(-50%);
}

.ag-header-search {
  background: var(--surface-2);
  border: 1px solid var(--border-2);
  color: var(--text-1);
  outline: none;
  border-radius: 8px;
  width: 210px;
  padding: 7px 12px 7px 34px;
  transition: border-color .15s;
  font-family: Inter, system-ui, -apple-system, BlinkMacSystemFont, Segoe UI, Roboto, Noto Sans, Ubuntu, Cantarell, Helvetica Neue, sans-serif;
  font-size: 12px;
}

.ag-header-search::placeholder {
  color: var(--text-3);
}

.ag-header-search:focus {
  border-color: #8b5cf659;
}

.ag-spawn-btn {
  color: var(--violet);
  cursor: pointer;
  display: flex;
  background: #8b5cf62e;
  border: 1px solid #8b5cf652;
  border-radius: 8px;
  align-items:  center;
  gap: 7px;
  padding: 7px 16px;
  transition: background .15s, border-color .15s;
  font-family: Inter, system-ui, -apple-system, BlinkMacSystemFont, Segoe UI, Roboto, Noto Sans, Ubuntu, Cantarell, Helvetica Neue, sans-serif;
  font-size: 12px;
  font-weight: 600;
}

.ag-spawn-btn:hover {
  background: #8b5cf642;
  border-color: #8b5cf680;
}

.ag-stats-bar {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  border-bottom: 1px solid var(--border-1);
  z-index: 190;
  position: relative;
  flex-shrink: 0;
}

.ag-stat-card {
  background: var(--surface-1);
  border-right: 1px solid var(--border-1);
  display: flex;
  flex-direction: column;
  gap: 3px;
  padding: 13px 22px;
}

.ag-stat-card:last-child {
  border-right: none;
}

.ag-stat-label {
  text-transform: uppercase;
  letter-spacing: .08em;
  color: var(--text-3);
  font-size: 10px;
  font-weight: 600;
}

.ag-stat-value {
  letter-spacing: -.03em;
  font-size: 22px;
  font-weight: 700;
}

.ag-stat-value.cyan {
  color: var(--cyan);
}

.ag-stat-value.emerald {
  color: var(--emerald);
}

.ag-stat-value.violet {
  color: var(--violet);
}

.ag-stat-value.amber {
  color: var(--amber);
}

.ag-stat-sub {
  color: var(--text-3);
  font-size: 10px;
}

.ag-stat-sub .up {
  color: var(--emerald);
  font-weight: 600;
}

.ag-tab-bar {
  display: flex;
  background: var(--surface-1);
  border-bottom: 1px solid var(--border-1);
  z-index: 180;
  position: relative;
  flex-shrink: 0;
  align-items:  center;
  gap: 4px;
  padding: 0 28px;
}

.ag-tab-btn {
  display: flex;
  color: var(--text-3);
  cursor: pointer;
  position: relative;
  letter-spacing: -.01em;
  background: none;
  border: none;
  border-bottom: 2px solid #0000;
  align-items:  center;
  gap: 7px;
  margin-bottom: -1px;
  padding: 11px 16px;
  transition: color .15s, border-color .15s;
  font-family: Inter, system-ui, -apple-system, BlinkMacSystemFont, Segoe UI, Roboto, Noto Sans, Ubuntu, Cantarell, Helvetica Neue, sans-serif;
  font-size: 12px;
  font-weight: 600;
  top: 1px;
}

.ag-tab-btn:hover {
  color: var(--text-2);
}

.ag-tab-btn.active {
  color: var(--text-1);
  border-bottom-color: var(--violet);
}

.ag-tab-btn svg {
  flex-shrink: 0;
}

.ag-tab-badge {
  background: var(--surface-3);
  border: 1px solid var(--border-2);
  color: var(--text-3);
  border-radius: 10px;
  padding: 1px 7px;
  font-size: 10px;
  font-weight: 700;
}

.ag-tab-btn.active .ag-tab-badge {
  background: var(--violet-dim);
  color: var(--violet);
  border-color: #8b5cf640;
}

.ag-view {
  display: none;
  overflow: hidden;
  flex: 1;
}

.ag-view.visible {
  display: flex;
  flex-direction: column;
}

.ag-builder-shell {
  display: grid;
  grid-template-columns: 320px minmax(0, 1fr) 340px;
  flex: 1;
  gap: 0;
  min-height: 0;
}

.ag-builder-sidebar, .ag-builder-inspector {
  border-right: 1px solid var(--border-1);
  overflow-y: auto;
  background: linear-gradient(#0a0c14fa, #080a10fa);
  padding: 24px 22px;
}

.ag-builder-inspector {
  border-right: none;
  border-left: 1px solid var(--border-1);
}

.ag-builder-eyebrow {
  text-transform: uppercase;
  letter-spacing: .12em;
  color: var(--text-3);
  font-size: 10px;
  font-weight: 700;
}

.ag-builder-title {
  letter-spacing: -.03em;
  margin-top: 8px;
  font-size: 18px;
  font-weight: 700;
}

.ag-builder-copy {
  color: var(--text-2);
  margin-top: 10px;
  font-size: 12px;
  line-height: 1.7;
}

.ag-builder-stat-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 8px;
  margin-top: 18px;
}

.ag-builder-stat {
  border: 1px solid var(--border-2);
  color: var(--text-3);
  background: #ffffff05;
  border-radius: 12px;
  padding: 12px 10px;
  font-size: 11px;
}

.ag-builder-stat span {
  display: block;
  color: var(--text-1);
  margin-bottom: 4px;
  font-size: 18px;
  font-weight: 700;
}

.ag-builder-palette {
  display: flex;
  flex-direction: column;
  gap: 10px;
  margin-top: 20px;
}

.ag-builder-palette-item {
  border: 1px solid var(--border-2);
  color: var(--text-1);
  display: flex;
  cursor: pointer;
  text-align: left;
  background: #ffffff05;
  border-radius: 14px;
  align-items:  flex-start;
  gap: 10px;
  padding: 12px 13px;
  transition: border-color .15s, transform .15s, background .15s;
}

.ag-builder-palette-item:hover {
  background: #8b5cf614;
  border-color: #8b5cf647;
  transform: translateY(-1px);
}

.ag-builder-palette-item strong, .ag-builder-detail-card strong {
  display: block;
  font-size: 12px;
  font-weight: 600;
}

.ag-builder-palette-item small {
  display: block;
  color: var(--text-3);
  margin-top: 3px;
  font-size: 11px;
  line-height: 1.5;
}

.ag-builder-palette-dot {
  border-radius: 999px;
  flex-shrink: 0;
  width: 10px;
  height: 10px;
  margin-top: 4px;
  box-shadow: 0 0 14px;
}

.ag-builder-sidebar-foot {
  display: flex;
  flex-direction: column;
  gap: 10px;
  margin-top: 20px;
}

.ag-builder-action {
  cursor: pointer;
  border-radius: 10px;
  padding: 11px 14px;
  font-family: Inter, system-ui, -apple-system, BlinkMacSystemFont, Segoe UI, Roboto, Noto Sans, Ubuntu, Cantarell, Helvetica Neue, sans-serif;
  font-size: 12px;
  font-weight: 600;
}

.ag-builder-primary {
  color: #c7b6ff;
  background: #8b5cf626;
  border: 1px solid #8b5cf642;
}

.ag-builder-secondary {
  border: 1px solid var(--border-2);
  color: var(--text-2);
  background: none;
}

.ag-builder-main {
  display: flex;
  background: radial-gradient(circle at 0 0, #22d3ee14, #0000 30%), radial-gradient(circle at 100% 0, #8b5cf61a, #0000 34%), linear-gradient(#090b12, #07080d);
  flex-direction: column;
  min-width: 0;
  min-height: 0;
}

.ag-builder-toolbar {
  display: flex;
  border-bottom: 1px solid var(--border-1);
  flex-wrap: wrap;
  justify-content: space-between;
  align-items:  center;
  gap: 18px;
  padding: 22px 28px 18px;
}

.ag-builder-toolbar-badges {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.ag-builder-toolbar-badges span {
  border: 1px solid var(--border-2);
  letter-spacing: .06em;
  text-transform: uppercase;
  color: var(--text-3);
  background: #ffffff08;
  border-radius: 999px;
  padding: 5px 9px;
  font-size: 10px;
  font-weight: 700;
}

.ag-builder-canvas {
  position: relative;
  overflow: auto;
  background-image: linear-gradient(#ffffff09 1px, #0000 1px), linear-gradient(90deg, #ffffff09 1px, #0000 1px);
  background-size: 32px 32px;
  flex: 1;
  min-height: 0;
  padding: 36px;
}

.ag-builder-canvas-stage {
  position: relative;
  min-width: 100%;
  min-height: 100%;
}

.ag-builder-lines {
  position: absolute;
  pointer-events: auto;
  width: 100%;
  height: 100%;
  inset: 0;
}

.ag-builder-line {
  fill: none;
  stroke: #8b5cf673;
  stroke-width: 2;
  stroke-dasharray: 6 6;
  pointer-events: none;
}

.ag-builder-line.selected {
  stroke: #22d3eeeb;
  stroke-width: 3;
  stroke-dasharray: none;
}

.ag-builder-line-hit {
  fill: none;
  stroke: transparent;
  stroke-width: 18;
  cursor: pointer;
}

.ag-builder-line-label {
  fill: #ffffff57;
  text-anchor: middle;
  pointer-events: none;
  font-family: JetBrains Mono, monospace;
  font-size: 10px;
}

.ag-builder-node {
  position: absolute;
  cursor: pointer;
  text-align: left;
  color: var(--text-1);
  user-select: none;
  background: linear-gradient(#10141ffa, #0a0d14fa);
  border: 1px solid #ffffff14;
  border-radius: 18px;
  width: 220px;
  min-height: 112px;
  padding: 16px 16px 14px;
  transition: transform .16s, border-color .16s, box-shadow .16s;
  box-shadow: 0 18px 42px #00000047;
}

.ag-builder-node:hover, .ag-builder-node.selected {
  border-color: #8b5cf699;
  border-color: color-mix(in srgb, var(--node-accent) 60%, white 10%);
  box-shadow: 0 20px 52px #00000052, inset 0 0 0 1px #8b5cf657;
  box-shadow: 0 20px 52px #00000052, 0 0 0 1px color-mix(in srgb, var(--node-accent) 34%, transparent) inset;
  transform: translateY(-2px);
}

.ag-builder-node.connecting {
  border-color: #8b5cf6bd;
  border-color: color-mix(in srgb, var(--node-accent) 74%, white 8%);
  box-shadow: 0 22px 56px #0000005c, inset 0 0 0 1px #8b5cf68c;
  box-shadow: 0 22px 56px #0000005c, 0 0 0 1px color-mix(in srgb, var(--node-accent) 55%, transparent) inset;
}

.ag-builder-node-eyebrow {
  text-transform: uppercase;
  letter-spacing: .12em;
  color: color-mix(in srgb, var(--node-accent) 80%, white 10%);
  font-size: 10px;
}

.ag-builder-node-title {
  margin-top: 8px;
  font-size: 15px;
  font-weight: 700;
}

.ag-builder-node-subtitle {
  color: var(--text-2);
  margin-top: 6px;
  font-size: 11px;
  line-height: 1.5;
}

.ag-builder-node-chip {
  display: inline-flex;
  color: var(--text-2);
  background: #ffffff0a;
  border: 1px solid #ffffff0f;
  border-radius: 999px;
  margin-top: 10px;
  padding: 4px 8px;
  font-size: 10px;
}

.ag-builder-port {
  position: absolute;
  background: var(--node-accent);
  box-shadow: 0 0 18px #8b5cf68c;
  box-shadow: 0 0 18px color-mix(in srgb, var(--node-accent) 55%, transparent);
  cursor: crosshair;
  border: none;
  border-radius: 999px;
  width: 12px;
  height: 12px;
  padding: 0;
  top: 48px;
}

.ag-builder-port.in {
  left: -6px;
}

.ag-builder-port.out {
  right: -6px;
}

.ag-builder-field {
  display: flex;
  text-transform: uppercase;
  letter-spacing: .08em;
  color: var(--text-3);
  flex-direction: column;
  gap: 8px;
  margin-top: 16px;
  font-size: 11px;
  font-weight: 700;
}

.ag-builder-field input, .ag-builder-field select, .ag-builder-field textarea {
  border: 1px solid var(--border-2);
  color: var(--text-1);
  resize: vertical;
  background: #ffffff08;
  border-radius: 12px;
  padding: 11px 12px;
  font-size: 13px;
}

.ag-builder-field-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}

.ag-builder-detail-card {
  background: #60a5fa14;
  border: 1px solid #60a5fa2e;
  border-radius: 14px;
  margin-top: 18px;
  padding: 14px;
}

.ag-builder-empty-canvas {
  position: absolute;
  display: flex;
  text-align: center;
  flex-direction: column;
  justify-content: center;
  align-items:  center;
  padding: 40px;
  inset: 0;
}

.ag-builder-empty-title {
  letter-spacing: -.03em;
  color: var(--text-1);
  font-size: 24px;
  font-weight: 700;
}

.ag-builder-empty-copy {
  color: var(--text-2);
  max-width: 520px;
  margin-top: 10px;
  font-size: 13px;
  line-height: 1.8;
}

.ag-builder-empty-actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 12px;
  margin-top: 22px;
}

.ag-builder-inspector-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 18px;
}

.ag-builder-danger {
  color: #ff9fb0;
  background: #fb71851f;
  border: 1px solid #fb71853d;
}

.ag-builder-detail-card p {
  color: var(--text-2);
  margin: 8px 0;
  font-size: 12px;
  line-height: 1.6;
}

.ag-builder-detail-card span, .ag-builder-empty {
  color: var(--text-3);
  font-size: 11px;
  line-height: 1.6;
}

@media (max-width: 1320px) {
  .ag-builder-shell {
    grid-template-columns: 280px minmax(0, 1fr) 300px;
  }
}

@media (max-width: 1120px) {
  .ag-builder-shell {
    grid-template-columns: 1fr;
  }

  .ag-builder-sidebar, .ag-builder-inspector {
    border: none;
    border-bottom: 1px solid var(--border-1);
  }

  .ag-builder-inspector {
    border-top: 1px solid var(--border-1);
  }
}

@media (max-width: 760px) {
  .ag-builder-toolbar, .ag-builder-sidebar, .ag-builder-inspector {
    padding-left: 18px;
    padding-right: 18px;
  }

  .ag-builder-canvas {
    padding: 18px;
  }

  .ag-builder-field-grid {
    grid-template-columns: 1fr;
  }
}

.ag-grid-area {
  overflow-y: auto;
  flex: 1;
  padding: 20px 28px 56px;
}

.ag-grid-area::-webkit-scrollbar {
  width: 4px;
}

.ag-grid-area::-webkit-scrollbar-track {
  background: none;
}

.ag-grid-area::-webkit-scrollbar-thumb {
  background: var(--surface-3);
  border-radius: 2px;
}

.ag-section-label {
  text-transform: uppercase;
  letter-spacing: .1em;
  color: var(--text-3);
  display: flex;
  align-items:  center;
  gap: 8px;
  margin-bottom: 12px;
  font-size: 10px;
  font-weight: 600;
}

.ag-section-label:after {
  content: "";
  background: var(--border-1);
  flex: 1;
  height: 1px;
}

.ag-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
  gap: 10px;
  margin-bottom: 24px;
}

.ag-card {
  background: var(--surface-1);
  border: 1px solid var(--border-1);
  overflow: hidden;
  cursor: pointer;
  position: relative;
  animation: ag-fadeUp .4s ease both;
  border-radius: 12px;
  transition: border-color .2s, box-shadow .2s;
}

.ag-card:hover {
  border-color: #8b5cf638;
  box-shadow: 0 0 24px #8b5cf60f;
}

.ag-card.active-card {
  box-shadow: inset 3px 0 0 var(--cyan), 0 0 28px #22d3ee0f;
  border-color: #22d3ee33;
}

.ag-card.active-card:hover {
  box-shadow: inset 3px 0 0 var(--cyan), 0 0 32px #22d3ee1f;
  border-color: #22d3ee61;
}

.ag-card.primary-card {
  box-shadow: inset 3px 0 0 var(--violet), 0 0 28px #8b5cf614;
  border-color: #8b5cf64d;
}

.ag-card.primary-card:hover {
  box-shadow: inset 3px 0 0 var(--violet), 0 0 36px #8b5cf624;
}

.ag-card:first-child {
  animation-delay: 40ms;
}

.ag-card:nth-child(2) {
  animation-delay: 80ms;
}

.ag-card:nth-child(3) {
  animation-delay: .12s;
}

.ag-card:nth-child(4) {
  animation-delay: .16s;
}

.ag-card:nth-child(5) {
  animation-delay: .2s;
}

.ag-card:nth-child(6) {
  animation-delay: .24s;
}

.ag-card:nth-child(7) {
  animation-delay: .28s;
}

.ag-card:nth-child(8) {
  animation-delay: .32s;
}

.ag-card:nth-child(9) {
  animation-delay: .36s;
}

.ag-card:nth-child(10) {
  animation-delay: .4s;
}

.ag-card:nth-child(11) {
  animation-delay: .44s;
}

.ag-card:nth-child(12) {
  animation-delay: .48s;
}

.ag-card-body {
  display: flex;
  align-items:  flex-start;
  gap: 12px;
  padding: 15px 16px 12px;
}

.ag-avatar {
  display: flex;
  border-radius: 10px;
  flex-shrink: 0;
  justify-content: center;
  align-items:  center;
  width: 38px;
  height: 38px;
  font-size: 18px;
}

.ag-avatar-violet {
  background: #8b5cf62e;
}

.ag-avatar-blue {
  background: #60a5fa26;
}

.ag-avatar-emerald {
  background: #34d39926;
}

.ag-avatar-cyan {
  background: #22d3ee1f;
}

.ag-avatar-amber {
  background: #fbbf241f;
}

.ag-avatar-rose {
  background: #fb71851f;
}

.ag-card-info {
  flex: 1;
  min-width: 0;
}

.ag-card-name {
  letter-spacing: -.01em;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  margin-bottom: 4px;
  font-size: 13px;
  font-weight: 600;
}

.ag-card-task {
  color: var(--text-2);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  font-size: 11px;
  line-height: 1.45;
}

.ag-card-task.no-task {
  color: var(--text-3);
  font-style: italic;
}

.ag-status-badge {
  display: flex;
  text-transform: uppercase;
  letter-spacing: .06em;
  flex-shrink: 0;
  align-items:  center;
  gap: 5px;
  font-size: 10px;
  font-weight: 600;
}

.ag-status-dot {
  border-radius: 50%;
  flex-shrink: 0;
  width: 6px;
  height: 6px;
}

.ag-status-badge.active {
  color: var(--cyan);
}

.ag-status-badge.active .ag-status-dot {
  background: var(--cyan);
  box-shadow: 0 0 6px var(--cyan);
  animation: ag-dotPulse 2s ease-in-out infinite;
}

.ag-status-badge.primary-status {
  color: var(--violet);
}

.ag-status-badge.primary-status .ag-status-dot {
  background: var(--violet);
  box-shadow: 0 0 6px var(--violet);
  animation: ag-dotPulse 2s ease-in-out infinite;
}

.ag-status-badge.idle {
  color: var(--text-3);
}

.ag-status-badge.idle .ag-status-dot {
  background: var(--text-3);
}

.ag-card-footer {
  border-top: 1px solid var(--border-1);
  display: flex;
  align-items:  center;
  gap: 10px;
  padding: 10px 16px;
}

.ag-authority-bar {
  display: flex;
  align-items:  center;
  gap: 2px;
}

.ag-authority-pip {
  border-radius: 2px;
  width: 12px;
  height: 4px;
}

.ag-authority-pip.filled {
  background: var(--violet);
}

.ag-authority-pip.filled.cyan {
  background: var(--cyan);
}

.ag-authority-pip.empty {
  background: var(--border-2);
}

.ag-authority-label {
  color: var(--text-3);
  margin-left: 4px;
  font-size: 10px;
}

.ag-footer-spacer {
  flex: 1;
}

.ag-tools-badge {
  color: var(--text-3);
  background: var(--surface-2);
  border: 1px solid var(--border-1);
  border-radius: 4px;
  padding: 2px 8px;
  font-size: 10px;
}

.ag-since-label {
  color: var(--text-3);
  font-size: 10px;
}

.ag-activity-bar {
  background: var(--surface-1);
  border-top: 1px solid var(--border-1);
  display: flex;
  overflow: hidden;
  flex-shrink: 0;
  align-items:  center;
  height: 44px;
}

.ag-activity-label {
  text-transform: uppercase;
  letter-spacing: .1em;
  color: var(--text-3);
  border-right: 1px solid var(--border-1);
  display: flex;
  flex-shrink: 0;
  align-items:  center;
  height: 100%;
  padding: 0 16px;
  font-size: 10px;
  font-weight: 700;
}

.ag-activity-track {
  overflow: hidden;
  position: relative;
  flex: 1;
  height: 100%;
}

.ag-activity-scroll {
  display: flex;
  animation: ag-scrollFeed 40s linear infinite;
  white-space: nowrap;
  gap: 0;
  height: 100%;
}

.ag-activity-event {
  display: inline-flex;
  color: var(--text-2);
  border-right: 1px solid var(--border-1);
  flex-shrink: 0;
  align-items:  center;
  gap: 8px;
  height: 100%;
  padding: 0 24px;
  font-size: 11px;
}

.ag-event-dot {
  border-radius: 50%;
  flex-shrink: 0;
  width: 5px;
  height: 5px;
}

.ag-event-time {
  color: var(--text-3);
  font-variant-numeric: tabular-nums;
  font-size: 10px;
}

.ag-event-agent {
  color: var(--violet);
  font-weight: 600;
}

.ag-event-cyan {
  color: var(--cyan);
  font-weight: 600;
}

.ag-event-emerald {
  color: var(--emerald);
  font-weight: 600;
}

.ag-orbital-view {
  position: relative;
  overflow: hidden;
}

.ag-aurora {
  position: absolute;
  pointer-events: none;
  z-index: 0;
  inset: 0;
}

.ag-aurora:before {
  content: "";
  position: absolute;
  filter: blur(40px);
  background: radial-gradient(at 50% 0%, #8b5cf624 0%, #22d3ee0f 40%, #0000 70%);
  width: 900px;
  height: 500px;
  top: -120px;
  left: 50%;
  transform: translateX(-50%);
}

.ag-aurora:after {
  content: "";
  position: absolute;
  background-image: radial-gradient(circle, #ffffff07 1px, #0000 1px);
  background-size: 28px 28px;
  inset: 0;
}

.ag-orbital-canvas {
  position: absolute;
  z-index: 10;
  inset: 0 0 48px;
}

.ag-lines-svg {
  position: absolute;
  pointer-events: none;
  z-index: 1;
  overflow: visible;
  width: 100%;
  height: 100%;
  inset: 0;
}

.ag-orbit-ring-trace {
  position: absolute;
  pointer-events: none;
  border: 1px dashed #ffffff0d;
  border-radius: 50%;
  transform: translate(-50%, -50%);
}

.ag-center-orb {
  position: absolute;
  display: flex;
  cursor: pointer;
  z-index: 20;
  flex-direction: column;
  align-items:  center;
  transform: translate(-50%, -50%);
}

.ag-orb-cluster {
  position: relative;
  width: 80px;
  height: 80px;
}

.ag-orb-ring-outer {
  position: absolute;
  animation: ag-orbRotate 14s linear infinite reverse;
  border: 1px solid #8b5cf61f;
  border-radius: 50%;
}

.ag-orb-ring-inner {
  position: absolute;
  animation: ag-orbRotate 9s linear infinite;
  border: 1px solid #8b5cf638;
  border-radius: 50%;
}

.ag-orb-core {
  display: flex;
  animation: ag-orbPulse 4s ease-in-out infinite;
  position: relative;
  z-index: 2;
  background: radial-gradient(circle at 35% 35%, #a78bfa8c, #8b5cf647 60%, #0000);
  border: 2px solid #8b5cf68c;
  border-radius: 50%;
  justify-content: center;
  align-items:  center;
  width: 80px;
  height: 80px;
  font-size: 34px;
  box-shadow: 0 0 40px #8b5cf659, 0 0 80px #8b5cf624, inset 0 0 28px #8b5cf62e;
}

.ag-orb-label {
  letter-spacing: -.01em;
  margin-top: 12px;
  font-size: 12px;
  font-weight: 700;
}

.ag-orb-badge {
  text-transform: uppercase;
  letter-spacing: .1em;
  color: var(--violet);
  background: #8b5cf61f;
  border: 1px solid #8b5cf640;
  border-radius: 10px;
  margin-top: 4px;
  padding: 2px 9px;
  font-size: 9px;
  font-weight: 700;
}

.ag-orbital-node {
  position: absolute;
  display: flex;
  cursor: pointer;
  z-index: 20;
  flex-direction: column;
  align-items:  center;
  gap: 5px;
  transition: filter .2s;
  transform: translate(-50%, -50%);
}

.ag-orbital-node:hover {
  filter: brightness(1.15);
}

.ag-node-bubble {
  display: flex;
  position: relative;
  border: 2px solid #0000;
  border-radius: 50%;
  justify-content: center;
  align-items:  center;
  transition: box-shadow .2s, border-color .2s;
}

.ag-node-bubble.size-lg {
  width: 64px;
  height: 64px;
  font-size: 26px;
}

.ag-node-bubble.size-md {
  width: 48px;
  height: 48px;
  font-size: 20px;
}

.ag-node-bubble.size-sm {
  opacity: .45;
  width: 40px;
  height: 40px;
  font-size: 16px;
}

.ag-node-bubble.active-node {
  animation: ag-nodePulse 3s ease-in-out infinite;
  border-color: #22d3ee8c;
  box-shadow: 0 0 22px #22d3ee40, 0 0 44px #22d3ee1a;
}

.ag-node-bubble.idle-inner {
  opacity: .45;
  border-color: #ffffff14;
}

.ag-node-bubble.idle-outer {
  opacity: .3;
  border-color: #ffffff0d;
}

.ag-bubble-dot {
  position: absolute;
  border: 2px solid var(--bg, #07070a);
  border-radius: 50%;
  width: 10px;
  height: 10px;
  bottom: 2px;
  right: 2px;
}

.ag-bubble-dot.active {
  background: var(--cyan);
  box-shadow: 0 0 6px var(--cyan);
}

.ag-bubble-dot.idle {
  background: #ffffff40;
}

.ag-node-label {
  color: var(--text-2);
  text-align: center;
  white-space: nowrap;
  font-size: 10px;
  font-weight: 600;
}

.ag-node-label.dimmed {
  opacity: .45;
  font-size: 9px;
}

.ag-node-task-mini {
  color: var(--cyan);
  text-align: center;
  max-width: 90px;
  font-size: 9px;
  font-weight: 500;
  line-height: 1.35;
}

.ag-detail-card {
  position: absolute;
  z-index: 30;
  background: var(--surface-2);
  animation: ag-cardPop .25s cubic-bezier(.175, .885, .32, 1.275) both;
  border: 1px solid #8b5cf64d;
  border-radius: 14px;
  width: 248px;
  padding: 15px;
  box-shadow: 0 20px 60px #000000a6, 0 0 30px #8b5cf61a;
}

.ag-dc-header {
  display: flex;
  align-items:  center;
  gap: 10px;
  margin-bottom: 11px;
}

.ag-dc-emoji {
  display: flex;
  border-radius: 10px;
  flex-shrink: 0;
  justify-content: center;
  align-items:  center;
  width: 38px;
  height: 38px;
  font-size: 20px;
}

.ag-dc-name {
  font-size: 13px;
  font-weight: 700;
}

.ag-dc-status {
  display: flex;
  align-items:  center;
  gap: 5px;
  margin-top: 2px;
  font-size: 10px;
}

.ag-dc-dot {
  border-radius: 50%;
  width: 5px;
  height: 5px;
}

.ag-dc-dot.active {
  background: var(--cyan);
  box-shadow: 0 0 5px var(--cyan);
  animation: ag-dotPulse 2s infinite;
}

.ag-dc-section-label {
  text-transform: uppercase;
  letter-spacing: .08em;
  color: var(--text-3);
  margin-bottom: 4px;
  font-size: 10px;
  font-weight: 600;
}

.ag-dc-task {
  color: var(--text-2);
  margin-bottom: 10px;
  font-size: 11px;
  line-height: 1.5;
}

.ag-dc-auth {
  display: flex;
  align-items:  center;
  gap: 2px;
  margin-bottom: 10px;
}

.ag-dc-pip {
  border-radius: 2px;
  width: 14px;
  height: 3px;
}

.ag-dc-pip.on {
  background: var(--cyan);
}

.ag-dc-pip.off {
  background: var(--border-2);
}

.ag-dc-auth-val {
  color: var(--text-3);
  margin-left: 6px;
  font-size: 10px;
}

.ag-dc-tools {
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
}

.ag-dc-tool {
  background: var(--surface-3);
  border: 1px solid var(--border-2);
  color: var(--text-2);
  border-radius: 4px;
  padding: 2px 8px;
  font-size: 10px;
}

.ag-orbital-bottom {
  position: absolute;
  z-index: 50;
  display: flex;
  border-top: 1px solid var(--border-1);
  background: linear-gradient(to top, #07070af7 0%, #07070ad1 100%);
  align-items:  center;
  height: 48px;
  padding: 0 24px;
  bottom: 0;
  left: 0;
  right: 0;
}

.ag-bottom-stats {
  display: flex;
  flex-shrink: 0;
  gap: 20px;
}

.ag-bs-item {
  display: flex;
  flex-direction: column;
  gap: 0;
}

.ag-bs-val {
  letter-spacing: -.03em;
  font-size: 17px;
  font-weight: 700;
  line-height: 1.1;
}

.ag-bs-val.cyan {
  color: var(--cyan);
}

.ag-bs-val.emerald {
  color: var(--emerald);
}

.ag-bs-val.violet {
  color: var(--violet);
}

.ag-bs-val.amber {
  color: var(--amber);
}

.ag-bs-key {
  text-transform: uppercase;
  letter-spacing: .08em;
  color: var(--text-3);
  font-size: 9px;
  font-weight: 600;
}

.ag-bottom-divider {
  background: var(--border-1);
  width: 1px;
  height: 28px;
  margin: 0 18px;
}

.ag-ticker-wrap {
  overflow: hidden;
  position: relative;
  flex: 1;
}

.ag-ticker-label {
  text-transform: uppercase;
  letter-spacing: .1em;
  color: var(--text-3);
  margin-bottom: 2px;
  font-size: 9px;
  font-weight: 700;
}

.ag-ticker-scroll {
  white-space: nowrap;
  animation: ag-tickerScroll 32s linear infinite;
  color: var(--text-2);
  font-size: 11px;
}

.ag-ticker-sep {
  color: var(--text-3);
  margin: 0 12px;
}

.ag-ticker-violet {
  color: var(--violet);
  font-weight: 600;
}

.ag-ticker-cyan {
  color: var(--cyan);
  font-weight: 600;
}

.ag-ticker-emerald {
  color: var(--emerald);
  font-weight: 600;
}

@keyframes ag-dotPulse {
  0%, 100% {
    box-shadow: 0 0 6px;
    opacity: 1;
  }

  50% {
    box-shadow: 0 0 12px;
    opacity: .65;
  }
}

@keyframes ag-fadeUp {
  from {
    opacity: 0;
    transform: translateY(8px);
  }

  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@keyframes ag-scrollFeed {
  0% {
    transform: translateX(0);
  }

  100% {
    transform: translateX(-50%);
  }
}

@keyframes ag-orbPulse {
  0%, 100% {
    box-shadow: 0 0 40px #8b5cf659, 0 0 80px #8b5cf624, inset 0 0 28px #8b5cf62e;
  }

  50% {
    box-shadow: 0 0 60px #8b5cf680, 0 0 110px #8b5cf638, inset 0 0 38px #8b5cf642;
  }
}

@keyframes ag-nodePulse {
  0%, 100% {
    box-shadow: 0 0 22px #22d3ee40, 0 0 44px #22d3ee1a;
  }

  50% {
    box-shadow: 0 0 32px #22d3ee66, 0 0 64px #22d3ee2e;
  }
}

@keyframes ag-orbRotate {
  from {
    transform: translate(-50%, -50%)rotate(0);
  }

  to {
    transform: translate(-50%, -50%)rotate(360deg);
  }
}

@keyframes ag-tickerScroll {
  0% {
    transform: translateX(0);
  }

  100% {
    transform: translateX(-50%);
  }
}

@keyframes ag-cardPop {
  from {
    opacity: 0;
    transform: scale(.92)translateY(6px);
  }

  to {
    opacity: 1;
    transform: scale(1)translateY(0);
  }
}

.ag-spawn-toast {
  position: fixed;
  z-index: 310;
  color: var(--emerald);
  background: #34d3991a;
  border: 1px solid #34d39947;
  border-radius: 10px;
  max-width: 360px;
  padding: 10px 12px;
  font-size: 12px;
  top: 24px;
  right: 24px;
}

.ag-spawn-toast.error {
  color: var(--rose);
  background: #f871711a;
  border-color: #f8717147;
}

.ag-spawn-overlay {
  position: fixed;
  backdrop-filter: blur(8px);
  z-index: 300;
  display: flex;
  overflow-y: auto;
  background: #03060cb8;
  justify-content: center;
  align-items:  flex-start;
  padding: 20px;
  inset: 0;
}

.ag-spawn-dialog {
  outline: none;
  background: #090d16fa;
  border: 1px solid #ffffff14;
  border-radius: 18px;
  flex-shrink: 0;
  width: min(560px, 100%);
  margin: 40px 0;
  padding: 20px;
  box-shadow: 0 24px 80px #0006;
}

.ag-spawn-dialog-header {
  display: flex;
  justify-content: space-between;
  align-items:  flex-start;
  gap: 12px;
}

.ag-spawn-dialog-title {
  color: var(--text-1);
  font-size: 16px;
  font-weight: 600;
}

.ag-spawn-dialog-subtitle {
  color: var(--text-3);
  margin-top: 6px;
  font-size: 12px;
  line-height: 1.6;
}

.ag-spawn-dialog-close {
  color: var(--text-1);
  cursor: pointer;
  background: #ffffff0f;
  border: 1px solid #ffffff1f;
  border-radius: 999px;
  flex-shrink: 0;
  width: 32px;
  height: 32px;
  font-size: 18px;
  line-height: 1;
}

.ag-spawn-dialog-close:disabled {
  cursor: not-allowed;
  opacity: .6;
}

.ag-spawn-dialog-body {
  display: flex;
  flex-direction: column;
  gap: 14px;
  margin-top: 18px;
}

.ag-spawn-field-label {
  display: flex;
  color: var(--text-2);
  flex-direction: column;
  gap: 8px;
  font-size: 12px;
  font-weight: 600;
}

.ag-spawn-specialist-list {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.ag-spawn-specialist-btn {
  display: flex;
  color: var(--text-1);
  cursor: pointer;
  text-align: left;
  background: #ffffff08;
  border: 1px solid #ffffff14;
  border-radius: 10px;
  align-items:  center;
  gap: 10px;
  padding: 10px 12px;
  font-size: 13px;
  font-weight: 400;
}

.ag-spawn-specialist-btn.selected {
  background: #22d3ee1a;
  border-color: #22d3ee66;
  font-weight: 600;
}

.ag-spawn-specialist-meta {
  color: var(--text-3);
  margin-top: -6px;
  font-size: 11px;
  line-height: 1.5;
}

.ag-spawn-field-input {
  color: var(--text-1);
  --buncss-light: ;
  --buncss-dark: initial;
  color-scheme: dark;
  outline: none;
  resize: vertical;
  background: #ffffff08;
  border: 1px solid #ffffff14;
  border-radius: 10px;
  width: 100%;
  padding: 12px 14px;
  font-size: 13px;
}

.ag-spawn-dialog-footer {
  display: flex;
  justify-content: flex-end;
  gap: 10px;
  margin-top: 18px;
}

.ag-spawn-btn-primary, .ag-spawn-btn-secondary {
  cursor: pointer;
  border-radius: 10px;
  padding: 10px 14px;
  font-size: 12px;
}

.ag-spawn-btn-primary {
  color: var(--cyan);
  background: #22d3ee24;
  border: 1px solid #22d3ee3d;
  font-weight: 600;
}

.ag-spawn-btn-secondary {
  color: var(--text-2);
  background: none;
  border: 1px solid #ffffff14;
  font-weight: 500;
}

.ag-spawn-btn-primary:disabled, .ag-spawn-btn-secondary:disabled {
  cursor: not-allowed;
  opacity: .6;
}

/* ui/src/v2/rooms/workflows/WorkflowsRoom.css */
.v2-wf {
  display: flex;
  position: relative;
  flex-direction: column;
  height: 100%;
  min-height: 0;
}

.v2-wf__stats {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: var(--s-3);
  padding: var(--s-4) var(--s-6) var(--s-3);
}

@media (max-width: 720px) {
  .v2-wf__stats {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

.v2-wf__stat {
  background: var(--paper-2);
  border: 1px solid var(--rule-soft);
  border-radius: var(--r-2);
  padding: var(--s-3) var(--s-4);
  display: flex;
  flex-direction: column;
  gap: 2px;
  min-width: 0;
}

.v2-wf__stat-label {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--ink-3);
}

.v2-wf__stat-value {
  font-family: var(--font-display);
  font-size: var(--text-xl);
  color: var(--ink);
  line-height: 1.1;
}

.v2-wf__stat-sub {
  font-family: var(--font-sans);
  font-size: var(--text-xs);
  color: var(--ink-3);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.v2-wf__tabs {
  display: flex;
  gap: var(--s-1);
  padding: 0 var(--s-6);
  border-bottom: var(--hair-soft);
}

.v2-wf__tab {
  display: inline-flex;
  align-items:  center;
  gap: var(--s-2);
  padding: var(--s-3) var(--s-3);
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  color: var(--ink-3);
  cursor: pointer;
  transition: color var(--dur-fast) var(--ease-out), border-color var(--dur-fast) var(--ease-out);
  background: none;
  border: 0;
  border-bottom: 2px solid #0000;
  margin-bottom: -1px;
}

.v2-wf__tab:hover {
  color: var(--ink);
}

.v2-wf__tab[data-active="true"] {
  color: var(--ink);
  border-bottom-color: var(--accent);
}

.v2-wf__tab[data-disabled="true"] {
  opacity: .4;
  cursor: not-allowed;
}

.v2-wf__tab[data-disabled="true"]:hover {
  color: var(--ink-3);
}

.v2-wf__tab:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 2px;
  border-radius: var(--r-1);
}

.v2-wf__tab-badge {
  font-family: var(--font-mono);
  border-radius: var(--r-pill);
  background: var(--paper-3);
  color: var(--ink-3);
  letter-spacing: 0;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  max-width: 140px;
  padding: 1px 6px;
  font-size: 10px;
}

.v2-wf__tab[data-active="true"] .v2-wf__tab-badge {
  background: color-mix(in srgb, var(--accent) 14%, transparent);
  color: var(--accent);
}

.v2-wf__toolbar {
  display: flex;
  align-items:  center;
  gap: var(--s-2);
  padding: var(--s-3) var(--s-6);
  border-bottom: var(--hair-soft);
  flex-wrap: wrap;
}

.v2-wf__search {
  display: inline-flex;
  align-items:  center;
  gap: var(--s-2);
  background: var(--paper-2);
  border: 1px solid var(--rule);
  border-radius: var(--r-pill);
  color: var(--ink-3);
  flex: 1;
  min-width: 160px;
  max-width: 360px;
  padding: 6px 10px;
}

.v2-wf__search:focus-within {
  border-color: var(--ink-3);
  color: var(--ink-2);
}

.v2-wf__search-input {
  outline: 0;
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  color: var(--ink);
  background: none;
  border: 0;
  flex: 1;
}

.v2-wf__search-input::placeholder {
  color: var(--ink-3);
}

.v2-wf__filter-row {
  display: inline-flex;
  border: 1px solid var(--rule);
  border-radius: var(--r-pill);
  overflow: hidden;
  background: var(--paper);
  align-items:  center;
}

.v2-wf__filter-btn {
  font-family: var(--font-sans);
  font-size: var(--text-xs);
  color: var(--ink-3);
  cursor: pointer;
  transition: background var(--dur-fast) var(--ease-out), color var(--dur-fast) var(--ease-out);
  background: none;
  border: 0;
  padding: 4px 12px;
}

.v2-wf__filter-btn:hover {
  background: var(--paper-3);
  color: var(--ink);
}

.v2-wf__filter-btn[data-active="true"] {
  background: var(--ink);
  color: var(--paper);
}

.v2-wf__refresh, .v2-wf__new-btn {
  display: inline-flex;
  justify-content: center;
  align-items:  center;
  gap: var(--s-2);
  border-radius: var(--r-pill);
  cursor: pointer;
  transition: background var(--dur-fast) var(--ease-out), color var(--dur-fast) var(--ease-out);
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  height: 28px;
}

.v2-wf__refresh {
  border: 1px solid var(--rule);
  background: var(--paper);
  color: var(--ink-2);
  width: 28px;
}

.v2-wf__refresh:hover {
  background: var(--paper-3);
  color: var(--ink);
}

.v2-wf__new-btn {
  background: var(--ink);
  color: var(--paper);
  border: 0;
  padding: 0 12px;
}

.v2-wf__new-btn:hover {
  background: var(--ink-2);
}

.v2-wf__new-btn:disabled {
  opacity: .5;
  cursor: default;
}

.v2-wf__new-btn:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 2px;
}

.v2-wf__refresh:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 2px;
}

.v2-wf__list {
  list-style: none;
  overflow-y: auto;
  flex: 1;
  margin: 0;
  padding: 0;
}

.v2-wf__row {
  display: grid;
  grid-template-columns: 1fr auto auto auto;
  gap: var(--s-3);
  padding: var(--s-3) var(--s-6);
  border-bottom: var(--hair-soft);
  transition: background var(--dur-fast) var(--ease-out);
  align-items:  center;
}

.v2-wf__row:hover {
  background: var(--paper-2);
}

.v2-wf__row-main {
  display: flex;
  text-align: left;
  cursor: pointer;
  background: none;
  border: 0;
  flex-direction: column;
  gap: 2px;
  min-width: 0;
  padding: 4px 0;
}

.v2-wf__row-main:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 2px;
  border-radius: var(--r-1);
}

.v2-wf__row-name {
  font-family: var(--font-sans);
  font-size: var(--text-md);
  color: var(--ink);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  font-weight: 500;
}

.v2-wf__row-desc {
  font-family: var(--font-sans);
  font-size: var(--text-xs);
  color: var(--ink-2);
  display: -webkit-box;
  -webkit-line-clamp: 1;
  overflow: hidden;
  -webkit-box-orient: vertical;
}

.v2-wf__row-meta {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: var(--ink-3);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.v2-wf__row-action {
  display: inline-flex;
  background: var(--paper);
  border: 1px solid var(--rule);
  border-radius: var(--r-pill);
  font-family: var(--font-sans);
  font-size: var(--text-xs);
  color: var(--ink-2);
  cursor: pointer;
  transition: background var(--dur-fast) var(--ease-out), color var(--dur-fast) var(--ease-out);
  justify-content: center;
  align-items:  center;
  gap: 6px;
  height: 28px;
  padding: 0 10px;
}

.v2-wf__row-action:hover {
  background: var(--paper-3);
  color: var(--ink);
}

.v2-wf__row-action--primary {
  background: var(--ink);
  color: var(--paper);
  border-color: var(--ink);
}

.v2-wf__row-action--primary:hover {
  background: var(--ink-2);
}

.v2-wf__row-action:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 2px;
}

.v2-wf__editor {
  display: flex;
  flex-direction: column;
  flex: 1;
  min-height: 0;
}

.v2-wf__editor-head {
  display: flex;
  align-items:  center;
  gap: var(--s-3);
  padding: var(--s-3) var(--s-6);
  border-bottom: var(--hair-soft);
  background: var(--paper-2);
}

.v2-wf__editor-title {
  font-family: var(--font-display);
  font-size: var(--text-lg);
  color: var(--ink);
}

.v2-wf__editor-version, .v2-wf__editor-runs {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: var(--ink-3);
}

.v2-wf__editor-canvas {
  position: relative;
  overflow: hidden;
  flex: 1;
  min-height: 0;
}

.v2-wf__editor-canvas .wf-canvas-layout {
  position: absolute;
  inset: 0;
}

.v2-wf__editor-empty {
  display: flex;
  justify-content: center;
  align-items:  center;
  gap: var(--s-3);
  padding: var(--s-8);
  text-align: center;
  color: var(--ink-3);
  flex-direction: column;
  flex: 1;
}

.v2-wf__editor-empty h3 {
  font-family: var(--font-display);
  font-size: var(--text-xl);
  color: var(--ink);
  margin: 0;
}

.v2-wf__editor-empty p {
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  color: var(--ink-2);
  max-width: 360px;
  margin: 0;
}

.v2-wf__builder {
  position: relative;
  overflow: hidden;
  flex: 1;
  min-height: 0;
}

.v2-wf__builder > * {
  inset: 0;
  position: absolute !important;
}

.v2-wf__empty {
  padding: var(--s-8) var(--s-4);
  text-align: center;
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  color: var(--ink-3);
}

.v2-wf__error {
  padding: var(--s-3) var(--s-6);
  background: color-mix(in srgb, var(--accent) 8%, transparent);
  color: var(--accent);
  font-family: var(--font-sans);
  font-size: var(--text-xs);
  border-bottom: var(--hair-soft);
}

.v2-wf__toast {
  position: absolute;
  right: var(--s-4);
  bottom: var(--s-4);
  padding: var(--s-3) var(--s-4);
  background: var(--ink);
  color: var(--paper);
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  border-radius: var(--r-2);
  z-index: 5;
  max-width: 360px;
  box-shadow: 0 6px 20px -10px #1a1a1a66;
}

.v2-wf__toast[data-tone="warn"] {
  background: var(--accent);
}

.v2-wf--inline .v2-wf__stats {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  padding: var(--s-3) var(--s-4) var(--s-2);
}

.v2-wf--inline .v2-wf__toolbar {
  padding: var(--s-2) var(--s-4);
}

.v2-wf--inline .v2-wf__row {
  padding: var(--s-3) var(--s-4);
  grid-template-columns: 1fr auto;
}

.v2-wf--inline .v2-wf__row-action {
  display: none;
}

.v2-wf__editor-canvas, .v2-wf__builder {
  --surface-1: var(--paper);
  --surface-2: var(--paper-2);
  --surface-3: var(--paper-3);
  --surface-4: var(--paper-3);
  --border-1: var(--rule-soft);
  --border-2: var(--rule);
  --border-3: var(--rule);
  --text-1: var(--ink);
  --text-2: var(--ink-2);
  --text-3: var(--ink-3);
  --violet: var(--accent);
  --violet-bright: var(--accent);
  --violet-dim: color-mix(in srgb, var(--accent) 12%, transparent);
  --emerald: var(--ok);
  --emerald-dim: color-mix(in srgb, var(--ok) 12%, transparent);
  --blue: var(--ink-2);
  --blue-dim: color-mix(in srgb, var(--ink-2) 12%, transparent);
  --amber: var(--warn);
  --amber-dim: color-mix(in srgb, var(--warn) 12%, transparent);
  --rose: var(--accent);
  --rose-dim: color-mix(in srgb, var(--accent) 12%, transparent);
  --cyan: var(--ink-2);
  --cyan-dim: color-mix(in srgb, var(--ink-2) 10%, transparent);
  background: var(--paper);
  color: var(--ink);
}

.v2-wf__editor-canvas .react-flow, .v2-wf__editor-canvas .react-flow__background, .v2-wf__editor-canvas .react-flow__pane {
  background: var(--paper);
}

.v2-wf__editor-canvas .react-flow__background-pattern {
  color: var(--rule);
}

.v2-wf__editor-canvas .react-flow__controls, .v2-wf__editor-canvas .react-flow__minimap {
  background: var(--paper-2) !important;
  border: 1px solid var(--rule) !important;
  box-shadow: 0 4px 16px -10px #1a1a1a2e !important;
}

.v2-wf__editor-canvas .react-flow__controls-button {
  background: var(--paper-2) !important;
  border-color: var(--rule) !important;
  fill: var(--ink-2) !important;
  color: var(--ink-2) !important;
}

.v2-wf__editor-canvas .react-flow__controls-button:hover {
  background: var(--paper-3) !important;
  fill: var(--ink) !important;
  color: var(--ink) !important;
}

.v2-wf__editor-canvas .wf-node {
  background: var(--paper) !important;
  border: 1px solid var(--rule) !important;
  color: var(--ink) !important;
  border-radius: var(--r-2) !important;
  box-shadow: 0 4px 14px -10px #1a1a1a24 !important;
}

.v2-wf__editor-canvas .wf-node.selected {
  border-color: var(--accent) !important;
  box-shadow: 0 0 0 1px var(--accent), 0 4px 14px -10px #1a1a1a2e !important;
}

.v2-wf__editor-canvas .wf-node-header {
  border-bottom: 1px solid var(--rule-soft) !important;
}

.v2-wf__editor-canvas .wf-node-header-label {
  color: var(--ink) !important;
}

.v2-wf__editor-canvas .wf-node-body, .v2-wf__editor-canvas .wf-node-field, .v2-wf__editor-canvas .wf-node-field-key, .v2-wf__editor-canvas .wf-node-field-overflow {
  color: var(--ink-2) !important;
}

.v2-wf__editor-canvas .wf-node-field-key {
  color: var(--ink-3) !important;
}

.v2-wf__editor-canvas .react-flow__edge-path, .v2-wf__editor-canvas .react-flow__edge .react-flow__edge-path {
  stroke: var(--ink-3) !important;
  stroke-width: 1.5 !important;
}

.v2-wf__editor-canvas .react-flow__edge.animated .react-flow__edge-path, .v2-wf__editor-canvas .react-flow__edge[data-animated="true"] .react-flow__edge-path {
  stroke: var(--accent) !important;
  stroke-width: 2 !important;
}

.v2-wf__editor-canvas .react-flow__edge.selected .react-flow__edge-path {
  stroke: var(--ink) !important;
  stroke-width: 2 !important;
}

.v2-wf__editor-canvas .react-flow__connection-path {
  stroke: var(--accent) !important;
  stroke-width: 2 !important;
}

.v2-wf__editor-canvas .react-flow__handle {
  background: var(--ink-2) !important;
  border: 2px solid var(--paper) !important;
  width: 10px !important;
  height: 10px !important;
}

.v2-wf__editor-canvas .react-flow__handle-connecting {
  background: var(--accent) !important;
}

.v2-wf__editor-canvas .react-flow__handle-valid {
  background: var(--ok) !important;
}

.v2-wf__editor-canvas .wf-palette {
  background: var(--paper-2) !important;
  border-right-color: var(--rule) !important;
  color: var(--ink) !important;
}

.v2-wf__editor-canvas .wf-palette-header, .v2-wf__editor-canvas .wf-palette-search {
  border-color: var(--rule-soft) !important;
}

.v2-wf__editor-canvas .wf-palette-search {
  background: var(--paper) !important;
  color: var(--ink) !important;
}

.v2-wf__editor-canvas .wf-palette-search::placeholder {
  color: var(--ink-3) !important;
}

.v2-wf__editor-canvas .wf-palette-label, .v2-wf__editor-canvas .wf-palette-category {
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--ink-3) !important;
  font-family: var(--font-mono) !important;
}

.v2-wf__editor-canvas .wf-palette-node {
  color: var(--ink-2) !important;
  border-color: #0000 !important;
}

.v2-wf__editor-canvas .wf-palette-node:hover {
  background: var(--paper-3) !important;
  color: var(--ink) !important;
}

.v2-wf__editor-canvas .wf-palette-node-name {
  color: var(--ink) !important;
}

.v2-wf__editor-canvas .wf-palette-node-icon {
  background: var(--paper-3) !important;
  color: var(--ink-2) !important;
}

.v2-wf__editor-canvas .wf-palette-empty {
  color: var(--ink-3) !important;
}

.v2-wf__editor-canvas .wf-right-panel {
  background: var(--paper-2) !important;
  border-left-color: var(--rule) !important;
  color: var(--ink) !important;
}

.v2-wf__editor-canvas .wf-panel-tabs {
  border-bottom-color: var(--rule-soft) !important;
}

.v2-wf__editor-canvas .wf-panel-tab {
  color: var(--ink-3) !important;
  background: none !important;
}

.v2-wf__editor-canvas .wf-panel-tab:hover {
  color: var(--ink) !important;
  background: var(--paper-3) !important;
}

.v2-wf__editor-canvas .wf-panel-tab.active {
  color: var(--ink) !important;
  border-bottom: 2px solid var(--accent) !important;
}

.v2-wf__editor-canvas .wf-panel-placeholder {
  color: var(--ink-3) !important;
}

.v2-wf__editor-canvas .wf-canvas-badge.disabled {
  background: var(--paper-3) !important;
  color: var(--ink-3) !important;
}

.v2-wf__editor-canvas .wf-exec-header:hover {
  background: var(--paper-3) !important;
}

.v2-wf__builder .ag-builder-shell {
  height: 100%;
  background: var(--paper) !important;
  color: var(--ink) !important;
}

.v2-wf__builder .ag-builder-sidebar, .v2-wf__builder .ag-builder-inspector {
  background: var(--paper-2) !important;
  border-color: var(--rule) !important;
  color: var(--ink) !important;
}

.v2-wf__builder .ag-builder-title {
  color: var(--ink) !important;
}

.v2-wf__builder .ag-builder-eyebrow {
  color: var(--ink-3) !important;
}

.v2-wf__builder .ag-builder-copy {
  color: var(--ink-2) !important;
}

.v2-wf__builder .ag-builder-stat {
  background: var(--paper) !important;
  border-color: var(--rule-soft) !important;
}

.v2-wf__builder .ag-builder-stat span {
  color: var(--ink) !important;
}

.v2-wf__builder .ag-builder-stat strong {
  color: var(--ink-3) !important;
}

.v2-wf__builder .ag-builder-palette-item {
  background: var(--paper) !important;
  border-color: var(--rule) !important;
  color: var(--ink-2) !important;
}

.v2-wf__builder .ag-builder-palette-item:hover {
  background: color-mix(in srgb, var(--accent) 6%, var(--paper)) !important;
  border-color: var(--accent) !important;
}

.v2-wf__builder .ag-builder-palette-item strong {
  color: var(--ink) !important;
}

.v2-wf__builder .ag-builder-palette-item small {
  color: var(--ink-3) !important;
}

.v2-wf__builder .ag-builder-action {
  border-radius: var(--r-pill) !important;
  font-family: var(--font-sans) !important;
}

.v2-wf__builder .ag-builder-primary {
  background: var(--ink) !important;
  color: var(--paper) !important;
  border-color: var(--ink) !important;
}

.v2-wf__builder .ag-builder-secondary {
  background: var(--paper-2) !important;
  color: var(--ink-2) !important;
  border-color: var(--rule) !important;
}

.v2-wf__builder .ag-builder-canvas {
  background: var(--paper-2) !important;
}

.v2-wf__builder .ag-builder-canvas-stage {
  background: var(--paper) !important;
}

.v2-wf__builder .ag-builder-node {
  background: var(--paper) !important;
  border: 1px solid var(--rule) !important;
  color: var(--ink) !important;
  border-radius: var(--r-2) !important;
  box-shadow: 0 4px 14px -10px #1a1a1a29 !important;
}

.v2-wf__builder .ag-builder-node:hover, .v2-wf__builder .ag-builder-node.selected {
  border-color: var(--accent) !important;
  box-shadow: 0 4px 16px -10px #1a1a1a33, 0 0 0 1px var(--accent) inset !important;
}

.v2-wf__builder .ag-builder-node.connecting {
  border-color: var(--accent) !important;
  box-shadow: 0 0 0 2px var(--accent) inset !important;
}

.v2-wf__builder .ag-builder-node-eyebrow {
  color: var(--accent) !important;
  font-family: var(--font-mono) !important;
}

.v2-wf__builder .ag-builder-node-title {
  color: var(--ink) !important;
}

.v2-wf__builder .ag-builder-node-subtitle {
  color: var(--ink-2) !important;
}

.v2-wf__builder .ag-builder-node-chip {
  background: var(--paper-3) !important;
  color: var(--ink-2) !important;
}

.v2-wf__builder .ag-builder-line {
  stroke: var(--ink-3) !important;
  stroke-dasharray: 5 5 !important;
}

.v2-wf__builder .ag-builder-line.selected {
  stroke: var(--accent) !important;
  stroke-dasharray: none !important;
}

.v2-wf__builder .ag-builder-line-label {
  fill: var(--ink-3) !important;
}

.v2-wf__builder .ag-builder-empty-canvas, .v2-wf__builder .ag-builder-empty-title, .v2-wf__builder .ag-builder-empty-copy {
  color: var(--ink-2) !important;
}

.v2-wf__builder .ag-builder-empty-title {
  color: var(--ink) !important;
  font-family: var(--font-display) !important;
}

/* ui/src/v2/rooms/memory/MemoryRoom.css */
.v2-mem {
  display: flex;
  position: relative;
  flex-direction: column;
  height: 100%;
  min-height: 0;
}

.v2-mem__stats {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: var(--s-3);
  padding: var(--s-4) var(--s-6) var(--s-3);
}

@media (max-width: 720px) {
  .v2-mem__stats {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

.v2-mem__stat {
  background: var(--paper-2);
  border: 1px solid var(--rule-soft);
  border-radius: var(--r-2);
  padding: var(--s-3) var(--s-4);
  display: flex;
  flex-direction: column;
  gap: 2px;
  min-width: 0;
}

.v2-mem__stat-label {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--ink-3);
}

.v2-mem__stat-value {
  font-family: var(--font-display);
  font-size: var(--text-xl);
  color: var(--ink);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  line-height: 1.1;
}

.v2-mem__stat-sub {
  font-family: var(--font-sans);
  font-size: var(--text-xs);
  color: var(--ink-3);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.v2-mem__tabs {
  display: flex;
  gap: var(--s-1);
  padding: 0 var(--s-6);
  border-bottom: var(--hair-soft);
}

.v2-mem__tab {
  display: inline-flex;
  align-items:  center;
  gap: var(--s-2);
  padding: var(--s-3) var(--s-3);
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  color: var(--ink-3);
  cursor: pointer;
  transition: color var(--dur-fast) var(--ease-out), border-color var(--dur-fast) var(--ease-out);
  background: none;
  border: 0;
  border-bottom: 2px solid #0000;
  margin-bottom: -1px;
}

.v2-mem__tab:hover {
  color: var(--ink);
}

.v2-mem__tab[data-active="true"] {
  color: var(--ink);
  border-bottom-color: var(--accent);
}

.v2-mem__tab:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 2px;
  border-radius: var(--r-1);
}

.v2-mem__tab-badge {
  font-family: var(--font-mono);
  border-radius: var(--r-pill);
  background: var(--paper-3);
  color: var(--ink-3);
  padding: 1px 6px;
  font-size: 10px;
}

.v2-mem__tab[data-active="true"] .v2-mem__tab-badge {
  background: color-mix(in srgb, var(--accent) 14%, transparent);
  color: var(--accent);
}

.v2-mem__toolbar {
  display: flex;
  align-items:  center;
  gap: var(--s-2);
  padding: var(--s-3) var(--s-6);
  border-bottom: var(--hair-soft);
  flex-wrap: wrap;
}

.v2-mem__search {
  display: inline-flex;
  align-items:  center;
  gap: var(--s-2);
  background: var(--paper-2);
  border: 1px solid var(--rule);
  border-radius: var(--r-pill);
  color: var(--ink-3);
  flex: 1;
  min-width: 200px;
  max-width: 360px;
  padding: 6px 10px;
}

.v2-mem__search:focus-within {
  border-color: var(--ink-3);
  color: var(--ink-2);
}

.v2-mem__search-input {
  outline: 0;
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  color: var(--ink);
  background: none;
  border: 0;
  flex: 1;
}

.v2-mem__search-input::placeholder {
  color: var(--ink-3);
}

.v2-mem__filter-row {
  display: inline-flex;
  flex-wrap: wrap;
  align-items:  center;
  gap: 4px;
}

.v2-mem__filter-btn {
  display: inline-flex;
  background: var(--paper-2);
  border: 1px solid var(--rule);
  border-radius: var(--r-pill);
  color: var(--ink-2);
  font-family: var(--font-sans);
  font-size: var(--text-xs);
  cursor: pointer;
  transition: background var(--dur-fast) var(--ease-out), color var(--dur-fast) var(--ease-out), border-color var(--dur-fast) var(--ease-out);
  align-items:  center;
  gap: 6px;
  padding: 4px 10px;
}

.v2-mem__filter-btn:hover {
  background: var(--paper-3);
  color: var(--ink);
}

.v2-mem__filter-btn[data-active="true"] {
  background: var(--ink);
  color: var(--paper);
  border-color: var(--ink);
}

.v2-mem__filter-count {
  font-family: var(--font-mono);
  border-radius: var(--r-pill);
  background: color-mix(in srgb, currentColor 14%, transparent);
  padding: 0 4px;
  font-size: 10px;
}

.v2-mem__refresh {
  display: inline-flex;
  border: 1px solid var(--rule);
  border-radius: var(--r-pill);
  background: var(--paper);
  color: var(--ink-2);
  cursor: pointer;
  transition: background var(--dur-fast) var(--ease-out);
  justify-content: center;
  align-items:  center;
  width: 28px;
  height: 28px;
}

.v2-mem__refresh:hover {
  background: var(--paper-3);
  color: var(--ink);
}

.v2-mem__refresh:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 2px;
}

.v2-mem__constellation {
  display: grid;
  grid-template-columns: minmax(0, 1.6fr) minmax(0, 320px);
  flex: 1;
  min-height: 0;
}

@media (max-width: 900px) {
  .v2-mem__constellation {
    grid-template-columns: minmax(0, 1fr);
  }
}

.v2-mem__stage {
  position: relative;
  background: var(--paper-2);
  border-right: var(--hair-soft);
  overflow: hidden;
  cursor: grab;
  touch-action: none;
}

.v2-mem__stage[data-panning="true"] {
  cursor: grabbing;
}

.v2-mem__svg {
  display: block;
  user-select: none;
}

.v2-mem__viewport-controls {
  position: absolute;
  top: var(--s-3);
  right: var(--s-3);
  display: flex;
  align-items:  center;
  gap: var(--s-2);
  opacity: 0;
  pointer-events: none;
  transition: opacity var(--dur-fast) var(--ease-out);
  z-index: 2;
}

.v2-mem__viewport-controls[data-visible="true"] {
  opacity: 1;
  pointer-events: auto;
}

.v2-mem__zoom-badge {
  font-family: var(--font-mono);
  letter-spacing: .05em;
  background: var(--paper);
  border: 1px solid var(--rule);
  border-radius: var(--r-pill);
  color: var(--ink-2);
  padding: 2px 8px;
  font-size: 10px;
}

.v2-mem__reset-btn {
  display: inline-flex;
  background: var(--paper);
  border: 1px solid var(--rule);
  border-radius: var(--r-pill);
  font-family: var(--font-sans);
  font-size: var(--text-xs);
  color: var(--ink-2);
  cursor: pointer;
  transition: background var(--dur-fast) var(--ease-out), color var(--dur-fast) var(--ease-out);
  align-items:  center;
  gap: 4px;
  padding: 4px 10px;
}

.v2-mem__reset-btn:hover {
  background: var(--paper-3);
  color: var(--ink);
}

.v2-mem__reset-btn:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 2px;
}

.v2-mem__line {
  stroke: var(--rule);
  stroke-width: 1;
  stroke-dasharray: 2 4;
}

.v2-mem__node {
  cursor: pointer;
  transition: opacity var(--dur-fast) var(--ease-out);
}

.v2-mem__node-disc {
  fill: var(--ink-2);
  transition: fill var(--dur-fast) var(--ease-out);
}

.v2-mem__node[data-type="person"] .v2-mem__node-disc {
  fill: var(--ink-2);
}

.v2-mem__node[data-type="project"] .v2-mem__node-disc {
  fill: var(--accent);
}

.v2-mem__node[data-type="tool"] .v2-mem__node-disc {
  fill: var(--warn);
}

.v2-mem__node[data-type="place"] .v2-mem__node-disc {
  fill: var(--ok);
}

.v2-mem__node[data-type="concept"] .v2-mem__node-disc {
  fill: var(--ink);
}

.v2-mem__node[data-type="event"] .v2-mem__node-disc {
  fill: var(--ink-3);
}

.v2-mem__node[data-selected="true"] .v2-mem__node-disc {
  fill: var(--accent);
}

.v2-mem__node-glow {
  fill: color-mix(in srgb, var(--accent) 18%, transparent);
}

.v2-mem__node-label {
  font-family: var(--font-sans);
  fill: var(--ink-2);
  pointer-events: none;
  user-select: none;
  font-size: 11px;
}

.v2-mem__node[data-selected="true"] .v2-mem__node-label {
  fill: var(--ink);
  font-weight: 600;
}

.v2-mem__explorer {
  display: grid;
  grid-template-columns: minmax(0, 1.6fr) minmax(0, 320px);
  flex: 1;
  min-height: 0;
}

@media (max-width: 900px) {
  .v2-mem__explorer {
    grid-template-columns: minmax(0, 1fr);
  }
}

.v2-mem__grid {
  overflow-y: auto;
  padding: var(--s-4) var(--s-6);
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: var(--s-3);
  align-content:  start;
}

.v2-mem__card {
  background: var(--paper-2);
  border: 1px solid var(--rule-soft);
  border-radius: var(--r-2);
  padding: var(--s-3) var(--s-4);
  display: flex;
  gap: var(--s-2);
  cursor: pointer;
  transition: border-color var(--dur-fast) var(--ease-out), background var(--dur-fast) var(--ease-out);
  flex-direction: column;
}

.v2-mem__card:hover {
  border-color: var(--rule);
  background: var(--paper);
}

.v2-mem__card[data-active="true"] {
  border-color: var(--accent);
  background: color-mix(in srgb, var(--accent) 4%, var(--paper));
}

.v2-mem__card-head {
  display: flex;
  align-items:  flex-start;
  gap: var(--s-2);
}

.v2-mem__card-icon {
  border-radius: var(--r-2);
  background: var(--paper-3);
  color: var(--ink-2);
  display: inline-flex;
  justify-content: center;
  align-items:  center;
  width: 32px;
  height: 32px;
}

.v2-mem__card-id {
  display: flex;
  flex-direction: column;
  gap: 2px;
  min-width: 0;
}

.v2-mem__card-name {
  font-family: var(--font-sans);
  font-size: var(--text-md);
  color: var(--ink);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  font-weight: 500;
}

.v2-mem__card-type {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: var(--ink-3);
  text-transform: uppercase;
  letter-spacing: .05em;
}

.v2-mem__card-facts {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 4px;
  margin: 0;
  padding: 0;
}

.v2-mem__card-facts li {
  display: flex;
  gap: var(--s-2);
  font-family: var(--font-sans);
  font-size: var(--text-xs);
  color: var(--ink-2);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.v2-mem__card-pred {
  color: var(--ink-3);
  font-family: var(--font-mono);
  text-transform: uppercase;
  letter-spacing: .05em;
  font-size: 10px;
}

.v2-mem__card-obj {
  overflow: hidden;
  text-overflow: ellipsis;
  color: var(--ink);
  flex: 1;
  min-width: 0;
}

.v2-mem__card-rels {
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
}

.v2-mem__card-rel-chip {
  font-family: var(--font-mono);
  border-radius: var(--r-pill);
  background: var(--paper-3);
  color: var(--ink-2);
  padding: 1px 6px;
  font-size: 10px;
}

.v2-mem__card-foot {
  font-family: var(--font-mono);
  color: var(--ink-3);
  border-top: var(--hair-soft);
  padding-top: var(--s-2);
  font-size: 10px;
}

.v2-mem__browser {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1.4fr) minmax(0, 1fr);
  flex: 1;
  min-height: 0;
}

@media (max-width: 900px) {
  .v2-mem__browser {
    grid-template-columns: 1fr;
    grid-template-rows: 1fr 1fr 1fr;
  }
}

.v2-mem__col {
  display: flex;
  border-right: var(--hair-soft);
  flex-direction: column;
  min-height: 0;
}

.v2-mem__col:last-child {
  border-right: 0;
}

.v2-mem__col-head {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--ink-3);
  padding: var(--s-3) var(--s-4);
  border-bottom: var(--hair-soft);
  background: var(--paper-2);
}

.v2-mem__col-list {
  list-style: none;
  overflow-y: auto;
  flex: 1;
  margin: 0;
  padding: 0;
}

.v2-mem__col-row {
  display: flex;
  align-items:  center;
  gap: var(--s-2);
  padding: var(--s-2) var(--s-4);
  text-align: left;
  cursor: pointer;
  border: 0;
  border-bottom: var(--hair-soft);
  color: var(--ink-2);
  transition: background var(--dur-fast) var(--ease-out);
  background: none;
  width: 100%;
}

.v2-mem__col-row:hover {
  background: var(--paper-2);
}

.v2-mem__col-row[data-active="true"] {
  background: var(--paper-3);
  color: var(--ink);
}

.v2-mem__col-row-name {
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  flex: 1;
  min-width: 0;
}

.v2-mem__col-row-meta {
  font-family: var(--font-mono);
  color: var(--ink-3);
  text-transform: uppercase;
  letter-spacing: .05em;
  font-size: 10px;
}

.v2-mem__col-empty {
  padding: var(--s-6) var(--s-4);
  text-align: center;
  color: var(--ink-3);
  font-family: var(--font-sans);
  font-size: var(--text-sm);
}

.v2-mem__rel-arrow {
  color: var(--ink-3);
  font-family: var(--font-mono);
}

.v2-mem__detail {
  display: flex;
  background: var(--paper);
  flex-direction: column;
  min-height: 0;
}

.v2-mem__detail--empty {
  justify-content: center;
  align-items:  center;
  gap: var(--s-3);
  padding: var(--s-8);
  text-align: center;
  color: var(--ink-3);
}

.v2-mem__detail--empty p {
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  max-width: 220px;
  margin: 0;
}

.v2-mem__detail-head {
  display: flex;
  align-items:  flex-start;
  gap: var(--s-3);
  padding: var(--s-4) var(--s-5);
  border-bottom: var(--hair-soft);
}

.v2-mem__detail-icon {
  border-radius: var(--r-2);
  background: var(--paper-3);
  color: var(--ink-2);
  display: inline-flex;
  justify-content: center;
  align-items:  center;
  width: 36px;
  height: 36px;
}

.v2-mem__detail-name {
  font-family: var(--font-display);
  font-size: var(--text-lg);
  color: var(--ink);
}

.v2-mem__detail-tabs {
  display: flex;
  gap: var(--s-1);
  padding: 0 var(--s-5);
  border-bottom: var(--hair-soft);
}

.v2-mem__detail-tab {
  padding: var(--s-2) var(--s-3);
  font-family: var(--font-sans);
  font-size: var(--text-xs);
  color: var(--ink-3);
  cursor: pointer;
  background: none;
  border: 0;
  border-bottom: 2px solid #0000;
  margin-bottom: -1px;
}

.v2-mem__detail-tab:hover {
  color: var(--ink);
}

.v2-mem__detail-tab[data-active="true"] {
  color: var(--ink);
  border-bottom-color: var(--accent);
}

.v2-mem__detail-body {
  overflow-y: auto;
  padding: var(--s-3) var(--s-5);
  flex: 1;
}

.v2-mem__detail-empty {
  padding: var(--s-5) 0;
  text-align: center;
  color: var(--ink-3);
  font-family: var(--font-sans);
  font-size: var(--text-sm);
}

.v2-mem__detail-facts, .v2-mem__detail-rels {
  list-style: none;
  display: flex;
  gap: var(--s-2);
  flex-direction: column;
  margin: 0;
  padding: 0;
}

.v2-mem__fact {
  background: var(--paper-2);
  border: 1px solid var(--rule-soft);
  border-radius: var(--r-1);
  padding: var(--s-2) var(--s-3);
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.v2-mem__fact-pred {
  font-family: var(--font-mono);
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--ink-3);
  font-size: 10px;
}

.v2-mem__fact-obj {
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  color: var(--ink);
  word-wrap: break-word;
}

.v2-mem__fact-meta {
  font-family: var(--font-mono);
  color: var(--ink-3);
  font-size: 10px;
}

.v2-mem__detail-rel {
  display: flex;
  align-items:  center;
  gap: var(--s-2);
  padding: var(--s-2) var(--s-3);
  background: var(--paper-2);
  border: 1px solid var(--rule-soft);
  border-radius: var(--r-1);
  cursor: pointer;
  text-align: left;
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  color: var(--ink);
  width: 100%;
}

.v2-mem__detail-rel:hover {
  background: var(--paper-3);
}

.v2-mem__detail-rel-name {
  flex: 1;
}

.v2-mem__detail-rel-type {
  font-family: var(--font-mono);
  color: var(--ink-3);
  text-transform: uppercase;
  letter-spacing: .05em;
  font-size: 10px;
}

.v2-mem__empty {
  padding: var(--s-8) var(--s-4);
  text-align: center;
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  color: var(--ink-3);
}

.v2-mem__error {
  padding: var(--s-3) var(--s-6);
  background: color-mix(in srgb, var(--accent) 8%, transparent);
  color: var(--accent);
  font-family: var(--font-sans);
  font-size: var(--text-xs);
  border-bottom: var(--hair-soft);
}

.v2-mem__toast {
  position: absolute;
  right: var(--s-4);
  bottom: var(--s-4);
  padding: var(--s-3) var(--s-4);
  background: var(--ink);
  color: var(--paper);
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  border-radius: var(--r-2);
  z-index: 5;
  max-width: 360px;
  box-shadow: 0 6px 20px -10px #1a1a1a66;
}

.v2-mem__toast[data-tone="warn"] {
  background: var(--accent);
}

.v2-mem--inline .v2-mem__stats {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  padding: var(--s-3) var(--s-4) var(--s-2);
}

.v2-mem--inline .v2-mem__toolbar {
  padding: var(--s-2) var(--s-4);
}

.v2-mem--inline .v2-mem__constellation {
  grid-template-columns: minmax(0, 1fr);
}

.v2-mem--inline .v2-mem__detail {
  display: none;
}

/* ui/src/v2/rooms/authority/AuthorityRoom.css */
.v2-auth {
  display: flex;
  position: relative;
  flex-direction: column;
  height: 100%;
  min-height: 0;
}

.v2-auth__emergency {
  display: flex;
  justify-content: space-between;
  align-items:  center;
  gap: var(--s-3);
  padding: var(--s-2) var(--s-6);
  border-bottom: var(--hair);
  background: var(--paper-2);
  flex-wrap: wrap;
}

.v2-auth__emergency[data-state="paused"] {
  background: color-mix(in srgb, var(--warn) 10%, var(--paper-2));
  border-bottom-color: var(--warn);
}

.v2-auth__emergency[data-state="killed"] {
  background: color-mix(in srgb, var(--accent) 10%, var(--paper-2));
  border-bottom-color: var(--accent);
}

.v2-auth__emergency-meta {
  display: inline-flex;
  align-items:  center;
  gap: var(--s-2);
}

.v2-auth__emergency-dot {
  border-radius: var(--r-pill);
  background: var(--ok);
  width: 8px;
  height: 8px;
}

.v2-auth__emergency[data-state="paused"] .v2-auth__emergency-dot {
  background: var(--warn);
  animation: v2-auth-pulse 1.6s ease-in-out infinite;
}

.v2-auth__emergency[data-state="killed"] .v2-auth__emergency-dot {
  background: var(--accent);
  animation: v2-auth-pulse 1s ease-in-out infinite;
}

@keyframes v2-auth-pulse {
  0%, 100% {
    opacity: 1;
    transform: scale(1);
  }

  50% {
    opacity: .5;
    transform: scale(1.4);
  }
}

@media (prefers-reduced-motion: reduce) {
  .v2-auth__emergency-dot {
    animation: none !important;
  }
}

.v2-auth__emergency-label {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--ink-2);
}

.v2-auth__emergency[data-state="paused"] .v2-auth__emergency-label {
  color: var(--warn);
}

.v2-auth__emergency[data-state="killed"] .v2-auth__emergency-label {
  color: var(--accent);
}

.v2-auth__emergency-actions {
  display: inline-flex;
  align-items:  center;
  gap: var(--s-2);
}

.v2-auth__emergency-btn {
  display: inline-flex;
  background: var(--paper);
  border: 1px solid var(--rule);
  border-radius: var(--r-pill);
  font-family: var(--font-sans);
  font-size: var(--text-xs);
  color: var(--ink-2);
  cursor: pointer;
  transition: background var(--dur-fast) var(--ease-out), color var(--dur-fast) var(--ease-out);
  align-items:  center;
  gap: 4px;
  padding: 4px 10px;
}

.v2-auth__emergency-btn:hover {
  background: var(--paper-3);
  color: var(--ink);
}

.v2-auth__emergency-btn--danger {
  background: var(--accent);
  color: var(--accent-ink);
  border-color: var(--accent);
}

.v2-auth__emergency-btn--danger:hover {
  background: var(--accent);
  filter: brightness(.9);
}

.v2-auth__emergency-btn:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 2px;
}

.v2-auth__stats {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: var(--s-3);
  padding: var(--s-4) var(--s-6) var(--s-3);
}

@media (max-width: 720px) {
  .v2-auth__stats {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

.v2-auth__stat {
  background: var(--paper-2);
  border: 1px solid var(--rule-soft);
  border-radius: var(--r-2);
  padding: var(--s-3) var(--s-4);
  display: flex;
  flex-direction: column;
  gap: 2px;
  min-width: 0;
}

.v2-auth__stat[data-tone="accent"] {
  border-color: var(--accent);
}

.v2-auth__stat[data-tone="warn"] {
  border-color: var(--warn);
}

.v2-auth__stat-label {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--ink-3);
}

.v2-auth__stat-value {
  font-family: var(--font-display);
  font-size: var(--text-xl);
  color: var(--ink);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  line-height: 1.1;
}

.v2-auth__stat[data-tone="accent"] .v2-auth__stat-value {
  color: var(--accent);
}

.v2-auth__stat-sub {
  font-family: var(--font-sans);
  font-size: var(--text-xs);
  color: var(--ink-3);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.v2-auth__tabs {
  display: flex;
  gap: var(--s-1);
  padding: 0 var(--s-6);
  border-bottom: var(--hair-soft);
  align-items: stretch;
}

.v2-auth__tab {
  display: inline-flex;
  align-items:  center;
  gap: var(--s-2);
  padding: var(--s-3) var(--s-3);
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  color: var(--ink-3);
  cursor: pointer;
  transition: color var(--dur-fast) var(--ease-out), border-color var(--dur-fast) var(--ease-out);
  background: none;
  border: 0;
  border-bottom: 2px solid #0000;
  margin-bottom: -1px;
}

.v2-auth__tab:hover {
  color: var(--ink);
}

.v2-auth__tab[data-active="true"] {
  color: var(--ink);
  border-bottom-color: var(--accent);
}

.v2-auth__tab:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 2px;
  border-radius: var(--r-1);
}

.v2-auth__tab-badge {
  font-family: var(--font-mono);
  border-radius: var(--r-pill);
  background: var(--paper-3);
  color: var(--ink-3);
  padding: 1px 6px;
  font-size: 10px;
}

.v2-auth__tab-badge[data-tone="accent"] {
  background: color-mix(in srgb, var(--accent) 14%, transparent);
  color: var(--accent);
}

.v2-auth__refresh {
  display: inline-flex;
  border: 1px solid var(--rule);
  border-radius: var(--r-pill);
  background: var(--paper);
  color: var(--ink-2);
  cursor: pointer;
  transition: background var(--dur-fast) var(--ease-out);
  justify-content: center;
  align-self:  center;
  align-items:  center;
  width: 28px;
  height: 28px;
  margin-left: auto;
}

.v2-auth__refresh:hover {
  background: var(--paper-3);
  color: var(--ink);
}

.v2-auth__refresh:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 2px;
}

.v2-auth__section {
  display: flex;
  gap: var(--s-2);
  padding: var(--s-4) var(--s-6);
  border-bottom: var(--hair-soft);
  flex-direction: column;
}

.v2-auth__section-head {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: var(--s-3);
}

.v2-auth__section-title {
  font-family: var(--font-display);
  font-size: var(--text-lg);
  color: var(--ink);
  margin: 0;
}

.v2-auth__section-count {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: var(--ink-3);
}

.v2-auth__section-desc {
  font-family: var(--font-sans);
  font-size: var(--text-xs);
  color: var(--ink-3);
  line-height: var(--lh-body);
  margin: 0;
}

.v2-auth__approvals {
  overflow-y: auto;
  display: flex;
  flex-direction: column;
  flex: 1;
}

.v2-auth__pending-list, .v2-auth__history-list, .v2-auth__suggestions {
  list-style: none;
  display: flex;
  gap: var(--s-2);
  flex-direction: column;
  margin: 0;
  padding: 0;
}

.v2-auth__pending {
  background: var(--paper-2);
  border: 1px solid var(--rule);
  border-radius: var(--r-2);
  padding: var(--s-3) var(--s-4);
  display: flex;
  gap: var(--s-2);
  flex-direction: column;
}

.v2-auth__pending[data-tone="accent"] {
  border-color: var(--accent);
}

.v2-auth__pending[data-tone="warn"] {
  border-color: var(--warn);
}

.v2-auth__pending[data-urgency="urgent"] {
  box-shadow: 0 0 0 1px var(--accent) inset;
}

.v2-auth__pending-head {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: var(--s-3);
}

.v2-auth__pending-meta {
  display: inline-flex;
  align-items:  center;
  gap: var(--s-2);
}

.v2-auth__pending-urgent {
  font-family: var(--font-mono);
  border-radius: var(--r-pill);
  background: var(--accent);
  color: var(--accent-ink);
  letter-spacing: .1em;
  padding: 2px 6px;
  font-size: 10px;
}

.v2-auth__pending-time {
  font-family: var(--font-mono);
  color: var(--ink-3);
  font-size: 10px;
}

.v2-auth__pending-agent {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: var(--ink-3);
}

.v2-auth__pending-intent {
  font-family: var(--font-display);
  font-size: var(--text-md);
  color: var(--ink);
  line-height: 1.4;
}

.v2-auth__pending-meta-row {
  display: flex;
  gap: var(--s-3);
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: var(--ink-3);
}

.v2-auth__pending-tool {
  color: var(--ink-2);
}

.v2-auth__pending-actions {
  display: flex;
  gap: var(--s-2);
  margin-top: var(--s-2);
  padding-top: var(--s-2);
  border-top: var(--hair-soft);
  justify-content: flex-end;
}

.v2-auth__history-row {
  display: grid;
  grid-template-columns: 60px 1fr 1.4fr auto;
  gap: var(--s-3);
  padding: var(--s-2) var(--s-3);
  background: var(--paper-2);
  border-radius: var(--r-1);
  font-family: var(--font-sans);
  font-size: var(--text-xs);
  align-items:  center;
}

.v2-auth__history-time {
  font-family: var(--font-mono);
  color: var(--ink-3);
}

.v2-auth__history-agent {
  color: var(--ink-2);
}

.v2-auth__history-tool {
  color: var(--ink);
  font-family: var(--font-mono);
}

.v2-auth__audit {
  overflow-y: auto;
  display: flex;
  gap: var(--s-3);
  padding: var(--s-4) var(--s-6);
  flex-direction: column;
  flex: 1;
}

.v2-auth__audit-stats {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: var(--s-3);
}

@media (max-width: 720px) {
  .v2-auth__audit-stats {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

.v2-auth__filter-row {
  display: flex;
  align-items:  center;
  gap: var(--s-2);
  flex-wrap: wrap;
}

.v2-auth__filter-btn {
  background: var(--paper-2);
  border: 1px solid var(--rule);
  border-radius: var(--r-pill);
  color: var(--ink-2);
  font-family: var(--font-sans);
  font-size: var(--text-xs);
  cursor: pointer;
  transition: background var(--dur-fast) var(--ease-out), color var(--dur-fast) var(--ease-out);
  padding: 4px 12px;
}

.v2-auth__filter-btn:hover {
  background: var(--paper-3);
  color: var(--ink);
}

.v2-auth__filter-btn[data-active="true"] {
  background: var(--ink);
  color: var(--paper);
  border-color: var(--ink);
}

.v2-auth__filter-meta {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: var(--ink-3);
  margin-left: auto;
}

.v2-auth__audit-list {
  list-style: none;
  display: flex;
  flex-direction: column;
  margin: 0;
  padding: 0;
}

.v2-auth__audit-row {
  display: grid;
  grid-template-columns: 60px auto 1fr 1.4fr 1fr auto;
  gap: var(--s-3);
  padding: var(--s-2) var(--s-3);
  border-bottom: var(--hair-soft);
  font-family: var(--font-sans);
  font-size: var(--text-xs);
  align-items:  center;
}

.v2-auth__audit-time {
  font-family: var(--font-mono);
  color: var(--ink-3);
}

.v2-auth__audit-agent {
  color: var(--ink-2);
}

.v2-auth__audit-tool {
  color: var(--ink);
  font-family: var(--font-mono);
}

.v2-auth__audit-cat, .v2-auth__audit-ms {
  color: var(--ink-3);
  font-family: var(--font-mono);
}

.v2-auth__grants {
  overflow-y: auto;
  flex: 1;
}

.v2-auth__slider {
  appearance: none;
  border-radius: var(--r-pill);
  background: var(--paper-3);
  outline: none;
  margin: var(--s-2) 0;
  width: 100%;
  height: 6px;
}

.v2-auth__slider::-webkit-slider-thumb {
  appearance: none;
  border-radius: var(--r-pill);
  background: var(--ink);
  border: 2px solid var(--paper);
  cursor: pointer;
  box-shadow: 0 0 0 1px var(--ink);
  width: 16px;
  height: 16px;
}

.v2-auth__slider[data-zone="ok"]::-webkit-slider-thumb {
  background: var(--ok);
  box-shadow: 0 0 0 1px var(--ok);
}

.v2-auth__slider[data-zone="warn"]::-webkit-slider-thumb {
  background: var(--warn);
  box-shadow: 0 0 0 1px var(--warn);
}

.v2-auth__slider[data-zone="accent"]::-webkit-slider-thumb {
  background: var(--accent);
  box-shadow: 0 0 0 1px var(--accent);
}

.v2-auth__slider::-moz-range-thumb {
  border-radius: var(--r-pill);
  background: var(--ink);
  border: 2px solid var(--paper);
  cursor: pointer;
  width: 16px;
  height: 16px;
}

.v2-auth__slider:disabled {
  opacity: .4;
  cursor: default;
}

.v2-auth__slider-scale {
  display: flex;
  font-family: var(--font-mono);
  color: var(--ink-3);
  letter-spacing: .05em;
  justify-content: space-between;
  font-size: 10px;
}

.v2-auth__chip-row {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.v2-auth__chip {
  background: var(--paper-2);
  border: 1px solid var(--rule);
  border-radius: var(--r-pill);
  font-family: var(--font-sans);
  font-size: var(--text-xs);
  color: var(--ink-2);
  cursor: pointer;
  transition: background var(--dur-fast) var(--ease-out), color var(--dur-fast) var(--ease-out), border-color var(--dur-fast) var(--ease-out);
  padding: 4px 12px;
}

.v2-auth__chip:hover {
  background: var(--paper-3);
  color: var(--ink);
}

.v2-auth__chip[data-active="true"] {
  background: var(--ink);
  color: var(--paper);
  border-color: var(--ink);
}

.v2-auth__table {
  border-collapse: collapse;
  font-family: var(--font-sans);
  font-size: var(--text-xs);
  margin-top: var(--s-2);
  width: 100%;
}

.v2-auth__table th, .v2-auth__table td {
  padding: var(--s-2) var(--s-3);
  border-bottom: var(--hair-soft);
  text-align: left;
}

.v2-auth__table th {
  font-family: var(--font-mono);
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--ink-3);
  font-size: 10px;
  font-weight: 500;
}

.v2-auth__table td {
  color: var(--ink-2);
  vertical-align: middle;
}

.v2-auth__table em {
  color: var(--ink-3);
  font-style: italic;
}

.v2-auth__icon-btn {
  display: inline-flex;
  border-radius: var(--r-1);
  color: var(--ink-3);
  cursor: pointer;
  transition: background var(--dur-fast) var(--ease-out), color var(--dur-fast) var(--ease-out);
  background: none;
  border: 0;
  justify-content: center;
  align-items:  center;
  width: 24px;
  height: 24px;
}

.v2-auth__icon-btn:hover {
  background: var(--paper-3);
  color: var(--accent);
}

.v2-auth__add-row {
  display: flex;
  align-items:  center;
  gap: var(--s-2);
  margin-top: var(--s-3);
  padding-top: var(--s-3);
  border-top: var(--hair-soft);
}

.v2-auth__select {
  background: var(--paper);
  border: 1px solid var(--rule);
  border-radius: var(--r-pill);
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  color: var(--ink);
  flex: 1;
  padding: 6px 10px;
}

.v2-auth__select:focus {
  outline: 2px solid var(--accent);
  outline-offset: -2px;
}

.v2-auth__learning {
  overflow-y: auto;
  flex: 1;
}

.v2-auth__threshold-row {
  display: flex;
  gap: var(--s-2);
  flex-direction: column;
}

.v2-auth__label {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  letter-spacing: .05em;
  color: var(--ink-2);
}

.v2-auth__suggestion {
  background: var(--paper-2);
  border: 1px solid var(--rule);
  border-radius: var(--r-2);
  padding: var(--s-3) var(--s-4);
  display: flex;
  gap: var(--s-2);
  flex-direction: column;
}

.v2-auth__suggestion-meta {
  display: flex;
  align-items:  center;
  gap: var(--s-3);
}

.v2-auth__suggestion-tool {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: var(--ink-2);
}

.v2-auth__suggestion-text {
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  color: var(--ink);
  line-height: var(--lh-body);
}

.v2-auth__suggestion-text code {
  font-family: var(--font-mono);
  background: var(--paper-3);
  border-radius: var(--r-1);
  padding: 1px 6px;
  font-size: .92em;
}

.v2-auth__suggestion-actions {
  display: flex;
  gap: var(--s-2);
  justify-content: flex-end;
}

.v2-auth__btn {
  display: inline-flex;
  border-radius: var(--r-pill);
  font-family: var(--font-sans);
  font-size: var(--text-xs);
  cursor: pointer;
  border: 1px solid var(--rule);
  transition: background var(--dur-fast) var(--ease-out), color var(--dur-fast) var(--ease-out);
  align-items:  center;
  gap: 4px;
  padding: 5px 12px;
}

.v2-auth__btn--secondary {
  background: var(--paper);
  color: var(--ink-2);
}

.v2-auth__btn--secondary:hover {
  background: var(--paper-3);
  color: var(--ink);
}

.v2-auth__btn--primary {
  background: var(--accent);
  color: var(--accent-ink);
  border-color: var(--accent);
}

.v2-auth__btn--primary:hover {
  filter: brightness(.92);
}

.v2-auth__btn:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 2px;
}

.v2-auth__empty {
  padding: var(--s-6) var(--s-4);
  text-align: center;
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  color: var(--ink-3);
  background: var(--paper-2);
  border: 1px dashed var(--rule);
  border-radius: var(--r-2);
}

.v2-auth__empty-line {
  font-family: var(--font-sans);
  font-size: var(--text-xs);
  color: var(--ink-3);
  padding: var(--s-2) 0;
  font-style: italic;
}

.v2-auth__error {
  padding: var(--s-3) var(--s-6);
  background: color-mix(in srgb, var(--accent) 8%, transparent);
  color: var(--accent);
  font-family: var(--font-sans);
  font-size: var(--text-xs);
  border-bottom: var(--hair-soft);
}

.v2-auth__toast {
  position: absolute;
  right: var(--s-4);
  bottom: var(--s-4);
  padding: var(--s-3) var(--s-4);
  background: var(--ink);
  color: var(--paper);
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  border-radius: var(--r-2);
  z-index: 5;
  max-width: 360px;
  box-shadow: 0 6px 20px -10px #1a1a1a66;
}

.v2-auth__toast[data-tone="warn"] {
  background: var(--accent);
}

.v2-auth--inline .v2-auth__stats {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  padding: var(--s-3) var(--s-4) var(--s-2);
}

.v2-auth--inline .v2-auth__emergency {
  padding: var(--s-2) var(--s-4);
}

.v2-auth--inline .v2-auth__section {
  padding: var(--s-3) var(--s-4);
}

/* ui/src/v2/rooms/calendar/CalendarRoom.css */
.v2-cal {
  display: flex;
  position: relative;
  flex-direction: column;
  height: 100%;
  min-height: 0;
}

.v2-cal__stats {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: var(--s-3);
  padding: var(--s-4) var(--s-6) var(--s-3);
}

@media (max-width: 720px) {
  .v2-cal__stats {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

.v2-cal__stat {
  background: var(--paper-2);
  border: 1px solid var(--rule-soft);
  border-radius: var(--r-2);
  padding: var(--s-3) var(--s-4);
  display: flex;
  flex-direction: column;
  gap: 2px;
  min-width: 0;
}

.v2-cal__stat-label {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--ink-3);
}

.v2-cal__stat-value {
  font-family: var(--font-display);
  font-size: var(--text-xl);
  color: var(--ink);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  line-height: 1.1;
}

.v2-cal__stat-sub {
  font-family: var(--font-sans);
  font-size: var(--text-xs);
  color: var(--ink-3);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.v2-cal__toolbar {
  display: flex;
  align-items:  center;
  gap: var(--s-2);
  padding: var(--s-3) var(--s-6);
  border-bottom: var(--hair-soft);
  flex-wrap: wrap;
}

.v2-cal__nav {
  display: inline-flex;
  align-items:  center;
  gap: var(--s-2);
}

.v2-cal__nav-btn {
  display: inline-flex;
  background: var(--paper);
  border: 1px solid var(--rule);
  border-radius: var(--r-pill);
  color: var(--ink-2);
  cursor: pointer;
  transition: background var(--dur-fast) var(--ease-out), color var(--dur-fast) var(--ease-out);
  justify-content: center;
  align-items:  center;
  width: 28px;
  height: 28px;
}

.v2-cal__nav-btn:hover {
  background: var(--paper-3);
  color: var(--ink);
}

.v2-cal__today-btn {
  background: var(--paper-2);
  border: 1px solid var(--rule);
  border-radius: var(--r-pill);
  font-family: var(--font-sans);
  font-size: var(--text-xs);
  color: var(--ink-2);
  cursor: pointer;
  transition: background var(--dur-fast) var(--ease-out);
  padding: 4px 12px;
}

.v2-cal__today-btn:hover {
  background: var(--paper-3);
  color: var(--ink);
}

.v2-cal__week-label {
  margin-left: var(--s-2);
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: var(--ink-3);
  letter-spacing: .05em;
}

.v2-cal__search {
  display: inline-flex;
  align-items:  center;
  gap: var(--s-2);
  background: var(--paper-2);
  border: 1px solid var(--rule);
  border-radius: var(--r-pill);
  color: var(--ink-3);
  flex: 1;
  min-width: 180px;
  max-width: 320px;
  padding: 6px 10px;
}

.v2-cal__search:focus-within {
  border-color: var(--ink-3);
  color: var(--ink-2);
}

.v2-cal__search-input {
  outline: 0;
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  color: var(--ink);
  background: none;
  border: 0;
  flex: 1;
}

.v2-cal__search-input::placeholder {
  color: var(--ink-3);
}

.v2-cal__view-row {
  display: inline-flex;
  border: 1px solid var(--rule);
  border-radius: var(--r-pill);
  overflow: hidden;
  background: var(--paper);
}

.v2-cal__view-btn {
  font-family: var(--font-sans);
  font-size: var(--text-xs);
  color: var(--ink-3);
  cursor: pointer;
  transition: background var(--dur-fast) var(--ease-out), color var(--dur-fast) var(--ease-out);
  background: none;
  border: 0;
  padding: 4px 12px;
}

.v2-cal__view-btn:hover {
  background: var(--paper-3);
  color: var(--ink);
}

.v2-cal__view-btn[data-active="true"] {
  background: var(--ink);
  color: var(--paper);
}

.v2-cal__refresh, .v2-cal__new-btn {
  display: inline-flex;
  justify-content: center;
  align-items:  center;
  gap: var(--s-2);
  border-radius: var(--r-pill);
  cursor: pointer;
  transition: background var(--dur-fast) var(--ease-out);
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  height: 28px;
}

.v2-cal__refresh {
  border: 1px solid var(--rule);
  background: var(--paper);
  color: var(--ink-2);
  width: 28px;
}

.v2-cal__refresh:hover {
  background: var(--paper-3);
  color: var(--ink);
}

.v2-cal__new-btn {
  background: var(--ink);
  color: var(--paper);
  border: 0;
  padding: 0 12px;
}

.v2-cal__new-btn:hover {
  background: var(--ink-2);
}

.v2-cal__refresh:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 2px;
}

.v2-cal__new-btn:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 2px;
}

.v2-cal__week {
  display: grid;
  grid-template-columns: repeat(7, minmax(0, 1fr));
  padding: var(--s-3) var(--s-6);
  border-bottom: var(--hair-soft);
  gap: 0;
}

.v2-cal__day-cell {
  display: flex;
  padding: var(--s-3) var(--s-2);
  border-radius: var(--r-2);
  cursor: pointer;
  transition: background var(--dur-fast) var(--ease-out), border-color var(--dur-fast) var(--ease-out);
  background: none;
  border: 1px solid #0000;
  flex-direction: column;
  align-items:  center;
  gap: 4px;
}

.v2-cal__day-cell:hover {
  background: var(--paper-2);
}

.v2-cal__day-cell[data-active="true"] {
  background: var(--paper-2);
  border-color: var(--rule);
}

.v2-cal__day-cell[data-today="true"] .v2-cal__day-num {
  background: var(--accent);
  color: var(--accent-ink);
}

.v2-cal__day-cell:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 2px;
}

.v2-cal__day-name {
  font-family: var(--font-mono);
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--ink-3);
  font-size: 10px;
}

.v2-cal__day-num {
  display: inline-flex;
  border-radius: var(--r-pill);
  font-family: var(--font-display);
  font-size: var(--text-md);
  color: var(--ink);
  background: none;
  justify-content: center;
  align-items:  center;
  width: 28px;
  height: 28px;
}

.v2-cal__day-dots {
  display: flex;
  align-items:  center;
  gap: 3px;
  min-height: 6px;
  margin-top: 2px;
}

.v2-cal__day-dot {
  border-radius: var(--r-pill);
  background: var(--ink-3);
  width: 6px;
  height: 6px;
}

.v2-cal__day-dot[data-type="commitment"] {
  background: var(--ink-2);
}

.v2-cal__day-dot[data-type="content"] {
  background: var(--warn);
}

.v2-cal__day-more {
  font-family: var(--font-mono);
  color: var(--ink-3);
  margin-left: 2px;
  font-size: 10px;
}

.v2-cal__detail {
  display: flex;
  flex-direction: column;
  flex: 1;
  min-height: 0;
}

.v2-cal__detail-head {
  display: flex;
  padding: var(--s-3) var(--s-6);
  border-bottom: var(--hair-soft);
  justify-content: space-between;
  align-items: baseline;
}

.v2-cal__detail-title {
  font-family: var(--font-display);
  font-size: var(--text-lg);
  color: var(--ink);
  margin: 0;
}

.v2-cal__detail-count {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: var(--ink-3);
}

.v2-cal__lanes {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  flex: 1;
  min-height: 0;
}

@media (max-width: 720px) {
  .v2-cal__lanes {
    grid-template-columns: minmax(0, 1fr);
    grid-template-rows: 1fr 1fr;
  }
}

.v2-cal__lane {
  display: flex;
  border-right: var(--hair-soft);
  flex-direction: column;
  min-height: 0;
}

.v2-cal__lane:last-child {
  border-right: 0;
}

.v2-cal__lane-head {
  display: flex;
  padding: var(--s-3) var(--s-6);
  background: var(--paper-2);
  border-bottom: var(--hair-soft);
  justify-content: space-between;
  align-items:  center;
}

.v2-cal__lane-label {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--ink-2);
}

.v2-cal__lane[data-tone="warn"] .v2-cal__lane-label {
  color: var(--warn);
}

.v2-cal__lane-count {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: var(--ink-3);
}

.v2-cal__lane-list {
  list-style: none;
  padding: var(--s-3) var(--s-6);
  overflow-y: auto;
  display: flex;
  gap: var(--s-2);
  flex-direction: column;
  flex: 1;
  margin: 0;
}

.v2-cal__lane-empty {
  padding: var(--s-6) var(--s-4);
  text-align: center;
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  color: var(--ink-3);
  font-style: italic;
}

.v2-cal__event {
  display: grid;
  grid-template-columns: 28px 1fr;
  gap: var(--s-3);
  padding: var(--s-3) var(--s-4);
  background: var(--paper-2);
  border: 1px solid var(--rule-soft);
  border-radius: var(--r-2);
  text-align: left;
  cursor: pointer;
  transition: background var(--dur-fast) var(--ease-out), border-color var(--dur-fast) var(--ease-out);
  align-items:  flex-start;
}

.v2-cal__event:hover {
  background: var(--paper);
  border-color: var(--rule);
}

.v2-cal__event[data-active="true"] {
  border-color: var(--accent);
  background: color-mix(in srgb, var(--accent) 4%, var(--paper));
}

.v2-cal__event-icon {
  border-radius: var(--r-1);
  background: var(--paper-3);
  color: var(--ink-2);
  display: inline-flex;
  justify-content: center;
  align-items:  center;
  width: 28px;
  height: 28px;
}

.v2-cal__event[data-type="content"] .v2-cal__event-icon {
  background: color-mix(in srgb, var(--warn) 14%, transparent);
  color: var(--warn);
}

.v2-cal__event-body {
  display: flex;
  flex-direction: column;
  gap: 2px;
  min-width: 0;
}

.v2-cal__event-time {
  font-family: var(--font-mono);
  letter-spacing: .05em;
  color: var(--ink-3);
  font-size: 10px;
}

.v2-cal__event-title {
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  color: var(--ink);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  line-height: 1.3;
}

.v2-cal__event-meta {
  display: flex;
  flex-wrap: wrap;
  align-items:  center;
  gap: 4px;
  margin-top: 2px;
}

.v2-cal__event-assignee {
  font-family: var(--font-mono);
  color: var(--ink-3);
  font-size: 10px;
}

.v2-cal__side {
  position: absolute;
  top: var(--s-4);
  right: var(--s-4);
  bottom: var(--s-4);
  background: var(--paper);
  border: 1px solid var(--rule);
  border-radius: var(--r-2);
  display: flex;
  z-index: 4;
  overflow: hidden;
  flex-direction: column;
  width: 320px;
  box-shadow: 0 6px 20px -10px #1a1a1a2e;
}

@media (max-width: 900px) {
  .v2-cal__side {
    display: none;
  }
}

.v2-cal__side-head {
  display: flex;
  justify-content: space-between;
  align-items:  flex-start;
  gap: var(--s-3);
  padding: var(--s-4) var(--s-5);
  border-bottom: var(--hair-soft);
  background: var(--paper-2);
}

.v2-cal__side-eyebrow {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--ink-3);
}

.v2-cal__side-title {
  font-family: var(--font-display);
  font-size: var(--text-lg);
  color: var(--ink);
  margin: 4px 0 0;
  line-height: 1.3;
}

.v2-cal__side-fields {
  padding: var(--s-4) var(--s-5);
  display: flex;
  gap: var(--s-3);
  overflow-y: auto;
  flex-direction: column;
  margin: 0;
}

.v2-cal__side-fields > div {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.v2-cal__side-fields dt {
  font-family: var(--font-mono);
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--ink-3);
  font-size: 10px;
}

.v2-cal__side-fields dd {
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  color: var(--ink);
  margin: 0;
}

.v2-cal__side-muted {
  font-style: italic;
  color: var(--ink-3) !important;
}

.v2-cal__icon-btn {
  display: inline-flex;
  color: var(--ink-3);
  border-radius: var(--r-pill);
  cursor: pointer;
  transition: background var(--dur-fast) var(--ease-out), color var(--dur-fast) var(--ease-out);
  background: none;
  border: 0;
  justify-content: center;
  align-items:  center;
  width: 28px;
  height: 28px;
}

.v2-cal__icon-btn:hover {
  background: var(--paper-3);
  color: var(--ink);
}

.v2-cal__overlay {
  position: fixed;
  display: flex;
  padding: var(--s-4);
  z-index: 65;
  background: #1a1a1a66;
  justify-content: center;
  align-items:  center;
  inset: 0;
}

.v2-cal__dialog {
  background: var(--paper);
  border: 1px solid var(--rule);
  border-radius: var(--r-2);
  display: flex;
  overflow: hidden;
  flex-direction: column;
  width: 100%;
  max-width: 480px;
}

.v2-cal__dialog-head {
  display: flex;
  padding: var(--s-4) var(--s-5);
  border-bottom: var(--hair-soft);
  background: var(--paper-2);
  justify-content: space-between;
  align-items:  flex-start;
}

.v2-cal__dialog-title {
  font-family: var(--font-display);
  font-size: var(--text-lg);
  color: var(--ink);
}

.v2-cal__dialog-subtitle {
  font-family: var(--font-sans);
  font-size: var(--text-xs);
  color: var(--ink-3);
  margin-top: 2px;
}

.v2-cal__dialog-body {
  padding: var(--s-5);
  display: flex;
  gap: var(--s-4);
  flex-direction: column;
}

.v2-cal__field {
  display: flex;
  gap: var(--s-2);
  flex-direction: column;
}

.v2-cal__field-label {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--ink-3);
}

.v2-cal__field-hint {
  font-family: var(--font-mono);
  color: var(--ink-3);
  font-size: 10px;
}

.v2-cal__input {
  background: var(--paper);
  border: 1px solid var(--rule);
  border-radius: var(--r-1);
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  color: var(--ink);
  width: 100%;
  padding: 8px 12px;
}

.v2-cal__input:focus {
  outline: 2px solid var(--accent);
  outline-offset: -2px;
}

.v2-cal__chip-row {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.v2-cal__chip {
  background: var(--paper-2);
  border: 1px solid var(--rule);
  border-radius: var(--r-pill);
  font-family: var(--font-sans);
  font-size: var(--text-xs);
  color: var(--ink-2);
  cursor: pointer;
  transition: background var(--dur-fast) var(--ease-out), color var(--dur-fast) var(--ease-out), border-color var(--dur-fast) var(--ease-out);
  padding: 4px 12px;
}

.v2-cal__chip:hover {
  background: var(--paper-3);
  color: var(--ink);
}

.v2-cal__chip[data-active="true"] {
  background: var(--ink);
  color: var(--paper);
  border-color: var(--ink);
}

.v2-cal__dialog-foot {
  display: flex;
  justify-content: flex-end;
  gap: var(--s-2);
  padding: var(--s-3) var(--s-5);
  border-top: var(--hair-soft);
  background: var(--paper-2);
}

.v2-cal__btn {
  border-radius: var(--r-pill);
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  cursor: pointer;
  border: 1px solid var(--rule);
  transition: background var(--dur-fast) var(--ease-out), color var(--dur-fast) var(--ease-out);
  padding: 6px 14px;
}

.v2-cal__btn--secondary {
  color: var(--ink-2);
  background: none;
}

.v2-cal__btn--secondary:hover {
  background: var(--paper-3);
  color: var(--ink);
}

.v2-cal__btn--primary {
  background: var(--ink);
  color: var(--paper);
  border-color: var(--ink);
}

.v2-cal__btn--primary:hover {
  background: var(--ink-2);
}

.v2-cal__btn:disabled {
  opacity: .5;
  cursor: default;
}

.v2-cal__error {
  padding: var(--s-3) var(--s-6);
  background: color-mix(in srgb, var(--accent) 8%, transparent);
  color: var(--accent);
  font-family: var(--font-sans);
  font-size: var(--text-xs);
  border-bottom: var(--hair-soft);
}

.v2-cal__toast {
  position: absolute;
  right: var(--s-4);
  bottom: var(--s-4);
  padding: var(--s-3) var(--s-4);
  background: var(--ink);
  color: var(--paper);
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  border-radius: var(--r-2);
  z-index: 6;
  max-width: 360px;
  box-shadow: 0 6px 20px -10px #1a1a1a66;
}

.v2-cal__toast[data-tone="warn"] {
  background: var(--accent);
}

.v2-cal--inline .v2-cal__stats {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  padding: var(--s-3) var(--s-4) var(--s-2);
}

.v2-cal--inline .v2-cal__toolbar {
  padding: var(--s-2) var(--s-4);
}

.v2-cal--inline .v2-cal__week {
  padding: var(--s-3) var(--s-4);
}

.v2-cal--inline .v2-cal__lanes {
  grid-template-columns: minmax(0, 1fr);
  grid-template-rows: 1fr 1fr;
}

.v2-cal--inline .v2-cal__side {
  display: none;
}

/* ui/src/v2/rooms/goals/GoalsRoom.css */
.v2-goals {
  display: flex;
  position: relative;
  flex-direction: column;
  height: 100%;
  min-height: 0;
}

.v2-goals__stats {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: var(--s-3);
  padding: var(--s-4) var(--s-6) var(--s-3);
}

@media (max-width: 720px) {
  .v2-goals__stats {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

.v2-goals__stat {
  background: var(--paper-2);
  border: 1px solid var(--rule-soft);
  border-radius: var(--r-2);
  padding: var(--s-3) var(--s-4);
  display: flex;
  flex-direction: column;
  gap: 2px;
  min-width: 0;
}

.v2-goals__stat[data-tone="warn"] {
  border-color: var(--warn);
}

.v2-goals__stat[data-tone="accent"] {
  border-color: var(--accent);
}

.v2-goals__stat-label {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--ink-3);
}

.v2-goals__stat-value {
  font-family: var(--font-display);
  font-size: var(--text-xl);
  color: var(--ink);
  line-height: 1.1;
}

.v2-goals__stat[data-tone="accent"] .v2-goals__stat-value {
  color: var(--accent);
}

.v2-goals__stat-sub {
  font-family: var(--font-sans);
  font-size: var(--text-xs);
  color: var(--ink-3);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.v2-goals__tabs {
  display: flex;
  gap: var(--s-1);
  padding: 0 var(--s-6);
  border-bottom: var(--hair-soft);
}

.v2-goals__tab {
  display: inline-flex;
  align-items:  center;
  gap: var(--s-2);
  padding: var(--s-3) var(--s-3);
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  color: var(--ink-3);
  cursor: pointer;
  transition: color var(--dur-fast) var(--ease-out), border-color var(--dur-fast) var(--ease-out);
  background: none;
  border: 0;
  border-bottom: 2px solid #0000;
  margin-bottom: -1px;
}

.v2-goals__tab:hover {
  color: var(--ink);
}

.v2-goals__tab[data-active="true"] {
  color: var(--ink);
  border-bottom-color: var(--accent);
}

.v2-goals__tab:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 2px;
  border-radius: var(--r-1);
}

.v2-goals__toolbar {
  display: flex;
  align-items:  center;
  gap: var(--s-2);
  padding: var(--s-3) var(--s-6);
  border-bottom: var(--hair-soft);
  flex-wrap: wrap;
}

.v2-goals__search {
  display: inline-flex;
  align-items:  center;
  gap: var(--s-2);
  background: var(--paper-2);
  border: 1px solid var(--rule);
  border-radius: var(--r-pill);
  color: var(--ink-3);
  flex: 1;
  min-width: 180px;
  max-width: 320px;
  padding: 6px 10px;
}

.v2-goals__search:focus-within {
  border-color: var(--ink-3);
  color: var(--ink-2);
}

.v2-goals__search-input {
  outline: 0;
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  color: var(--ink);
  background: none;
  border: 0;
  flex: 1;
}

.v2-goals__search-input::placeholder {
  color: var(--ink-3);
}

.v2-goals__filter-row {
  display: inline-flex;
  border: 1px solid var(--rule);
  border-radius: var(--r-pill);
  overflow: hidden;
  background: var(--paper);
}

.v2-goals__filter-btn {
  font-family: var(--font-sans);
  font-size: var(--text-xs);
  color: var(--ink-3);
  cursor: pointer;
  transition: background var(--dur-fast) var(--ease-out), color var(--dur-fast) var(--ease-out);
  white-space: nowrap;
  background: none;
  border: 0;
  padding: 4px 10px;
}

.v2-goals__filter-btn:hover {
  background: var(--paper-3);
  color: var(--ink);
}

.v2-goals__filter-btn[data-active="true"] {
  background: var(--ink);
  color: var(--paper);
}

.v2-goals__refresh, .v2-goals__new-btn {
  display: inline-flex;
  justify-content: center;
  align-items:  center;
  gap: var(--s-2);
  border-radius: var(--r-pill);
  cursor: pointer;
  transition: background var(--dur-fast) var(--ease-out);
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  height: 28px;
}

.v2-goals__refresh {
  border: 1px solid var(--rule);
  background: var(--paper);
  color: var(--ink-2);
  width: 28px;
}

.v2-goals__refresh:hover {
  background: var(--paper-3);
  color: var(--ink);
}

.v2-goals__new-btn {
  background: var(--ink);
  color: var(--paper);
  border: 0;
  padding: 0 12px;
}

.v2-goals__new-btn:hover {
  background: var(--ink-2);
}

.v2-goals__tree {
  overflow-y: auto;
  padding: var(--s-3) var(--s-4) var(--s-6);
  flex: 1;
}

.v2-goals__tree-list {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 2px;
  margin: 0;
  padding: 0;
}

.v2-goals__tree-list .v2-goals__tree-list {
  margin-top: 2px;
}

.v2-goals__tree-row {
  display: grid;
  grid-template-columns: 24px auto 1fr 120px auto auto;
  gap: var(--s-2);
  padding: var(--s-2) var(--s-3) var(--s-2) 0;
  border-radius: var(--r-2);
  cursor: pointer;
  transition: background var(--dur-fast) var(--ease-out), border-color var(--dur-fast) var(--ease-out);
  border: 1px solid #0000;
  align-items:  center;
}

.v2-goals__tree-row:hover {
  background: var(--paper-2);
}

.v2-goals__tree-row[data-selected="true"] {
  background: var(--paper-2);
  border-color: var(--accent);
}

.v2-goals__tree-toggle {
  display: inline-flex;
  color: var(--ink-3);
  cursor: pointer;
  border-radius: var(--r-1);
  transition: transform var(--dur-fast) var(--ease-out), color var(--dur-fast) var(--ease-out);
  background: none;
  border: 0;
  justify-content: center;
  align-items:  center;
  width: 20px;
  height: 20px;
}

.v2-goals__tree-toggle:hover {
  color: var(--ink);
}

.v2-goals__tree-toggle[data-expanded="true"] {
  transform: rotate(90deg);
}

.v2-goals__tree-spacer {
  width: 20px;
}

.v2-goals__tree-level {
  font-family: var(--font-mono);
  letter-spacing: .1em;
  text-transform: uppercase;
  border-radius: var(--r-pill);
  background: var(--paper-3);
  color: var(--ink-3);
  padding: 2px 6px;
  font-size: 10px;
}

.v2-goals__tree-level[data-level="objective"] {
  background: var(--ink);
  color: var(--paper);
}

.v2-goals__tree-level[data-level="key_result"] {
  background: color-mix(in srgb, var(--accent) 12%, transparent);
  color: var(--accent);
}

.v2-goals__tree-title {
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  color: var(--ink);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  min-width: 0;
}

.v2-goals__score-bar {
  position: relative;
  background: var(--paper-3);
  border-radius: var(--r-pill);
  overflow: hidden;
  display: flex;
  align-items:  center;
  min-width: 80px;
  height: 16px;
  padding: 0 6px;
}

.v2-goals__score-bar-fill {
  position: absolute;
  background: var(--ink-2);
  transition: width var(--dur-fast) var(--ease-out);
  top: 0;
  bottom: 0;
  left: 0;
}

.v2-goals__score-bar-fill[data-tone="ok"] {
  background: color-mix(in srgb, var(--ok) 50%, transparent);
}

.v2-goals__score-bar-fill[data-tone="warn"] {
  background: color-mix(in srgb, var(--warn) 55%, transparent);
}

.v2-goals__score-bar-fill[data-tone="accent"] {
  background: color-mix(in srgb, var(--accent) 55%, transparent);
}

.v2-goals__score-bar-label {
  position: relative;
  font-family: var(--font-mono);
  color: var(--ink);
  z-index: 1;
  font-size: 10px;
}

.v2-goals__timeline {
  overflow-y: auto;
  padding: var(--s-4) var(--s-6);
  display: flex;
  gap: var(--s-5);
  flex-direction: column;
  flex: 1;
}

.v2-goals__time-band {
  display: flex;
  gap: var(--s-2);
  flex-direction: column;
}

.v2-goals__time-band-head {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--ink-3);
  padding-bottom: var(--s-2);
  border-bottom: var(--hair-soft);
}

.v2-goals__time-list {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 4px;
  margin: 0;
  padding: 0;
}

.v2-goals__time-row {
  display: grid;
  grid-template-columns: 70px 1fr auto auto 100px;
  gap: var(--s-3);
  padding: var(--s-2) var(--s-3);
  background: var(--paper-2);
  border-radius: var(--r-2);
  text-align: left;
  cursor: pointer;
  transition: background var(--dur-fast) var(--ease-out), border-color var(--dur-fast) var(--ease-out);
  border: 1px solid #0000;
  align-items:  center;
  width: 100%;
}

.v2-goals__time-row:hover {
  background: var(--paper);
  border-color: var(--rule);
}

.v2-goals__time-row[data-selected="true"] {
  border-color: var(--accent);
}

.v2-goals__time-date {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: var(--ink-3);
  letter-spacing: .05em;
}

.v2-goals__time-title {
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  color: var(--ink);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.v2-goals__metrics {
  overflow-y: auto;
  padding: var(--s-4) var(--s-6);
  display: flex;
  gap: var(--s-5);
  flex-direction: column;
  flex: 1;
}

.v2-goals__metrics-section {
  display: flex;
  gap: var(--s-3);
  flex-direction: column;
}

.v2-goals__metrics-title {
  font-family: var(--font-display);
  font-size: var(--text-lg);
  color: var(--ink);
  margin: 0;
}

.v2-goals__metrics-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
  gap: var(--s-3);
}

.v2-goals__metric-tile {
  background: var(--paper-2);
  border: 1px solid var(--rule-soft);
  border-radius: var(--r-2);
  padding: var(--s-3) var(--s-4);
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.v2-goals__metric-tile[data-tone="ok"] {
  border-color: color-mix(in srgb, var(--ok) 40%, var(--rule-soft));
}

.v2-goals__metric-tile[data-tone="warn"] {
  border-color: color-mix(in srgb, var(--warn) 40%, var(--rule-soft));
}

.v2-goals__metric-tile[data-tone="accent"] {
  border-color: var(--accent);
}

.v2-goals__metric-label {
  font-family: var(--font-mono);
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--ink-3);
  font-size: 10px;
}

.v2-goals__metric-value {
  font-family: var(--font-display);
  font-size: var(--text-xl);
  color: var(--ink);
}

.v2-goals__metric-tile[data-tone="accent"] .v2-goals__metric-value {
  color: var(--accent);
}

.v2-goals__overdue-list {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 4px;
  margin: 0;
  padding: 0;
}

.v2-goals__overdue-row {
  display: grid;
  grid-template-columns: 24px 1fr auto 120px;
  gap: var(--s-3);
  padding: var(--s-2) var(--s-3);
  background: color-mix(in srgb, var(--warn) 6%, var(--paper));
  border: 1px solid color-mix(in srgb, var(--warn) 40%, var(--rule));
  border-radius: var(--r-2);
  text-align: left;
  cursor: pointer;
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  color: var(--ink);
  transition: background var(--dur-fast) var(--ease-out);
  align-items:  center;
  width: 100%;
}

.v2-goals__overdue-row:hover {
  background: color-mix(in srgb, var(--warn) 10%, var(--paper));
}

.v2-goals__overdue-title {
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.v2-goals__overdue-due {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: var(--warn);
}

.v2-goals__side {
  position: absolute;
  top: var(--s-4);
  right: var(--s-4);
  bottom: var(--s-4);
  background: var(--paper);
  border: 1px solid var(--rule);
  border-radius: var(--r-2);
  display: flex;
  z-index: 4;
  overflow: hidden;
  flex-direction: column;
  width: 360px;
  box-shadow: 0 6px 20px -10px #1a1a1a2e;
}

@media (max-width: 900px) {
  .v2-goals__side {
    display: none;
  }
}

.v2-goals__side-head {
  display: flex;
  justify-content: space-between;
  align-items:  flex-start;
  gap: var(--s-3);
  padding: var(--s-4) var(--s-5);
  border-bottom: var(--hair-soft);
  background: var(--paper-2);
}

.v2-goals__side-eyebrow {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--ink-3);
}

.v2-goals__side-title {
  font-family: var(--font-display);
  font-size: var(--text-lg);
  color: var(--ink);
  margin: 4px 0 0;
  line-height: 1.3;
}

.v2-goals__side-parent {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: var(--ink-3);
  margin-top: 4px;
}

.v2-goals__side-body {
  overflow-y: auto;
  padding: var(--s-4) var(--s-5);
  display: flex;
  gap: var(--s-4);
  flex-direction: column;
  flex: 1;
}

.v2-goals__side-section {
  display: flex;
  gap: var(--s-2);
  flex-direction: column;
}

.v2-goals__side-label {
  font-family: var(--font-mono);
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--ink-3);
  font-size: 10px;
}

.v2-goals__side-desc {
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  color: var(--ink-2);
  line-height: var(--lh-body);
  margin: 0;
}

.v2-goals__side-text {
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  color: var(--ink);
  margin: 0;
}

.v2-goals__score-slider {
  appearance: none;
  border-radius: var(--r-pill);
  background: var(--paper-3);
  outline: none;
  width: 100%;
  height: 6px;
}

.v2-goals__score-slider::-webkit-slider-thumb {
  appearance: none;
  border-radius: var(--r-pill);
  background: var(--accent);
  border: 2px solid var(--paper);
  cursor: pointer;
  box-shadow: 0 0 0 1px var(--accent);
  width: 16px;
  height: 16px;
}

.v2-goals__score-slider::-moz-range-thumb {
  border-radius: var(--r-pill);
  background: var(--accent);
  border: 2px solid var(--paper);
  cursor: pointer;
  width: 16px;
  height: 16px;
}

.v2-goals__chip-row {
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
}

.v2-goals__chip {
  background: var(--paper-2);
  border: 1px solid var(--rule);
  border-radius: var(--r-pill);
  font-family: var(--font-sans);
  font-size: var(--text-xs);
  color: var(--ink-2);
  cursor: pointer;
  transition: background var(--dur-fast) var(--ease-out), color var(--dur-fast) var(--ease-out), border-color var(--dur-fast) var(--ease-out);
  padding: 4px 10px;
}

.v2-goals__chip:hover {
  background: var(--paper-3);
  color: var(--ink);
}

.v2-goals__chip[data-active="true"] {
  background: var(--ink);
  color: var(--paper);
  border-color: var(--ink);
}

.v2-goals__side-children {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 4px;
  margin: 0;
  padding: 0;
}

.v2-goals__side-child {
  display: flex;
  justify-content: space-between;
  align-items:  center;
  gap: var(--s-2);
  background: var(--paper-2);
  border: 1px solid var(--rule-soft);
  border-radius: var(--r-1);
  font-family: var(--font-sans);
  font-size: var(--text-xs);
  color: var(--ink);
  padding: 6px 10px;
}

.v2-goals__icon-btn {
  display: inline-flex;
  color: var(--ink-3);
  border-radius: var(--r-pill);
  cursor: pointer;
  transition: background var(--dur-fast) var(--ease-out), color var(--dur-fast) var(--ease-out);
  background: none;
  border: 0;
  justify-content: center;
  align-items:  center;
  width: 28px;
  height: 28px;
}

.v2-goals__icon-btn:hover {
  background: var(--paper-3);
  color: var(--ink);
}

.v2-goals__btn {
  display: inline-flex;
  border-radius: var(--r-pill);
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  cursor: pointer;
  border: 1px solid var(--rule);
  transition: background var(--dur-fast) var(--ease-out), color var(--dur-fast) var(--ease-out);
  align-items:  center;
  gap: 4px;
  padding: 6px 14px;
}

.v2-goals__btn--secondary {
  color: var(--ink-2);
  background: none;
}

.v2-goals__btn--secondary:hover {
  background: var(--paper-3);
  color: var(--ink);
}

.v2-goals__btn--primary {
  background: var(--ink);
  color: var(--paper);
  border-color: var(--ink);
}

.v2-goals__btn--primary:hover {
  background: var(--ink-2);
}

.v2-goals__btn:disabled {
  opacity: .5;
  cursor: default;
}

.v2-goals__overlay {
  position: fixed;
  display: flex;
  padding: var(--s-4);
  z-index: 65;
  background: #1a1a1a66;
  justify-content: center;
  align-items:  center;
  inset: 0;
}

.v2-goals__dialog {
  background: var(--paper);
  border: 1px solid var(--rule);
  border-radius: var(--r-2);
  display: flex;
  overflow: hidden;
  flex-direction: column;
  width: 100%;
  max-width: 480px;
}

.v2-goals__dialog-head {
  display: flex;
  padding: var(--s-4) var(--s-5);
  border-bottom: var(--hair-soft);
  background: var(--paper-2);
  justify-content: space-between;
  align-items:  flex-start;
}

.v2-goals__dialog-title {
  font-family: var(--font-display);
  font-size: var(--text-lg);
  color: var(--ink);
}

.v2-goals__dialog-subtitle {
  font-family: var(--font-sans);
  font-size: var(--text-xs);
  color: var(--ink-3);
  margin-top: 2px;
}

.v2-goals__dialog-body {
  padding: var(--s-5);
  display: flex;
  gap: var(--s-4);
  flex-direction: column;
}

.v2-goals__field {
  display: flex;
  gap: var(--s-2);
  flex-direction: column;
}

.v2-goals__field-label {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--ink-3);
}

.v2-goals__input {
  background: var(--paper);
  border: 1px solid var(--rule);
  border-radius: var(--r-1);
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  color: var(--ink);
  width: 100%;
  padding: 8px 12px;
}

.v2-goals__input:focus {
  outline: 2px solid var(--accent);
  outline-offset: -2px;
}

.v2-goals__dialog-foot {
  display: flex;
  justify-content: flex-end;
  gap: var(--s-2);
  padding: var(--s-3) var(--s-5);
  border-top: var(--hair-soft);
  background: var(--paper-2);
}

.v2-goals__empty {
  padding: var(--s-8) var(--s-4);
  text-align: center;
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  color: var(--ink-3);
}

.v2-goals__empty-line {
  font-family: var(--font-sans);
  font-size: var(--text-xs);
  color: var(--ink-3);
  padding: var(--s-2) 0;
  font-style: italic;
}

.v2-goals__error {
  padding: var(--s-3) var(--s-6);
  background: color-mix(in srgb, var(--accent) 8%, transparent);
  color: var(--accent);
  font-family: var(--font-sans);
  font-size: var(--text-xs);
  border-bottom: var(--hair-soft);
}

.v2-goals__toast {
  position: absolute;
  right: var(--s-4);
  bottom: var(--s-4);
  padding: var(--s-3) var(--s-4);
  background: var(--ink);
  color: var(--paper);
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  border-radius: var(--r-2);
  z-index: 6;
  max-width: 360px;
  box-shadow: 0 6px 20px -10px #1a1a1a66;
}

.v2-goals__toast[data-tone="warn"] {
  background: var(--accent);
}

.v2-goals--inline .v2-goals__stats {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  padding: var(--s-3) var(--s-4) var(--s-2);
}

.v2-goals--inline .v2-goals__toolbar {
  padding: var(--s-2) var(--s-4);
}

.v2-goals--inline .v2-goals__tree {
  padding: var(--s-3) var(--s-4);
}

.v2-goals--inline .v2-goals__side {
  display: none;
}

/* ui/src/v2/rooms/tasks/TasksRoom.css */
.v2-tasks {
  display: flex;
  position: relative;
  flex-direction: column;
  height: 100%;
  min-height: 0;
}

.v2-tasks__stats {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: var(--s-3);
  padding: var(--s-4) var(--s-6) var(--s-3);
}

@media (max-width: 720px) {
  .v2-tasks__stats {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

.v2-tasks__stat {
  background: var(--paper-2);
  border: 1px solid var(--rule-soft);
  border-radius: var(--r-2);
  padding: var(--s-3) var(--s-4);
  display: flex;
  flex-direction: column;
  gap: 2px;
  min-width: 0;
}

.v2-tasks__stat[data-tone="ok"] {
  border-color: color-mix(in srgb, var(--ok) 40%, var(--rule-soft));
}

.v2-tasks__stat[data-tone="warn"] {
  border-color: var(--warn);
}

.v2-tasks__stat[data-tone="accent"] {
  border-color: var(--accent);
}

.v2-tasks__stat-label {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--ink-3);
}

.v2-tasks__stat-value {
  font-family: var(--font-display);
  font-size: var(--text-xl);
  color: var(--ink);
  line-height: 1.1;
}

.v2-tasks__stat[data-tone="warn"] .v2-tasks__stat-value {
  color: var(--warn);
}

.v2-tasks__stat[data-tone="accent"] .v2-tasks__stat-value {
  color: var(--accent);
}

.v2-tasks__stat-sub {
  font-family: var(--font-sans);
  font-size: var(--text-xs);
  color: var(--ink-3);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.v2-tasks__toolbar {
  display: flex;
  align-items:  center;
  gap: var(--s-2);
  padding: var(--s-3) var(--s-6);
  border-bottom: var(--hair-soft);
  flex-wrap: wrap;
}

.v2-tasks__search {
  display: inline-flex;
  align-items:  center;
  gap: var(--s-2);
  background: var(--paper-2);
  border: 1px solid var(--rule);
  border-radius: var(--r-pill);
  color: var(--ink-3);
  flex: 1;
  min-width: 180px;
  max-width: 320px;
  padding: 6px 10px;
}

.v2-tasks__search:focus-within {
  border-color: var(--ink-3);
  color: var(--ink-2);
}

.v2-tasks__search-input {
  outline: 0;
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  color: var(--ink);
  background: none;
  border: 0;
  flex: 1;
}

.v2-tasks__search-input::placeholder {
  color: var(--ink-3);
}

.v2-tasks__filter-row {
  display: inline-flex;
  border: 1px solid var(--rule);
  border-radius: var(--r-pill);
  overflow: hidden;
  background: var(--paper);
}

.v2-tasks__filter-btn {
  font-family: var(--font-sans);
  font-size: var(--text-xs);
  color: var(--ink-3);
  cursor: pointer;
  white-space: nowrap;
  transition: background var(--dur-fast) var(--ease-out), color var(--dur-fast) var(--ease-out);
  background: none;
  border: 0;
  padding: 4px 10px;
}

.v2-tasks__filter-btn:hover {
  background: var(--paper-3);
  color: var(--ink);
}

.v2-tasks__filter-btn[data-active="true"] {
  background: var(--ink);
  color: var(--paper);
}

.v2-tasks__view-row {
  display: inline-flex;
  border: 1px solid var(--rule);
  border-radius: var(--r-pill);
  overflow: hidden;
  background: var(--paper);
}

.v2-tasks__view-btn {
  display: inline-flex;
  color: var(--ink-3);
  cursor: pointer;
  transition: background var(--dur-fast) var(--ease-out), color var(--dur-fast) var(--ease-out);
  background: none;
  border: 0;
  justify-content: center;
  align-items:  center;
  width: 30px;
  height: 26px;
}

.v2-tasks__view-btn:hover {
  background: var(--paper-3);
  color: var(--ink);
}

.v2-tasks__view-btn[data-active="true"] {
  background: var(--ink);
  color: var(--paper);
}

.v2-tasks__select {
  background: var(--paper-2);
  border: 1px solid var(--rule);
  border-radius: var(--r-pill);
  font-family: var(--font-sans);
  font-size: var(--text-xs);
  color: var(--ink-2);
  cursor: pointer;
  padding: 4px 10px;
}

.v2-tasks__refresh, .v2-tasks__new-btn {
  display: inline-flex;
  justify-content: center;
  align-items:  center;
  gap: var(--s-2);
  border-radius: var(--r-pill);
  cursor: pointer;
  transition: background var(--dur-fast) var(--ease-out);
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  height: 28px;
}

.v2-tasks__refresh {
  border: 1px solid var(--rule);
  background: var(--paper);
  color: var(--ink-2);
  width: 28px;
}

.v2-tasks__refresh:hover {
  background: var(--paper-3);
  color: var(--ink);
}

.v2-tasks__new-btn {
  background: var(--ink);
  color: var(--paper);
  border: 0;
  padding: 0 12px;
}

.v2-tasks__new-btn:hover {
  background: var(--ink-2);
}

.v2-tasks__kanban {
  display: grid;
  grid-template-columns: repeat(5, minmax(220px, 1fr));
  overflow-x: auto;
  flex: 1;
  gap: 0;
  min-height: 0;
}

@media (max-width: 1100px) {
  .v2-tasks__kanban {
    grid-template-columns: repeat(5, minmax(200px, 220px));
  }
}

.v2-tasks__col {
  display: flex;
  border-right: var(--hair-soft);
  background: var(--paper);
  flex-direction: column;
  min-height: 0;
}

.v2-tasks__col:last-child {
  border-right: 0;
}

.v2-tasks__col[data-status="completed"] {
  background: color-mix(in srgb, var(--ok) 3%, var(--paper));
}

.v2-tasks__col[data-status="failed"], .v2-tasks__col[data-status="escalated"] {
  background: color-mix(in srgb, var(--accent) 3%, var(--paper));
}

.v2-tasks__col[data-status="active"] {
  background: color-mix(in srgb, var(--warn) 3%, var(--paper));
}

.v2-tasks__col-head {
  display: flex;
  padding: var(--s-3) var(--s-4);
  background: var(--paper-2);
  border-bottom: var(--hair-soft);
  position: sticky;
  z-index: 1;
  justify-content: space-between;
  align-items:  center;
  top: 0;
}

.v2-tasks__col[data-status="completed"] .v2-tasks__col-head {
  background: color-mix(in srgb, var(--ok) 8%, var(--paper-2));
}

.v2-tasks__col[data-status="failed"] .v2-tasks__col-head, .v2-tasks__col[data-status="escalated"] .v2-tasks__col-head {
  background: color-mix(in srgb, var(--accent) 8%, var(--paper-2));
}

.v2-tasks__col-label {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--ink-2);
}

.v2-tasks__col-count {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: var(--ink-3);
}

.v2-tasks__col-list {
  list-style: none;
  padding: var(--s-3) var(--s-3);
  display: flex;
  gap: var(--s-2);
  overflow-y: auto;
  flex-direction: column;
  flex: 1;
  margin: 0;
}

.v2-tasks__col-empty {
  padding: var(--s-3);
  text-align: center;
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: var(--ink-3);
}

.v2-tasks__card {
  background: var(--paper-2);
  border: 1px solid var(--rule);
  border-radius: var(--r-2);
  padding: var(--s-2) var(--s-3);
  display: flex;
  gap: var(--s-2);
  transition: border-color var(--dur-fast) var(--ease-out), background var(--dur-fast) var(--ease-out);
  flex-direction: column;
}

.v2-tasks__card:hover {
  background: var(--paper);
  border-color: var(--ink-3);
}

.v2-tasks__card[data-priority="critical"] {
  border-left: 3px solid var(--accent);
}

.v2-tasks__card[data-priority="high"] {
  border-left: 3px solid var(--warn);
}

.v2-tasks__card[data-overdue="true"] {
  border-color: var(--warn);
}

.v2-tasks__card-head {
  display: flex;
  align-items:  flex-start;
  gap: 6px;
}

.v2-tasks__pip {
  border-radius: var(--r-pill);
  background: var(--ink-3);
  flex-shrink: 0;
  width: 6px;
  height: 6px;
  margin-top: 7px;
}

.v2-tasks__pip[data-priority="critical"] {
  background: var(--accent);
}

.v2-tasks__pip[data-priority="high"] {
  background: var(--warn);
}

.v2-tasks__pip[data-priority="normal"] {
  background: var(--ink-2);
}

.v2-tasks__pip[data-priority="low"] {
  background: var(--ok);
}

.v2-tasks__card-what {
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  color: var(--ink);
  word-break: break-word;
  flex: 1;
  line-height: 1.35;
}

.v2-tasks__card-context {
  font-family: var(--font-sans);
  font-size: var(--text-xs);
  color: var(--ink-2);
  line-height: var(--lh-body);
  display: -webkit-box;
  -webkit-line-clamp: 2;
  overflow: hidden;
  -webkit-box-orient: vertical;
}

.v2-tasks__card-meta {
  display: flex;
  flex-wrap: wrap;
  align-items:  center;
  gap: 6px;
}

.v2-tasks__card-due {
  display: inline-flex;
  font-family: var(--font-mono);
  color: var(--ink-3);
  align-items:  center;
  gap: 3px;
  font-size: 10px;
}

.v2-tasks__card-due[data-overdue="true"] {
  color: var(--warn);
  font-weight: 600;
}

.v2-tasks__card-assignee {
  font-family: var(--font-mono);
  color: var(--ink-2);
  background: var(--paper-3);
  border-radius: var(--r-pill);
  padding: 1px 6px;
  font-size: 10px;
}

.v2-tasks__card-actions {
  display: flex;
  padding-top: var(--s-2);
  border-top: var(--hair-soft);
  align-items:  center;
  gap: 4px;
}

.v2-tasks__priority-select {
  font-family: var(--font-sans);
  color: var(--ink-2);
  background: var(--paper);
  border: 1px solid var(--rule);
  border-radius: var(--r-pill);
  flex: 1;
  padding: 2px 6px;
  font-size: 10px;
}

.v2-tasks__icon-btn {
  display: inline-flex;
  color: var(--ink-3);
  border-radius: var(--r-pill);
  cursor: pointer;
  transition: background var(--dur-fast) var(--ease-out), color var(--dur-fast) var(--ease-out);
  background: none;
  border: 0;
  justify-content: center;
  align-items:  center;
  width: 24px;
  height: 24px;
}

.v2-tasks__icon-btn:hover {
  background: var(--paper-3);
  color: var(--ink);
}

.v2-tasks__icon-btn--primary:hover {
  background: var(--accent);
  color: var(--accent-ink);
}

.v2-tasks__card-result {
  display: flex;
  font-family: var(--font-sans);
  font-size: var(--text-xs);
  color: var(--ink-2);
  padding: var(--s-2);
  background: var(--paper-3);
  border-radius: var(--r-1);
  flex-direction: column;
  gap: 2px;
}

.v2-tasks__card-result-label {
  font-family: var(--font-mono);
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--ink-3);
  font-size: 10px;
}

.v2-tasks__list {
  list-style: none;
  overflow-y: auto;
  flex: 1;
  margin: 0;
  padding: 0;
}

.v2-tasks__list-row {
  display: grid;
  grid-template-columns: 12px 1fr auto auto auto auto auto;
  gap: var(--s-3);
  padding: var(--s-3) var(--s-6);
  border-bottom: var(--hair-soft);
  transition: background var(--dur-fast) var(--ease-out);
  align-items:  center;
}

.v2-tasks__list-row:hover {
  background: var(--paper-2);
}

.v2-tasks__list-row[data-overdue="true"] {
  background: color-mix(in srgb, var(--warn) 4%, var(--paper));
}

.v2-tasks__list-what {
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  color: var(--ink);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  min-width: 0;
}

.v2-tasks__list-due {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: var(--ink-3);
}

.v2-tasks__list-due[data-overdue="true"] {
  color: var(--warn);
  font-weight: 600;
}

.v2-tasks__list-assignee {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: var(--ink-2);
  background: var(--paper-3);
  border-radius: var(--r-pill);
  padding: 1px 6px;
}

.v2-tasks__list-actions {
  display: flex;
  gap: 4px;
}

.v2-tasks__overlay {
  position: fixed;
  display: flex;
  padding: var(--s-4);
  z-index: 65;
  background: #1a1a1a66;
  justify-content: center;
  align-items:  center;
  inset: 0;
}

.v2-tasks__dialog {
  background: var(--paper);
  border: 1px solid var(--rule);
  border-radius: var(--r-2);
  display: flex;
  overflow: hidden;
  flex-direction: column;
  width: 100%;
  max-width: 520px;
}

.v2-tasks__dialog-head {
  display: flex;
  padding: var(--s-4) var(--s-5);
  border-bottom: var(--hair-soft);
  background: var(--paper-2);
  justify-content: space-between;
  align-items:  flex-start;
}

.v2-tasks__dialog-title {
  font-family: var(--font-display);
  font-size: var(--text-lg);
  color: var(--ink);
}

.v2-tasks__dialog-subtitle {
  font-family: var(--font-sans);
  font-size: var(--text-xs);
  color: var(--ink-3);
  margin-top: 2px;
}

.v2-tasks__dialog-body {
  padding: var(--s-5);
  display: flex;
  gap: var(--s-4);
  overflow-y: auto;
  flex-direction: column;
  max-height: 70vh;
}

.v2-tasks__field {
  display: flex;
  gap: var(--s-2);
  flex-direction: column;
}

.v2-tasks__field-label {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--ink-3);
}

.v2-tasks__field-hint {
  font-family: var(--font-mono);
  color: var(--ink-3);
  font-size: 10px;
}

.v2-tasks__input, .v2-tasks__textarea {
  background: var(--paper);
  border: 1px solid var(--rule);
  border-radius: var(--r-1);
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  color: var(--ink);
  width: 100%;
  padding: 8px 12px;
}

.v2-tasks__textarea {
  resize: vertical;
  min-height: 56px;
}

.v2-tasks__input:focus, .v2-tasks__textarea:focus {
  outline: 2px solid var(--accent);
  outline-offset: -2px;
}

.v2-tasks__chip-row {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.v2-tasks__chip {
  background: var(--paper-2);
  border: 1px solid var(--rule);
  border-radius: var(--r-pill);
  font-family: var(--font-sans);
  font-size: var(--text-xs);
  color: var(--ink-2);
  cursor: pointer;
  transition: background var(--dur-fast) var(--ease-out), color var(--dur-fast) var(--ease-out), border-color var(--dur-fast) var(--ease-out);
  padding: 4px 12px;
}

.v2-tasks__chip:hover {
  background: var(--paper-3);
  color: var(--ink);
}

.v2-tasks__chip[data-active="true"] {
  background: var(--ink);
  color: var(--paper);
  border-color: var(--ink);
}

.v2-tasks__dialog-foot {
  display: flex;
  justify-content: flex-end;
  gap: var(--s-2);
  padding: var(--s-3) var(--s-5);
  border-top: var(--hair-soft);
  background: var(--paper-2);
}

.v2-tasks__btn {
  border-radius: var(--r-pill);
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  cursor: pointer;
  border: 1px solid var(--rule);
  transition: background var(--dur-fast) var(--ease-out), color var(--dur-fast) var(--ease-out);
  padding: 6px 14px;
}

.v2-tasks__btn--secondary {
  color: var(--ink-2);
  background: none;
}

.v2-tasks__btn--secondary:hover {
  background: var(--paper-3);
  color: var(--ink);
}

.v2-tasks__btn--primary {
  background: var(--ink);
  color: var(--paper);
  border-color: var(--ink);
}

.v2-tasks__btn--primary:hover {
  background: var(--ink-2);
}

.v2-tasks__btn:disabled {
  opacity: .5;
  cursor: default;
}

.v2-tasks__empty {
  padding: var(--s-8) var(--s-4);
  text-align: center;
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  color: var(--ink-3);
}

.v2-tasks__error {
  padding: var(--s-3) var(--s-6);
  background: color-mix(in srgb, var(--accent) 8%, transparent);
  color: var(--accent);
  font-family: var(--font-sans);
  font-size: var(--text-xs);
  border-bottom: var(--hair-soft);
}

.v2-tasks__toast {
  position: absolute;
  right: var(--s-4);
  bottom: var(--s-4);
  padding: var(--s-3) var(--s-4);
  background: var(--ink);
  color: var(--paper);
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  border-radius: var(--r-2);
  z-index: 6;
  max-width: 360px;
  box-shadow: 0 6px 20px -10px #1a1a1a66;
}

.v2-tasks__toast[data-tone="warn"] {
  background: var(--accent);
}

.v2-tasks--inline .v2-tasks__stats {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  padding: var(--s-3) var(--s-4) var(--s-2);
}

.v2-tasks--inline .v2-tasks__toolbar {
  padding: var(--s-2) var(--s-4);
}

.v2-tasks--inline .v2-tasks__kanban {
  grid-template-columns: repeat(5, minmax(180px, 200px));
}

/* ui/src/v2/rooms/content/ContentRoom.css */
.v2-content {
  display: flex;
  position: relative;
  flex-direction: column;
  height: 100%;
  min-height: 0;
}

.v2-content__stats {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: var(--s-3);
  padding: var(--s-4) var(--s-6) var(--s-3);
}

@media (max-width: 720px) {
  .v2-content__stats {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

.v2-content__stat {
  background: var(--paper-2);
  border: 1px solid var(--rule-soft);
  border-radius: var(--r-2);
  padding: var(--s-3) var(--s-4);
  display: flex;
  flex-direction: column;
  gap: 2px;
  min-width: 0;
}

.v2-content__stat[data-tone="ok"] {
  border-color: color-mix(in srgb, var(--ok) 40%, var(--rule-soft));
}

.v2-content__stat[data-tone="warn"] {
  border-color: var(--warn);
}

.v2-content__stat[data-tone="accent"] {
  border-color: var(--accent);
}

.v2-content__stat-label {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--ink-3);
}

.v2-content__stat-value {
  font-family: var(--font-display);
  font-size: var(--text-xl);
  color: var(--ink);
  line-height: 1.1;
}

.v2-content__stat[data-tone="warn"] .v2-content__stat-value {
  color: var(--warn);
}

.v2-content__stat[data-tone="accent"] .v2-content__stat-value {
  color: var(--accent);
}

.v2-content__stat-sub {
  font-family: var(--font-sans);
  font-size: var(--text-xs);
  color: var(--ink-3);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.v2-content__toolbar {
  display: flex;
  align-items:  center;
  gap: var(--s-2);
  padding: var(--s-3) var(--s-6);
  border-bottom: var(--hair-soft);
  flex-wrap: wrap;
}

.v2-content__search {
  display: inline-flex;
  align-items:  center;
  gap: var(--s-2);
  background: var(--paper-2);
  border: 1px solid var(--rule);
  border-radius: var(--r-pill);
  color: var(--ink-3);
  flex: 1;
  min-width: 180px;
  max-width: 320px;
  padding: 6px 10px;
}

.v2-content__search:focus-within {
  border-color: var(--ink-3);
  color: var(--ink-2);
}

.v2-content__search-input {
  outline: 0;
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  color: var(--ink);
  background: none;
  border: 0;
  flex: 1;
}

.v2-content__search-input::placeholder {
  color: var(--ink-3);
}

.v2-content__filter-row {
  display: inline-flex;
  border: 1px solid var(--rule);
  border-radius: var(--r-pill);
  overflow: hidden;
  background: var(--paper);
}

.v2-content__filter-btn {
  font-family: var(--font-sans);
  font-size: var(--text-xs);
  color: var(--ink-3);
  cursor: pointer;
  white-space: nowrap;
  transition: background var(--dur-fast) var(--ease-out), color var(--dur-fast) var(--ease-out);
  background: none;
  border: 0;
  padding: 4px 10px;
}

.v2-content__filter-btn:hover {
  background: var(--paper-3);
  color: var(--ink);
}

.v2-content__filter-btn[data-active="true"] {
  background: var(--ink);
  color: var(--paper);
}

.v2-content__select {
  background: var(--paper-2);
  border: 1px solid var(--rule);
  border-radius: var(--r-pill);
  font-family: var(--font-sans);
  font-size: var(--text-xs);
  color: var(--ink-2);
  cursor: pointer;
  padding: 4px 10px;
}

.v2-content__view-row {
  display: inline-flex;
  border: 1px solid var(--rule);
  border-radius: var(--r-pill);
  overflow: hidden;
  background: var(--paper);
}

.v2-content__view-btn {
  display: inline-flex;
  color: var(--ink-3);
  cursor: pointer;
  transition: background var(--dur-fast) var(--ease-out), color var(--dur-fast) var(--ease-out);
  background: none;
  border: 0;
  justify-content: center;
  align-items:  center;
  width: 30px;
  height: 26px;
}

.v2-content__view-btn:hover {
  background: var(--paper-3);
  color: var(--ink);
}

.v2-content__view-btn[data-active="true"] {
  background: var(--ink);
  color: var(--paper);
}

.v2-content__refresh, .v2-content__new-btn {
  display: inline-flex;
  justify-content: center;
  align-items:  center;
  gap: var(--s-2);
  border-radius: var(--r-pill);
  cursor: pointer;
  transition: background var(--dur-fast) var(--ease-out);
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  height: 28px;
}

.v2-content__refresh {
  border: 1px solid var(--rule);
  background: var(--paper);
  color: var(--ink-2);
  width: 28px;
}

.v2-content__refresh:hover {
  background: var(--paper-3);
  color: var(--ink);
}

.v2-content__new-btn {
  background: var(--ink);
  color: var(--paper);
  border: 0;
  padding: 0 12px;
}

.v2-content__new-btn:hover {
  background: var(--ink-2);
}

.v2-content__kanban {
  display: grid;
  grid-template-columns: repeat(8, minmax(190px, 1fr));
  overflow-x: auto;
  flex: 1;
  gap: 0;
  min-height: 0;
}

@media (max-width: 1300px) {
  .v2-content__kanban {
    grid-template-columns: repeat(8, minmax(180px, 200px));
  }
}

.v2-content__col {
  display: flex;
  border-right: var(--hair-soft);
  background: var(--paper);
  flex-direction: column;
  min-height: 0;
}

.v2-content__col:last-child {
  border-right: 0;
}

.v2-content__col[data-stage="published"] {
  background: color-mix(in srgb, var(--ok) 3%, var(--paper));
}

.v2-content__col[data-stage="scheduled"] {
  background: color-mix(in srgb, var(--ok) 2%, var(--paper));
}

.v2-content__col[data-stage="review"] {
  background: color-mix(in srgb, var(--warn) 3%, var(--paper));
}

.v2-content__col-head {
  display: flex;
  padding: var(--s-3) var(--s-3);
  background: var(--paper-2);
  border-bottom: var(--hair-soft);
  position: sticky;
  z-index: 1;
  justify-content: space-between;
  align-items:  center;
  top: 0;
}

.v2-content__col-label {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--ink-2);
}

.v2-content__col-count {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: var(--ink-3);
}

.v2-content__col-list {
  list-style: none;
  padding: var(--s-3);
  display: flex;
  gap: var(--s-2);
  overflow-y: auto;
  flex-direction: column;
  flex: 1;
  margin: 0;
}

.v2-content__col-empty {
  padding: var(--s-3);
  text-align: center;
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: var(--ink-3);
}

.v2-content__card {
  background: var(--paper-2);
  border: 1px solid var(--rule);
  border-radius: var(--r-2);
  padding: var(--s-2) var(--s-3);
  display: flex;
  gap: var(--s-2);
  cursor: pointer;
  transition: background var(--dur-fast) var(--ease-out), border-color var(--dur-fast) var(--ease-out);
  flex-direction: column;
}

.v2-content__card:hover {
  background: var(--paper);
  border-color: var(--ink-3);
}

.v2-content__card[data-active="true"] {
  border-color: var(--accent);
  background: color-mix(in srgb, var(--accent) 4%, var(--paper));
}

.v2-content__card-head {
  display: flex;
  align-items:  flex-start;
  gap: 6px;
}

.v2-content__type-badge {
  display: inline-flex;
  border-radius: var(--r-pill);
  background: var(--paper-3);
  color: var(--ink-2);
  font-family: var(--font-mono);
  letter-spacing: .05em;
  flex-shrink: 0;
  justify-content: center;
  align-items:  center;
  min-width: 28px;
  height: 18px;
  padding: 0 6px;
  font-size: 9px;
}

.v2-content__card[data-type="youtube"] .v2-content__type-badge {
  background: color-mix(in srgb, var(--accent) 14%, transparent);
  color: var(--accent);
}

.v2-content__card[data-type="podcast"] .v2-content__type-badge {
  background: color-mix(in srgb, var(--warn) 14%, transparent);
  color: var(--warn);
}

.v2-content__card-title {
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  color: var(--ink);
  word-break: break-word;
  flex: 1;
  line-height: 1.35;
}

.v2-content__card-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
}

.v2-content__tag {
  font-family: var(--font-mono);
  border-radius: var(--r-pill);
  background: var(--paper-3);
  color: var(--ink-2);
  padding: 1px 6px;
  font-size: 10px;
}

.v2-content__tag-more {
  font-family: var(--font-mono);
  color: var(--ink-3);
  font-size: 10px;
}

.v2-content__card-foot {
  display: flex;
  font-family: var(--font-mono);
  color: var(--ink-3);
  justify-content: space-between;
  align-items:  center;
  font-size: 10px;
}

.v2-content__card-sched {
  color: var(--ok);
}

.v2-content__list {
  list-style: none;
  overflow-y: auto;
  flex: 1;
  margin: 0;
  padding: 0;
}

.v2-content__list-row {
  display: grid;
  grid-template-columns: auto 1fr auto auto;
  gap: var(--s-3);
  padding: var(--s-3) var(--s-6);
  border-bottom: var(--hair-soft);
  cursor: pointer;
  transition: background var(--dur-fast) var(--ease-out);
  align-items:  center;
}

.v2-content__list-row:hover {
  background: var(--paper-2);
}

.v2-content__list-row[data-active="true"] {
  background: color-mix(in srgb, var(--accent) 4%, var(--paper));
}

.v2-content__list-title {
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  color: var(--ink);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  min-width: 0;
}

.v2-content__list-time {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: var(--ink-3);
}

.v2-content__side {
  position: absolute;
  top: var(--s-4);
  right: var(--s-4);
  bottom: var(--s-4);
  background: var(--paper);
  border: 1px solid var(--rule);
  border-radius: var(--r-2);
  display: flex;
  z-index: 4;
  overflow: hidden;
  flex-direction: column;
  width: 420px;
  box-shadow: 0 6px 20px -10px #1a1a1a2e;
}

@media (max-width: 1100px) {
  .v2-content__side {
    width: 360px;
  }
}

@media (max-width: 900px) {
  .v2-content__side {
    display: none;
  }
}

.v2-content__side-head {
  display: flex;
  justify-content: space-between;
  align-items:  center;
  gap: var(--s-3);
  padding: var(--s-3) var(--s-5);
  border-bottom: var(--hair-soft);
  background: var(--paper-2);
}

.v2-content__side-meta {
  display: inline-flex;
  align-items:  center;
  gap: var(--s-2);
}

.v2-content__side-body {
  overflow-y: auto;
  padding: var(--s-4) var(--s-5);
  display: flex;
  gap: var(--s-4);
  flex-direction: column;
  flex: 1;
}

.v2-content__side-title-input {
  background: var(--paper);
  border-radius: var(--r-1);
  font-family: var(--font-display);
  font-size: var(--text-lg);
  color: var(--ink);
  border: 1px solid #0000;
  width: 100%;
  padding: 6px 10px;
  line-height: 1.3;
}

.v2-content__side-title-input:hover {
  border-color: var(--rule-soft);
}

.v2-content__side-title-input:focus {
  outline: 2px solid var(--accent);
  outline-offset: -2px;
  border-color: #0000;
}

.v2-content__field {
  display: flex;
  gap: var(--s-2);
  flex-direction: column;
}

.v2-content__field-label {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--ink-3);
}

.v2-content__input, .v2-content__textarea {
  background: var(--paper);
  border: 1px solid var(--rule);
  border-radius: var(--r-1);
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  color: var(--ink);
  width: 100%;
  padding: 8px 12px;
}

.v2-content__textarea {
  resize: vertical;
  font-family: var(--font-display);
  line-height: var(--lh-body);
  min-height: 120px;
}

.v2-content__input:focus, .v2-content__textarea:focus {
  outline: 2px solid var(--accent);
  outline-offset: -2px;
}

.v2-content__side-actions {
  display: flex;
  align-items:  center;
  gap: var(--s-2);
}

.v2-content__side-actions-spacer {
  flex: 1;
}

.v2-content__side-section {
  display: flex;
  gap: var(--s-2);
  padding-top: var(--s-3);
  border-top: var(--hair-soft);
  flex-direction: column;
}

.v2-content__side-label {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--ink-3);
}

.v2-content__notes {
  list-style: none;
  display: flex;
  gap: var(--s-2);
  flex-direction: column;
  margin: 0;
  padding: 0;
}

.v2-content__note {
  background: var(--paper-2);
  border: 1px solid var(--rule-soft);
  border-radius: var(--r-1);
  padding: var(--s-2) var(--s-3);
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.v2-content__note-meta {
  display: flex;
  font-family: var(--font-mono);
  color: var(--ink-3);
  letter-spacing: .05em;
  justify-content: space-between;
  align-items:  center;
  font-size: 10px;
}

.v2-content__note-stage {
  text-transform: uppercase;
  color: var(--ink-2);
}

.v2-content__note-text {
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  color: var(--ink);
  line-height: var(--lh-body);
  word-break: break-word;
}

.v2-content__note-add {
  display: flex;
  align-items:  center;
  gap: var(--s-2);
}

.v2-content__attachments {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 4px;
  margin: 0;
  padding: 0;
}

.v2-content__attachment {
  display: grid;
  grid-template-columns: 14px 1fr auto auto;
  align-items:  center;
  gap: var(--s-2);
  background: var(--paper-2);
  border: 1px solid var(--rule-soft);
  border-radius: var(--r-1);
  padding: 6px 10px;
}

.v2-content__attachment-name {
  font-family: var(--font-sans);
  font-size: var(--text-xs);
  color: var(--ink);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.v2-content__attachment-size {
  font-family: var(--font-mono);
  color: var(--ink-3);
  font-size: 10px;
}

.v2-content__chip-row {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.v2-content__chip {
  background: var(--paper-2);
  border: 1px solid var(--rule);
  border-radius: var(--r-pill);
  font-family: var(--font-sans);
  font-size: var(--text-xs);
  color: var(--ink-2);
  cursor: pointer;
  transition: background var(--dur-fast) var(--ease-out), color var(--dur-fast) var(--ease-out), border-color var(--dur-fast) var(--ease-out);
  padding: 4px 12px;
}

.v2-content__chip:hover {
  background: var(--paper-3);
  color: var(--ink);
}

.v2-content__chip[data-active="true"] {
  background: var(--ink);
  color: var(--paper);
  border-color: var(--ink);
}

.v2-content__icon-btn {
  display: inline-flex;
  color: var(--ink-3);
  border-radius: var(--r-pill);
  cursor: pointer;
  transition: background var(--dur-fast) var(--ease-out), color var(--dur-fast) var(--ease-out);
  background: none;
  border: 0;
  justify-content: center;
  align-items:  center;
  width: 24px;
  height: 24px;
}

.v2-content__icon-btn:hover {
  background: var(--paper-3);
  color: var(--ink);
}

.v2-content__btn {
  display: inline-flex;
  border-radius: var(--r-pill);
  font-family: var(--font-sans);
  font-size: var(--text-xs);
  cursor: pointer;
  border: 1px solid var(--rule);
  transition: background var(--dur-fast) var(--ease-out), color var(--dur-fast) var(--ease-out);
  align-items:  center;
  gap: 4px;
  padding: 6px 12px;
}

.v2-content__btn--secondary {
  color: var(--ink-2);
  background: none;
}

.v2-content__btn--secondary:hover {
  background: var(--paper-3);
  color: var(--ink);
}

.v2-content__btn--primary {
  background: var(--ink);
  color: var(--paper);
  border-color: var(--ink);
}

.v2-content__btn--primary:hover {
  background: var(--ink-2);
}

.v2-content__btn--danger {
  color: var(--accent);
  border-color: var(--accent);
  background: none;
}

.v2-content__btn--danger:hover {
  background: var(--accent);
  color: var(--accent-ink);
}

.v2-content__btn:disabled {
  opacity: .5;
  cursor: default;
}

.v2-content__overlay {
  position: fixed;
  display: flex;
  padding: var(--s-4);
  z-index: 65;
  background: #1a1a1a66;
  justify-content: center;
  align-items:  center;
  inset: 0;
}

.v2-content__dialog {
  background: var(--paper);
  border: 1px solid var(--rule);
  border-radius: var(--r-2);
  display: flex;
  overflow: hidden;
  flex-direction: column;
  width: 100%;
  max-width: 520px;
}

.v2-content__dialog-head {
  display: flex;
  padding: var(--s-4) var(--s-5);
  border-bottom: var(--hair-soft);
  background: var(--paper-2);
  justify-content: space-between;
  align-items:  flex-start;
}

.v2-content__dialog-title {
  font-family: var(--font-display);
  font-size: var(--text-lg);
  color: var(--ink);
}

.v2-content__dialog-subtitle {
  font-family: var(--font-sans);
  font-size: var(--text-xs);
  color: var(--ink-3);
  margin-top: 2px;
}

.v2-content__dialog-body {
  padding: var(--s-5);
  display: flex;
  gap: var(--s-4);
  flex-direction: column;
}

.v2-content__dialog-foot {
  display: flex;
  justify-content: flex-end;
  gap: var(--s-2);
  padding: var(--s-3) var(--s-5);
  border-top: var(--hair-soft);
  background: var(--paper-2);
}

.v2-content__empty {
  padding: var(--s-8) var(--s-4);
  text-align: center;
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  color: var(--ink-3);
}

.v2-content__empty-line {
  font-family: var(--font-sans);
  font-size: var(--text-xs);
  color: var(--ink-3);
  padding: var(--s-2) 0;
  font-style: italic;
}

.v2-content__error {
  padding: var(--s-3) var(--s-6);
  background: color-mix(in srgb, var(--accent) 8%, transparent);
  color: var(--accent);
  font-family: var(--font-sans);
  font-size: var(--text-xs);
  border-bottom: var(--hair-soft);
}

.v2-content__toast {
  position: absolute;
  right: var(--s-4);
  bottom: var(--s-4);
  padding: var(--s-3) var(--s-4);
  background: var(--ink);
  color: var(--paper);
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  border-radius: var(--r-2);
  z-index: 6;
  max-width: 360px;
  box-shadow: 0 6px 20px -10px #1a1a1a66;
}

.v2-content__toast[data-tone="warn"] {
  background: var(--accent);
}

.v2-content--inline .v2-content__stats {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  padding: var(--s-3) var(--s-4) var(--s-2);
}

.v2-content--inline .v2-content__toolbar {
  padding: var(--s-2) var(--s-4);
}

.v2-content--inline .v2-content__kanban {
  grid-template-columns: repeat(8, minmax(160px, 180px));
}

/* ui/src/v2/rooms/workspaces/WorkspacesRoom.css */
.v2-ws {
  display: flex;
  position: relative;
  flex-direction: column;
  height: 100%;
  min-height: 0;
}

.v2-ws__stats {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: var(--s-3);
  padding: var(--s-4) var(--s-6) var(--s-3);
}

@media (max-width: 720px) {
  .v2-ws__stats {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

.v2-ws__stat {
  background: var(--paper-2);
  border: 1px solid var(--rule-soft);
  border-radius: var(--r-2);
  padding: var(--s-3) var(--s-4);
  display: flex;
  flex-direction: column;
  gap: 2px;
  min-width: 0;
}

.v2-ws__stat[data-tone="ok"] {
  border-color: color-mix(in srgb, var(--ok) 40%, var(--rule-soft));
}

.v2-ws__stat[data-tone="warn"] {
  border-color: var(--warn);
}

.v2-ws__stat[data-tone="accent"] {
  border-color: var(--accent);
}

.v2-ws__stat-label {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--ink-3);
}

.v2-ws__stat-value {
  font-family: var(--font-display);
  font-size: var(--text-xl);
  color: var(--ink);
  line-height: 1.1;
}

.v2-ws__stat[data-tone="warn"] .v2-ws__stat-value {
  color: var(--warn);
}

.v2-ws__stat[data-tone="ok"] .v2-ws__stat-value {
  color: var(--ok);
}

.v2-ws__stat[data-tone="accent"] .v2-ws__stat-value {
  color: var(--accent);
}

.v2-ws__stat-sub {
  font-family: var(--font-sans);
  font-size: var(--text-xs);
  color: var(--ink-3);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.v2-ws__toolbar {
  display: flex;
  align-items:  center;
  gap: var(--s-2);
  padding: var(--s-3) var(--s-6);
  border-bottom: var(--hair-soft);
  flex-wrap: wrap;
}

.v2-ws__search {
  display: inline-flex;
  align-items:  center;
  gap: var(--s-2);
  background: var(--paper-2);
  border: 1px solid var(--rule);
  border-radius: var(--r-pill);
  color: var(--ink-3);
  flex: 1;
  min-width: 180px;
  max-width: 360px;
  padding: 6px 10px;
}

.v2-ws__search:focus-within {
  border-color: var(--ink-3);
  color: var(--ink-2);
}

.v2-ws__search-input {
  outline: 0;
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  color: var(--ink);
  background: none;
  border: 0;
  flex: 1;
}

.v2-ws__search-input::placeholder {
  color: var(--ink-3);
}

.v2-ws__refresh, .v2-ws__new-btn {
  display: inline-flex;
  justify-content: center;
  align-items:  center;
  gap: var(--s-2);
  border-radius: var(--r-pill);
  cursor: pointer;
  transition: background var(--dur-fast) var(--ease-out);
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  height: 28px;
}

.v2-ws__refresh {
  border: 1px solid var(--rule);
  background: var(--paper);
  color: var(--ink-2);
  width: 28px;
}

.v2-ws__refresh:hover {
  background: var(--paper-3);
  color: var(--ink);
}

.v2-ws__new-btn {
  background: var(--ink);
  color: var(--paper);
  border: 0;
  padding: 0 12px;
}

.v2-ws__new-btn:hover {
  background: var(--ink-2);
}

.v2-ws__grid {
  list-style: none;
  padding: var(--s-4) var(--s-6) var(--s-6);
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
  gap: var(--s-3);
  overflow-y: auto;
  flex: 1;
  min-height: 0;
  margin: 0;
}

@media (max-width: 720px) {
  .v2-ws__grid {
    grid-template-columns: 1fr;
    padding: var(--s-3) var(--s-4);
  }
}

.v2-ws__card {
  background: var(--paper-2);
  border: 1px solid var(--rule);
  border-radius: var(--r-2);
  padding: var(--s-3) var(--s-4);
  display: flex;
  gap: var(--s-3);
  transition: background var(--dur-fast) var(--ease-out), border-color var(--dur-fast) var(--ease-out);
  flex-direction: column;
}

.v2-ws__card:hover {
  background: var(--paper);
  border-color: var(--ink-3);
}

.v2-ws__card[data-status="running"] {
  border-color: color-mix(in srgb, var(--ok) 40%, var(--rule));
}

.v2-ws__card[data-status="error"] {
  border-color: var(--accent);
}

.v2-ws__card-head {
  display: flex;
  align-items:  flex-start;
  gap: var(--s-3);
}

.v2-ws__card-icon {
  border-radius: var(--r-2);
  background: var(--paper-3);
  color: var(--ink-2);
  display: inline-flex;
  flex-shrink: 0;
  justify-content: center;
  align-items:  center;
  width: 36px;
  height: 36px;
}

.v2-ws__card-id {
  display: flex;
  flex-direction: column;
  flex: 1;
  gap: 4px;
  min-width: 0;
}

.v2-ws__card-name {
  text-align: left;
  font-family: var(--font-display);
  font-size: var(--text-md);
  color: var(--ink);
  cursor: pointer;
  word-break: break-word;
  background: none;
  border: 0;
  padding: 0;
  line-height: 1.2;
}

.v2-ws__card-name:hover {
  text-decoration: underline;
  text-decoration-color: var(--ink-3);
  text-underline-offset: 3px;
}

.v2-ws__card-meta {
  display: flex;
  align-items:  center;
  gap: var(--s-2);
  flex-wrap: wrap;
}

.v2-ws__framework {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: var(--ink-3);
  letter-spacing: .05em;
}

.v2-ws__card-info {
  display: flex;
  align-items:  center;
  gap: var(--s-3);
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: var(--ink-3);
  flex-wrap: wrap;
}

.v2-ws__card-branch, .v2-ws__card-port {
  display: inline-flex;
  color: var(--ink-2);
  align-items:  center;
  gap: 4px;
}

.v2-ws__card-port {
  color: var(--ok);
}

.v2-ws__dirty {
  color: var(--warn);
  font-size: 14px;
  line-height: 1;
}

.v2-ws__card-github {
  color: var(--ink-3);
  display: inline-flex;
  text-decoration: none;
  align-items:  center;
}

.v2-ws__card-github:hover {
  color: var(--ink);
}

.v2-ws__card-time {
  white-space: nowrap;
  margin-left: auto;
}

.v2-ws__card-actions {
  display: flex;
  align-items:  center;
  gap: var(--s-2);
  padding-top: var(--s-2);
  border-top: var(--hair-soft);
}

.v2-ws__card-actions-spacer {
  flex: 1;
}

.v2-ws__btn {
  display: inline-flex;
  border-radius: var(--r-pill);
  font-family: var(--font-sans);
  font-size: var(--text-xs);
  cursor: pointer;
  border: 1px solid var(--rule);
  color: var(--ink-2);
  transition: background var(--dur-fast) var(--ease-out), color var(--dur-fast) var(--ease-out), border-color var(--dur-fast) var(--ease-out);
  background: none;
  align-items:  center;
  gap: 4px;
  padding: 6px 12px;
}

.v2-ws__btn--secondary:hover {
  background: var(--paper-3);
  color: var(--ink);
}

.v2-ws__btn--primary {
  background: var(--ink);
  color: var(--paper);
  border-color: var(--ink);
}

.v2-ws__btn--primary:hover {
  background: var(--ink-2);
}

.v2-ws__btn--icon {
  color: var(--ink-3);
  justify-content: center;
  width: 28px;
  height: 28px;
  padding: 0;
}

.v2-ws__btn--icon:hover {
  background: var(--paper-3);
  color: var(--accent);
  border-color: var(--accent);
}

.v2-ws--detail {
  display: flex;
  flex-direction: column;
  height: 100%;
  min-height: 0;
}

.v2-ws__detail-chrome {
  display: flex;
  align-items:  center;
  gap: var(--s-4);
  padding: var(--s-3) var(--s-6);
  border-bottom: var(--hair-soft);
  background: var(--paper-2);
  flex-wrap: wrap;
  flex-shrink: 0;
}

.v2-ws__back-btn {
  display: inline-flex;
  border: 1px solid var(--rule);
  border-radius: var(--r-pill);
  font-family: var(--font-sans);
  font-size: var(--text-xs);
  color: var(--ink-2);
  cursor: pointer;
  transition: background var(--dur-fast) var(--ease-out), color var(--dur-fast) var(--ease-out);
  background: none;
  align-items:  center;
  gap: 4px;
  padding: 4px 10px 4px 6px;
}

.v2-ws__back-btn:hover {
  background: var(--paper-3);
  color: var(--ink);
}

.v2-ws__detail-title {
  display: flex;
  align-items:  center;
  gap: var(--s-3);
  flex-wrap: wrap;
  flex: 1;
  min-width: 0;
}

.v2-ws__project-name {
  font-family: var(--font-display);
  font-size: var(--text-md);
  color: var(--ink);
  word-break: break-word;
}

.v2-ws__branch, .v2-ws__port {
  display: inline-flex;
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: var(--ink-2);
  align-items:  center;
  gap: 4px;
}

.v2-ws__port {
  color: var(--ok);
}

.v2-ws__detail-ide {
  display: flex;
  overflow: hidden;
  background: var(--paper);
  --j-bg: var(--paper);
  --j-surface: var(--paper-2);
  --j-border: var(--rule);
  --j-text: var(--ink);
  --j-text-dim: var(--ink-2);
  --j-text-muted: var(--ink-3);
  --j-accent: var(--ink);
  --j-success: var(--ok);
  --j-warning: var(--warn);
  --j-error: var(--accent);
  flex-direction: column;
  flex: 1;
  min-height: 0;
}

.v2-ws__detail-ide iframe {
  background: var(--paper);
}

.v2-ws__detail-ide .cm-editor {
  background: var(--paper);
  color: var(--ink);
}

.v2-ws__detail-ide .cm-editor .cm-gutters {
  background: var(--paper-2);
  color: var(--ink-3);
  border-right: 1px solid var(--rule-soft);
}

.v2-ws__detail-ide .cm-editor .cm-activeLineGutter, .v2-ws__detail-ide .cm-editor .cm-activeLine {
  background: var(--paper-3);
}

.v2-ws__detail-ide .cm-editor .cm-cursor {
  border-left-color: var(--ink);
}

.v2-ws__detail-ide .cm-editor .cm-selectionBackground, .v2-ws__detail-ide .cm-editor ::selection {
  background: color-mix(in srgb, var(--accent) 18%, transparent) !important;
}

.v2-ws__detail-split {
  display: grid;
  grid-template-columns: 280px 1fr;
  overflow: hidden;
  flex: 1;
  min-height: 0;
}

@media (max-width: 900px) {
  .v2-ws__detail-split {
    grid-template-columns: 220px 1fr;
  }
}

@media (max-width: 720px) {
  .v2-ws__detail-split {
    grid-template-columns: 1fr;
  }
}

.v2-ws__empty {
  padding: var(--s-8) var(--s-4);
  text-align: center;
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  color: var(--ink-3);
}

.v2-ws__error {
  padding: var(--s-3) var(--s-6);
  background: color-mix(in srgb, var(--accent) 8%, transparent);
  color: var(--accent);
  font-family: var(--font-sans);
  font-size: var(--text-xs);
  border-bottom: var(--hair-soft);
}

.v2-ws__toast {
  position: absolute;
  right: var(--s-4);
  bottom: var(--s-4);
  padding: var(--s-3) var(--s-4);
  background: var(--ink);
  color: var(--paper);
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  border-radius: var(--r-2);
  z-index: 6;
  max-width: 360px;
  box-shadow: 0 6px 20px -10px #1a1a1a66;
}

.v2-ws__toast[data-tone="warn"] {
  background: var(--accent);
}

.v2-ws--inline .v2-ws__stats {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  padding: var(--s-3) var(--s-4) var(--s-2);
}

.v2-ws--inline .v2-ws__toolbar {
  padding: var(--s-2) var(--s-4);
}

.v2-ws--inline .v2-ws__grid {
  grid-template-columns: 1fr;
  padding: var(--s-3) var(--s-4);
  gap: var(--s-2);
}

.v2-ws--inline .v2-ws__card {
  padding: var(--s-2) var(--s-3);
}

/* ui/src/v2/rooms/settings/SettingsRoom.css */
.v2-set {
  display: flex;
  position: relative;
  flex-direction: column;
  height: 100%;
  min-height: 0;
}

.v2-set__stats {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: var(--s-3);
  padding: var(--s-4) var(--s-6) var(--s-3);
}

@media (max-width: 720px) {
  .v2-set__stats {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

.v2-set__stat {
  background: var(--paper-2);
  border: 1px solid var(--rule-soft);
  border-radius: var(--r-2);
  padding: var(--s-3) var(--s-4);
  display: flex;
  flex-direction: column;
  gap: 2px;
  min-width: 0;
}

.v2-set__stat[data-tone="ok"] {
  border-color: color-mix(in srgb, var(--ok) 40%, var(--rule-soft));
}

.v2-set__stat[data-tone="warn"] {
  border-color: var(--warn);
}

.v2-set__stat[data-tone="accent"] {
  border-color: var(--accent);
}

.v2-set__stat-label {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--ink-3);
}

.v2-set__stat-value {
  font-family: var(--font-display);
  font-size: var(--text-xl);
  color: var(--ink);
  line-height: 1.1;
}

.v2-set__stat[data-tone="warn"] .v2-set__stat-value {
  color: var(--warn);
}

.v2-set__stat[data-tone="ok"] .v2-set__stat-value {
  color: var(--ok);
}

.v2-set__stat[data-tone="accent"] .v2-set__stat-value {
  color: var(--accent);
}

.v2-set__stat-sub {
  font-family: var(--font-sans);
  font-size: var(--text-xs);
  color: var(--ink-3);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.v2-set__banner {
  display: flex;
  align-items:  center;
  gap: var(--s-3);
  margin: 0 var(--s-6) var(--s-3);
  padding: var(--s-3) var(--s-4);
  background: color-mix(in srgb, var(--warn) 12%, var(--paper));
  border: 1px solid var(--warn);
  border-radius: var(--r-2);
  color: var(--ink);
  font-family: var(--font-sans);
  font-size: var(--text-sm);
}

.v2-set__banner > svg {
  color: var(--warn);
  flex-shrink: 0;
}

.v2-set__banner > span {
  flex: 1;
}

.v2-set__banner-btn {
  background: var(--ink);
  color: var(--paper);
  border-radius: var(--r-pill);
  font-family: var(--font-sans);
  font-size: var(--text-xs);
  cursor: pointer;
  border: 0;
  padding: 4px 12px;
  font-weight: 600;
}

.v2-set__banner-btn:hover {
  background: var(--ink-2);
}

.v2-set__banner-dismiss {
  color: var(--ink-3);
  cursor: pointer;
  font-family: var(--font-sans);
  font-size: var(--text-md);
  background: none;
  border: 0;
  padding: 0 4px;
  line-height: 1;
}

.v2-set__banner-dismiss:hover {
  color: var(--ink);
}

.v2-set__tabs {
  display: flex;
  padding: 0 var(--s-6);
  border-bottom: var(--hair-soft);
  overflow-x: auto;
  flex-shrink: 0;
  align-items:  center;
  gap: 0;
}

.v2-set__tab {
  display: inline-flex;
  padding: var(--s-3) var(--s-4);
  color: var(--ink-3);
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  cursor: pointer;
  white-space: nowrap;
  transition: color var(--dur-fast) var(--ease-out), border-color var(--dur-fast) var(--ease-out);
  background: none;
  border: 0;
  border-bottom: 2px solid #0000;
  align-items:  center;
  gap: 6px;
}

.v2-set__tab:hover {
  color: var(--ink);
}

.v2-set__tab:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: -2px;
}

.v2-set__tab[data-active="true"] {
  color: var(--ink);
  border-bottom-color: var(--ink);
}

.v2-set__body {
  overflow-y: auto;
  padding: var(--s-5) var(--s-6) var(--s-8);
  flex: 1;
  min-height: 0;
}

.v2-set__section {
  background: var(--paper-2);
  border: 1px solid var(--rule-soft);
  border-radius: var(--r-2);
  padding: var(--s-4) var(--s-5);
  margin-bottom: var(--s-4);
  display: flex;
  gap: var(--s-3);
  flex-direction: column;
}

.v2-set__section-head {
  display: flex;
  justify-content: space-between;
  align-items:  flex-start;
  gap: var(--s-3);
  flex-wrap: wrap;
}

.v2-set__section-title {
  font-family: var(--font-display);
  font-size: var(--text-md);
  color: var(--ink);
  margin: 0;
  line-height: 1.2;
}

.v2-set__section-sub {
  font-family: var(--font-sans);
  font-size: var(--text-xs);
  color: var(--ink-3);
  margin-top: 2px;
}

.v2-set__field {
  display: flex;
  gap: var(--s-2);
  flex-direction: column;
}

.v2-set__field-label {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--ink-3);
}

.v2-set__row {
  display: flex;
  justify-content: space-between;
  align-items:  center;
  gap: var(--s-3);
  font-family: var(--font-sans);
  font-size: var(--text-sm);
}

.v2-set__row-label {
  color: var(--ink-2);
}

.v2-set__row-value {
  color: var(--ink);
}

.v2-set__input, .v2-set__textarea, .v2-set__select {
  background: var(--paper);
  border: 1px solid var(--rule);
  border-radius: var(--r-1);
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  color: var(--ink);
  outline: 0;
  box-sizing: border-box;
  width: 100%;
  padding: 8px 12px;
}

.v2-set__textarea {
  resize: vertical;
  font-family: var(--font-display);
  line-height: var(--lh-body);
  min-height: 100px;
}

.v2-set__select {
  cursor: pointer;
}

.v2-set__input:focus, .v2-set__textarea:focus, .v2-set__select:focus {
  outline: 2px solid var(--accent);
  outline-offset: -2px;
}

.v2-set__hint {
  font-family: var(--font-sans);
  font-size: var(--text-xs);
  color: var(--ink-3);
  margin: 0;
  line-height: 1.5;
}

.v2-set__hint a {
  color: var(--accent);
}

.v2-set__hint code, .v2-set__code {
  display: inline-block;
  background: var(--paper-3);
  border-radius: var(--r-1);
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: var(--ink-2);
  padding: 2px 6px;
}

.v2-set__code--block {
  display: block;
  padding: var(--s-2) var(--s-3);
  word-break: break-all;
  margin-top: 4px;
}

.v2-set__btn {
  display: inline-flex;
  border-radius: var(--r-pill);
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  cursor: pointer;
  border: 1px solid var(--rule);
  color: var(--ink-2);
  transition: background var(--dur-fast) var(--ease-out), color var(--dur-fast) var(--ease-out), border-color var(--dur-fast) var(--ease-out);
  background: none;
  justify-content: center;
  align-items:  center;
  gap: 4px;
  padding: 6px 14px;
}

.v2-set__btn:hover {
  background: var(--paper-3);
  color: var(--ink);
}

.v2-set__btn:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 2px;
}

.v2-set__btn--primary {
  background: var(--ink);
  color: var(--paper);
  border-color: var(--ink);
}

.v2-set__btn--primary:hover {
  background: var(--ink-2);
}

.v2-set__btn--danger {
  color: var(--accent);
  border-color: var(--accent);
}

.v2-set__btn--danger:hover {
  background: var(--accent);
  color: var(--accent-ink);
}

.v2-set__btn:disabled {
  opacity: .5;
  cursor: default;
}

.v2-set__toggle {
  position: relative;
  background: var(--rule);
  cursor: pointer;
  transition: background var(--dur-fast) var(--ease-out);
  border: 0;
  border-radius: 10px;
  flex-shrink: 0;
  width: 36px;
  height: 20px;
  padding: 0;
}

.v2-set__toggle[data-checked="true"] {
  background: var(--ink);
}

.v2-set__toggle:after {
  content: "";
  position: absolute;
  background: var(--paper);
  transition: left var(--dur-fast) var(--ease-out);
  border-radius: 50%;
  width: 16px;
  height: 16px;
  top: 2px;
  left: 2px;
}

.v2-set__toggle[data-checked="true"]:after {
  left: 18px;
}

.v2-set__toggle-row {
  display: flex;
  align-items:  center;
  gap: var(--s-3);
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  color: var(--ink);
  cursor: pointer;
  user-select: none;
}

.v2-set__dot {
  background: var(--ink-3);
  display: inline-block;
  border-radius: 50%;
  flex-shrink: 0;
  width: 8px;
  height: 8px;
}

.v2-set__dot--ok {
  background: var(--ok);
}

.v2-set__dot--warn {
  background: var(--warn);
}

.v2-set__dot--accent {
  background: var(--accent);
}

.v2-set__chip {
  display: inline-flex;
  border-radius: var(--r-pill);
  background: var(--paper-3);
  color: var(--ink-2);
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  align-items:  center;
  gap: 4px;
  padding: 2px 8px;
}

.v2-set__chip--ok {
  background: color-mix(in srgb, var(--ok) 14%, transparent);
  color: var(--ok);
}

.v2-set__chip--warn {
  background: color-mix(in srgb, var(--warn) 14%, transparent);
  color: var(--warn);
}

.v2-set__chip--accent {
  background: color-mix(in srgb, var(--accent) 14%, transparent);
  color: var(--accent);
}

.v2-set__provider {
  background: var(--paper);
  border: 1px solid var(--rule);
  border-radius: var(--r-2);
  padding: var(--s-3) var(--s-4);
  display: flex;
  gap: var(--s-3);
  flex-direction: column;
}

.v2-set__provider-head {
  display: flex;
  align-items:  center;
  gap: var(--s-3);
  cursor: pointer;
  user-select: none;
  text-align: left;
  background: none;
  border: 0;
  width: 100%;
  padding: 0;
}

.v2-set__provider-name {
  font-family: var(--font-display);
  font-size: var(--text-md);
  color: var(--ink);
  flex: 1;
}

.v2-set__provider[data-primary="true"] {
  border-color: var(--ink);
}

.v2-set__provider-fields {
  display: flex;
  gap: var(--s-3);
  padding-top: var(--s-2);
  border-top: var(--hair-soft);
  flex-direction: column;
}

.v2-set__provider-actions {
  display: flex;
  align-items:  center;
  gap: var(--s-2);
  flex-wrap: wrap;
}

.v2-set__provider-actions-spacer {
  flex: 1;
}

.v2-set__test-result {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: var(--ink-3);
}

.v2-set__test-result[data-ok="true"] {
  color: var(--ok);
}

.v2-set__test-result[data-ok="false"] {
  color: var(--accent);
}

.v2-set__sidecar-list {
  list-style: none;
  display: flex;
  gap: var(--s-2);
  flex-direction: column;
  margin: 0;
  padding: 0;
}

.v2-set__sidecar {
  background: var(--paper);
  border: 1px solid var(--rule);
  border-radius: var(--r-2);
  padding: var(--s-3) var(--s-4);
  display: flex;
  align-items:  center;
  gap: var(--s-3);
  flex-wrap: wrap;
}

.v2-set__sidecar-name {
  font-family: var(--font-display);
  font-size: var(--text-md);
  color: var(--ink);
}

.v2-set__sidecar-meta {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: var(--ink-3);
  display: flex;
  gap: var(--s-2);
  flex-wrap: wrap;
  flex: 1;
  min-width: 0;
}

.v2-set__sidecar-actions {
  display: flex;
  align-items:  center;
  gap: var(--s-2);
}

.v2-set__token-box {
  background: color-mix(in srgb, var(--ok) 8%, var(--paper));
  border: 1px dashed var(--ok);
  border-radius: var(--r-2);
  padding: var(--s-3) var(--s-4);
  display: flex;
  gap: var(--s-2);
  flex-direction: column;
}

.v2-set__token-label {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--ok);
}

.v2-set__wizard-progress {
  background: var(--paper-3);
  border-radius: var(--r-pill);
  overflow: hidden;
  height: 6px;
}

.v2-set__wizard-progress-fill {
  background: var(--ink);
  transition: width var(--dur-base) var(--ease-out);
  height: 100%;
}

.v2-set__wizard-step {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--ink-3);
}

.v2-set__profile-snapshot {
  display: grid;
  gap: var(--s-3);
}

.v2-set__profile-group {
  border: 1px solid var(--rule-soft);
  border-radius: var(--r-2);
  padding: var(--s-3) var(--s-4);
  background: var(--paper);
}

.v2-set__profile-group-title {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--ink-3);
  margin-bottom: var(--s-2);
}

.v2-set__profile-question {
  font-size: var(--text-sm);
  color: var(--ink);
}

.v2-set__profile-answer {
  font-family: var(--font-display);
  font-size: var(--text-sm);
  color: var(--ink-2);
  line-height: var(--lh-body);
  white-space: pre-wrap;
  margin-top: 4px;
}

.v2-set__pers-bar {
  background: var(--paper-3);
  overflow: hidden;
  border-radius: 2px;
  height: 4px;
  margin-top: 2px;
}

.v2-set__pers-bar-fill {
  background: var(--ink);
  height: 100%;
}

.v2-set__chip-row {
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
}

.v2-set__empty {
  padding: var(--s-8) var(--s-4);
  text-align: center;
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  color: var(--ink-3);
}

.v2-set__error {
  padding: var(--s-3) var(--s-4);
  background: color-mix(in srgb, var(--accent) 8%, transparent);
  color: var(--accent);
  font-family: var(--font-sans);
  font-size: var(--text-xs);
  border-radius: var(--r-2);
}

.v2-set__toast {
  position: absolute;
  right: var(--s-4);
  bottom: var(--s-4);
  padding: var(--s-3) var(--s-4);
  background: var(--ink);
  color: var(--paper);
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  border-radius: var(--r-2);
  z-index: 6;
  max-width: 360px;
  box-shadow: 0 6px 20px -10px #1a1a1a66;
}

.v2-set__toast[data-tone="warn"] {
  background: var(--accent);
}

.v2-set__overlay {
  position: fixed;
  display: flex;
  padding: var(--s-4);
  z-index: 65;
  background: #1a1a1a66;
  justify-content: center;
  align-items:  center;
  inset: 0;
}

.v2-set__dialog {
  background: var(--paper);
  border: 1px solid var(--rule);
  border-radius: var(--r-2);
  display: flex;
  overflow: hidden;
  flex-direction: column;
  width: 100%;
  max-width: 520px;
  max-height: 90vh;
}

.v2-set__dialog-head {
  padding: var(--s-4) var(--s-5);
  border-bottom: var(--hair-soft);
  background: var(--paper-2);
}

.v2-set__dialog-body {
  padding: var(--s-5);
  display: flex;
  gap: var(--s-4);
  overflow-y: auto;
  flex-direction: column;
}

.v2-set__dialog-foot {
  display: flex;
  justify-content: flex-end;
  gap: var(--s-2);
  padding: var(--s-3) var(--s-5);
  border-top: var(--hair-soft);
  background: var(--paper-2);
}

.v2-set__legacy-embed {
  --j-bg: var(--paper);
  --j-surface: var(--paper-2);
  --j-border: var(--rule);
  --j-text: var(--ink);
  --j-text-dim: var(--ink-2);
  --j-text-muted: var(--ink-3);
  --j-accent: var(--ink);
  --j-success: var(--ok);
  --j-warning: var(--warn);
  --j-error: var(--accent);
}

.v2-set--inline .v2-set__stats {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  padding: var(--s-3) var(--s-4) var(--s-2);
}

.v2-set--inline .v2-set__tabs {
  padding: 0 var(--s-4);
}

.v2-set--inline .v2-set__tab {
  padding: var(--s-2) var(--s-3);
}

.v2-set--inline .v2-set__body {
  padding: var(--s-3) var(--s-4);
}

.v2-set--inline .v2-set__banner {
  margin: 0 var(--s-4) var(--s-3);
}

/* ui/src/v2/rooms/RoomWindow.css */
.v2-roomwin {
  display: flex;
  background: var(--paper);
  border: 1px solid var(--rule);
  border-radius: var(--r-2);
  overflow: hidden;
  flex-direction: column;
  box-shadow: 0 1px #1a1a1a0a, 4px 4px #1a1a1a0a;
}

.v2-roomwin--focus-pulse {
  animation: v2-roomwin-pulse .6s var(--ease-out);
}

@keyframes v2-roomwin-pulse {
  0%, 100% {
    box-shadow: 0 1px #1a1a1a0a, 4px 4px #1a1a1a0a;
  }

  50% {
    box-shadow: 0 0 0 3px #c23a2a2e, 4px 4px #1a1a1a0a;
  }
}

@media (prefers-reduced-motion: reduce) {
  .v2-roomwin--focus-pulse {
    animation: none;
    box-shadow: 0 0 0 2px var(--accent), 4px 4px 0 0 #1a1a1a0a;
  }
}

.v2-roomwin__chrome {
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items:  center;
  gap: var(--s-3);
  background: var(--paper-2);
  border-bottom: var(--hair-soft);
  user-select: none;
  cursor: default;
  padding: 8px 12px;
}

.v2-roomwin--minimized .v2-roomwin__chrome {
  cursor: pointer;
  border-bottom: 0;
}

.v2-roomwin__lights {
  display: inline-flex;
  align-items:  center;
  gap: 6px;
}

.v2-roomwin__light {
  border-radius: var(--r-pill);
  cursor: pointer;
  transition: filter var(--dur-fast) var(--ease-out), transform var(--dur-fast) var(--ease-out);
  border: 1px solid #1a1a1a2e;
  width: 12px;
  height: 12px;
  padding: 0;
}

.v2-roomwin__light--close {
  background: #d88b85;
}

.v2-roomwin__light--minimize {
  background: #d4b47a;
}

.v2-roomwin__light--expand {
  background: #95b89a;
}

.v2-roomwin__light:hover {
  filter: brightness(1.08) saturate(1.1);
  transform: scale(1.05);
}

.v2-roomwin__light:active {
  transform: scale(.92);
}

.v2-roomwin__light:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 2px;
}

.v2-roomwin__title {
  font-family: var(--font-display);
  font-size: var(--text-md);
  color: var(--ink);
  text-align: center;
  letter-spacing: -.005em;
}

.v2-roomwin__meta {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--ink-3);
}

.v2-roomwin__body {
  overflow: hidden;
  display: flex;
  flex-direction: column;
  height: clamp(280px, 50vh, 600px);
}

.v2-roomwin__body > * {
  overflow: auto;
  flex: 1;
  min-height: 0;
}

@media (max-width: 700px) {
  .v2-roomwin__body {
    height: clamp(240px, 60vh, 480px);
  }
}

.v2-roomwin--floating {
  border: 1px solid var(--rule);
  border-radius: var(--r-2);
  z-index: 30;
  display: flex;
  overflow: hidden;
  background: var(--paper);
  flex-direction: column;
  box-shadow: 0 1px #1a1a1a0a, 6px 8px #1a1a1a14, 0 0 #1a1a1a00;
}

.v2-roomwin--floating.v2-roomwin--focused {
  z-index: 35;
  box-shadow: 0 1px #1a1a1a0a, 6px 8px #1a1a1a1f;
}

.v2-roomwin--floating .v2-roomwin__body {
  flex: 1;
  height: auto;
  min-height: 0;
}

.v2-roomwin--floating.v2-roomwin--minimized {
  height: auto !important;
}

.v2-roomwin__resize {
  position: absolute;
  cursor: nwse-resize;
  background: linear-gradient(135deg, transparent 0 50%, var(--ink-3) 50% 60%, transparent 60% 70%, var(--ink-3) 70% 80%, transparent 80% 100%);
  opacity: .5;
  transition: opacity var(--dur-fast) var(--ease-out);
  width: 16px;
  height: 16px;
  bottom: 0;
  right: 0;
}

.v2-roomwin__resize:hover {
  opacity: 1;
}

/* ui/src/v2/thread/MarkdownBody.css */
.v2-md {
  font: inherit;
  color: inherit;
}

.v2-md > :first-child {
  margin-top: 0;
}

.v2-md > :last-child {
  margin-bottom: 0;
}

.v2-md__p {
  font: inherit;
  margin: 0 0 .75em;
}

.v2-md__p:last-child {
  margin-bottom: 0;
}

.v2-md strong {
  color: var(--ink);
  font-weight: 600;
}

.v2-md em {
  font-style: italic;
}

.v2-md del {
  color: var(--ink-3);
}

.v2-md h1, .v2-md h2, .v2-md h3, .v2-md h4 {
  font-family: var(--font-display);
  font-weight: 500;
  line-height: var(--lh-tight);
  letter-spacing: -.01em;
  color: var(--ink);
  margin: 1em 0 .4em;
}

.v2-md h1 {
  font-size: 1.25em;
}

.v2-md h2 {
  font-size: 1.15em;
}

.v2-md h3 {
  font-size: 1.05em;
}

.v2-md h4 {
  text-transform: uppercase;
  letter-spacing: .08em;
  color: var(--ink-3);
  font-size: 1em;
}

.v2-md ul, .v2-md ol {
  margin: 0 0 .75em;
  padding-left: 1.25em;
}

.v2-md li {
  margin-bottom: .25em;
}

.v2-md li > p {
  margin: 0;
}

.v2-md blockquote {
  border-left: 2px solid var(--rule);
  color: var(--ink-2);
  margin: .5em 0 .75em;
  padding: .2em 0 .2em .9em;
  font-style: italic;
}

.v2-md hr {
  border: 0;
  border-top: var(--hair);
  margin: 1em 0;
}

.v2-md__link {
  color: var(--accent);
  text-decoration: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 2px;
}

.v2-md__link:hover {
  text-decoration-thickness: 2px;
}

.v2-md__code-inline {
  font-family: var(--font-mono);
  background: var(--paper-2);
  border: var(--hair-soft);
  border-radius: var(--r-1);
  white-space: break-spaces;
  padding: 1px 5px;
  font-size: .9em;
}

.v2-md pre {
  padding: var(--s-3) var(--s-4);
  background: var(--paper-2);
  border: var(--hair);
  border-radius: var(--r-2);
  overflow-x: auto;
  font-family: var(--font-mono);
  margin: .5em 0 .75em;
  font-size: .88em;
  line-height: 1.5;
}

.v2-md pre code, .v2-md__code-block {
  font-family: var(--font-mono);
  font-size: inherit;
  white-space: pre;
  background: none;
  border: 0;
  padding: 0;
}

.v2-md table {
  border-collapse: collapse;
  font-size: .95em;
  font-family: var(--font-sans);
  width: 100%;
  margin: .5em 0 .75em;
}

.v2-md th, .v2-md td {
  border: var(--hair-soft);
  text-align: left;
  padding: 4px 10px;
}

.v2-md th {
  background: var(--paper-2);
  font-weight: 600;
  font-family: var(--font-mono);
  letter-spacing: .06em;
  text-transform: uppercase;
  color: var(--ink-2);
  font-size: .9em;
}

.v2-md input[type="checkbox"] {
  margin-right: 6px;
  transform: translateY(1px);
}

/* ui/src/v2/thread/items.css */
.v2-item {
  display: flex;
  gap: var(--s-1);
  padding: var(--s-1) 0;
  position: relative;
  flex-direction: column;
}

.v2-item__meta {
  display: flex;
  align-items:  center;
  gap: var(--s-2);
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--ink-3);
  font-weight: 600;
  line-height: 1.2;
}

.v2-item__meta-dot {
  background: var(--accent);
  display: inline-block;
  border-radius: 2px;
  flex-shrink: 0;
  width: 4px;
  height: 4px;
}

.v2-item__who, .v2-item__who--jarvis {
  color: var(--ink-3);
}

.v2-item__tag {
  color: var(--ink-3);
  font-weight: 500;
}

.v2-item__time {
  color: var(--ink-3);
  letter-spacing: .06em;
  text-transform: none;
  font-weight: 400;
}

.v2-item__body {
  font-family: var(--font-display);
  color: var(--ink);
  font-size: 16px;
  line-height: 1.6;
}

.v2-item--user .v2-item__body {
  font-family: var(--font-display);
  color: var(--ink-2);
  font-style: italic;
}

.v2-item__mic {
  display: inline-flex;
  vertical-align: -1px;
  align-items:  center;
  gap: 4px;
  margin-right: 4px;
}

.v2-item--speech .v2-item__body {
  font-family: var(--font-display);
  color: var(--ink);
}

.v2-item__speaking-dot {
  display: inline-block;
  border-radius: var(--r-pill);
  background: var(--accent);
  vertical-align: 2px;
  animation: v2-speaking 1.2s ease-in-out infinite;
  width: 6px;
  height: 6px;
  margin-left: 6px;
}

@keyframes v2-speaking {
  0%, 100% {
    opacity: 1;
    transform: scale(1);
  }

  50% {
    opacity: .4;
    transform: scale(.75);
  }
}

@media (prefers-reduced-motion: reduce) {
  .v2-item__speaking-dot {
    animation: none;
    opacity: .7;
  }
}

.v2-item--thought {
  padding-left: var(--s-4);
  border-left: 2px dotted var(--rule);
  margin-left: 2px;
}

.v2-item--thought .v2-item__body {
  font-family: var(--font-display);
  color: var(--ink-3);
  font-style: italic;
  font-size: var(--text-sm);
  line-height: 1.5;
}

.v2-item--result {
  padding: var(--s-3) var(--s-4);
  background: var(--paper-2);
  border: var(--hair);
  border-radius: var(--r-2);
  gap: var(--s-2);
}

.v2-item--result .v2-item__body {
  font-family: var(--font-display);
  font-size: var(--text-md);
  line-height: var(--lh-body);
}

.v2-item__detail {
  font-size: var(--text-sm);
  color: var(--ink-2);
  line-height: var(--lh-body);
  margin-top: var(--s-1);
}

/* ui/src/v2/thread/Thread.css */
.v2-thread {
  position: relative;
  display: flex;
  flex-direction: column;
  height: 100%;
}

.v2-thread__scroll {
  overflow-y: auto;
  overflow-x: hidden;
  scroll-behavior: smooth;
  flex: 1;
}

.v2-thread__inner {
  padding: var(--s-8) var(--s-8) var(--s-12);
  display: flex;
  gap: var(--s-6);
  flex-direction: column;
  width: 100%;
  max-width: 720px;
  margin: 0 auto;
}

.v2-thread__item {
  scroll-margin-top: var(--s-8);
  scroll-margin-bottom: var(--s-8);
  border-radius: var(--r-2);
  transition: box-shadow var(--dur-med) var(--ease-out);
}

.v2-thread__item:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: -2px;
}

.v2-thread__item--flash {
  animation: v2-thread-flash 1.6s var(--ease-out);
}

@keyframes v2-thread-flash {
  0% {
    box-shadow: 0 0 0 0 color-mix(in srgb, var(--accent) 0%, transparent);
  }

  20% {
    box-shadow: 0 0 0 4px color-mix(in srgb, var(--accent) 35%, transparent);
  }

  100% {
    box-shadow: 0 0 0 0 color-mix(in srgb, var(--accent) 0%, transparent);
  }
}

@media (prefers-reduced-motion: reduce) {
  .v2-thread__item--flash {
    animation: none;
    box-shadow: 0 0 0 2px var(--accent);
  }
}

.v2-thread__empty {
  display: flex;
  gap: var(--s-5);
  padding: var(--s-10) 0;
  flex-direction: column;
}

.v2-thread__empty-eyebrow {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--ink-3);
}

.v2-thread__empty-title {
  font-family: var(--font-display);
  font-size: var(--text-2xl);
  letter-spacing: -.01em;
  max-width: 18ch;
  font-weight: 500;
}

.v2-thread__empty-title em {
  color: var(--accent);
  font-style: italic;
}

.v2-thread__empty-lede {
  font-size: var(--text-md);
  color: var(--ink-2);
  line-height: var(--lh-body);
  max-width: 54ch;
}

.v2-thread__jump {
  position: absolute;
  left: 50%;
  bottom: var(--s-5);
  display: inline-flex;
  align-items:  center;
  gap: var(--s-2);
  background: var(--ink);
  color: var(--paper);
  border-radius: var(--r-pill);
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  letter-spacing: .1em;
  text-transform: uppercase;
  cursor: pointer;
  animation: v2-jump-in var(--dur-med) var(--ease-out);
  border: 0;
  padding: 8px 14px 8px 10px;
  transform: translateX(-50%);
  box-shadow: 0 4px 12px #1a1a1a40;
}

.v2-thread__jump-dot {
  border-radius: var(--r-pill);
  background: var(--accent);
  width: 6px;
  height: 6px;
}

.v2-thread__jump:hover {
  background: #0f0f0f;
}

.v2-thread__jump:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 3px;
}

@keyframes v2-jump-in {
  from {
    opacity: 0;
    transform: translate(-50%, 8px);
  }

  to {
    opacity: 1;
    transform: translate(-50%);
  }
}

.v2-thread__dev {
  position: absolute;
  right: var(--s-5);
  top: var(--s-3);
  display: flex;
  gap: var(--s-2);
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: var(--ink-3);
}

.v2-thread__dev-btn {
  background: var(--paper);
  border: 1px solid var(--rule);
  border-radius: var(--r-1);
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--ink-2);
  cursor: pointer;
  transition: background var(--dur-fast) var(--ease-out);
  padding: 4px 10px;
}

.v2-thread__dev-btn:hover {
  background: var(--paper-3);
}

.v2-thread__dev-btn:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 2px;
}

@media (prefers-reduced-motion: reduce) {
  .v2-thread__scroll {
    scroll-behavior: auto;
  }

  .v2-thread__jump {
    animation: none;
  }
}

/* ui/src/v2/shell/MicOrb.css */
.v2-orb {
  position: relative;
  display: inline-flex;
  cursor: pointer;
  color: inherit;
  background: none;
  border: 0;
  justify-content: center;
  align-items:  center;
  padding: 0;
}

.v2-orb:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 6px;
  border-radius: var(--r-pill);
}

.v2-orb__svg {
  overflow: visible;
  display: block;
}

@keyframes v2-orb-breathe {
  0%, 100% {
    transform: scale(1);
    opacity: .35;
  }

  50% {
    transform: scale(1.08);
    opacity: .6;
  }
}

@keyframes v2-orb-breathe-fast {
  0%, 100% {
    transform: scale(1);
    opacity: .4;
  }

  50% {
    transform: scale(1.04);
    opacity: .7;
  }
}

@keyframes v2-orb-orbit {
  from {
    transform: rotate(0);
  }

  to {
    transform: rotate(360deg);
  }
}

@keyframes v2-orb-line {
  0%, 100% {
    opacity: .5;
  }

  50% {
    opacity: 1;
  }
}

@keyframes v2-orb-wave-a {
  0%, 100% {
    transform: scaleY(.35);
  }

  50% {
    transform: scaleY(1);
  }
}

@keyframes v2-orb-wave-b {
  0%, 100% {
    transform: scaleY(.55);
  }

  50% {
    transform: scaleY(.8);
  }
}

@keyframes v2-orb-wave-c {
  0%, 100% {
    transform: scaleY(.9);
  }

  50% {
    transform: scaleY(.45);
  }
}

@keyframes v2-orb-wave-d {
  0%, 100% {
    transform: scaleY(.6);
  }

  50% {
    transform: scaleY(.95);
  }
}

@keyframes v2-orb-wave-e {
  0%, 100% {
    transform: scaleY(.4);
  }

  50% {
    transform: scaleY(.7);
  }
}

@keyframes v2-orb-approve {
  0%, 100% {
    opacity: .6;
  }

  50% {
    opacity: 1;
  }
}

@media (prefers-reduced-motion: reduce) {
  .v2-orb [class*="v2-orb-anim"] {
    animation: none !important;
  }
}

/* ui/src/v2/voice/TranscriptBubble.css */
.v2-transcript {
  margin: var(--s-2) var(--s-4) 0;
  padding: var(--s-2) var(--s-3);
  background: var(--paper);
  border: var(--hair-soft);
  border-radius: var(--r-2);
  font-family: var(--font-display);
  font-style: italic;
  font-size: var(--text-sm);
  color: var(--ink);
  display: flex;
  align-items:  flex-start;
  gap: var(--s-1);
  animation: v2-transcript-in var(--dur-fast) var(--ease-out);
  overflow: hidden;
  max-height: 6em;
  line-height: 1.45;
}

.v2-transcript__quote {
  color: var(--accent);
  font-family: var(--font-display);
  font-style: normal;
  font-size: var(--text-md);
  flex-shrink: 0;
  line-height: 1;
}

.v2-transcript__text {
  flex: 1;
  min-width: 0;
}

@keyframes v2-transcript-in {
  from {
    opacity: 0;
    transform: translateY(-2px);
  }

  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@media (prefers-reduced-motion: reduce) {
  .v2-transcript {
    animation: none;
  }
}

/* ui/src/v2/voice/RailConfirmationStack.css */
.v2-rail-confirm {
  display: flex;
  gap: var(--s-2);
  padding: var(--s-3) var(--s-4);
  border-top: var(--hair-soft);
  border-bottom: var(--hair-soft);
  background: color-mix(in srgb, var(--accent) 4%, var(--paper));
  flex-direction: column;
}

.v2-rail-confirm__head {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: var(--s-2);
}

.v2-rail-confirm__label {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--accent);
}

.v2-rail-confirm__count {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: var(--ink-3);
}

.v2-rail-confirm__list {
  display: flex;
  gap: var(--s-2);
  flex-direction: column;
}

.v2-rail-confirm__card {
  background: var(--paper);
  border: 1px solid var(--rule);
  border-radius: var(--r-2);
  padding: var(--s-2) var(--s-3);
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.v2-rail-confirm__card[data-tone="accent"] {
  border-color: var(--accent);
  box-shadow: 0 0 0 1px color-mix(in srgb, var(--accent) 30%, transparent) inset;
}

.v2-rail-confirm__card[data-tone="warn"] {
  border-color: var(--warn);
}

.v2-rail-confirm__card-meta {
  display: flex;
  align-items:  center;
  gap: var(--s-2);
  font-family: var(--font-mono);
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--ink-3);
  font-size: 10px;
}

.v2-rail-confirm__card-kind {
  color: var(--ink-2);
}

.v2-rail-confirm__card-impact {
  font-family: var(--font-mono);
  border-radius: var(--r-pill);
  background: var(--paper-3);
  color: var(--ink-2);
  margin-left: auto;
  padding: 1px 6px;
  font-size: 10px;
}

.v2-rail-confirm__card-impact[data-impact="destructive"] {
  background: color-mix(in srgb, var(--accent) 14%, transparent);
  color: var(--accent);
}

.v2-rail-confirm__card-impact[data-impact="external"] {
  background: color-mix(in srgb, var(--warn) 14%, transparent);
  color: var(--warn);
}

.v2-rail-confirm__card-title {
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  color: var(--ink);
  display: -webkit-box;
  -webkit-line-clamp: 3;
  overflow: hidden;
  -webkit-box-orient: vertical;
  line-height: 1.3;
}

.v2-rail-confirm__card-sub {
  font-family: var(--font-mono);
  color: var(--ink-3);
  font-size: 10px;
}

.v2-rail-confirm__card-quote {
  font-family: var(--font-display);
  font-style: italic;
  font-size: var(--text-xs);
  color: var(--ink-2);
  display: -webkit-box;
  -webkit-line-clamp: 2;
  overflow: hidden;
  -webkit-box-orient: vertical;
  line-height: 1.35;
}

.v2-rail-confirm__card-error {
  font-family: var(--font-sans);
  color: var(--accent);
  font-size: 10px;
}

.v2-rail-confirm__card-actions {
  display: flex;
  gap: 6px;
  margin-top: 4px;
}

.v2-rail-confirm__btn {
  display: inline-flex;
  font-family: var(--font-sans);
  font-size: var(--text-xs);
  border-radius: var(--r-pill);
  cursor: pointer;
  border: 1px solid var(--rule);
  background: var(--paper-2);
  color: var(--ink-2);
  transition: background var(--dur-fast) var(--ease-out), color var(--dur-fast) var(--ease-out), border-color var(--dur-fast) var(--ease-out);
  flex: 1;
  justify-content: center;
  align-items:  center;
  gap: 4px;
  padding: 5px 8px;
}

.v2-rail-confirm__btn:hover {
  background: var(--paper-3);
  color: var(--ink);
}

.v2-rail-confirm__btn--approve {
  background: var(--accent);
  color: var(--accent-ink);
  border-color: var(--accent);
}

.v2-rail-confirm__btn--approve:hover {
  background: var(--accent);
  color: var(--accent-ink);
  filter: brightness(.92);
}

.v2-rail-confirm__btn:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 2px;
}

.v2-rail-confirm__btn:disabled {
  opacity: .5;
  cursor: default;
}

.v2-rail-confirm__voice-hint {
  font-family: var(--font-sans);
  color: var(--ink-3);
  text-align: center;
  margin-top: 2px;
  font-size: 10px;
}

.v2-rail-confirm__voice-hint em {
  color: var(--accent);
  font-style: italic;
}

/* ui/src/v2/voice/RailReplyPreview.css */
.v2-rail-reply {
  padding: var(--s-3) var(--s-4);
  border-top: var(--hair-soft);
  border-bottom: var(--hair-soft);
  background: var(--paper-2);
  display: flex;
  gap: var(--s-2);
  animation: v2-rail-reply-in var(--dur-med) var(--ease-out);
  flex-direction: column;
}

@keyframes v2-rail-reply-in {
  from {
    opacity: 0;
    transform: translateY(-2px);
  }

  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@media (prefers-reduced-motion: reduce) {
  .v2-rail-reply {
    animation: none;
  }
}

.v2-rail-reply__head {
  display: flex;
  justify-content: space-between;
  align-items:  center;
  gap: var(--s-2);
}

.v2-rail-reply__attrib {
  display: inline-flex;
  align-items:  center;
  gap: var(--s-2);
  font-family: var(--font-mono);
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--accent);
  font-size: 10px;
}

.v2-rail-reply__dot {
  border-radius: var(--r-pill);
  background: var(--accent);
  width: 6px;
  height: 6px;
}

.v2-rail-reply__streaming {
  color: var(--accent);
  animation: v2-rail-reply-pulse 1.4s ease-in-out infinite;
  font-size: 10px;
}

@keyframes v2-rail-reply-pulse {
  0%, 100% {
    opacity: .3;
  }

  50% {
    opacity: 1;
  }
}

@media (prefers-reduced-motion: reduce) {
  .v2-rail-reply__streaming {
    animation: none;
    opacity: .6;
  }
}

.v2-rail-reply__text {
  font-family: var(--font-display);
  font-size: var(--text-sm);
  color: var(--ink);
  display: -webkit-box;
  -webkit-line-clamp: 6;
  overflow: hidden;
  -webkit-box-orient: vertical;
  line-height: 1.45;
}

.v2-rail-reply__caret {
  display: inline-block;
  color: var(--accent);
  animation: v2-rail-reply-blink 1s step-end infinite;
  margin-left: 2px;
}

@keyframes v2-rail-reply-blink {
  0%, 50% {
    opacity: 1;
  }

  51%, 100% {
    opacity: 0;
  }
}

@media (prefers-reduced-motion: reduce) {
  .v2-rail-reply__caret {
    animation: none;
    opacity: .6;
  }
}

.v2-rail-reply__link {
  display: inline-flex;
  font-family: var(--font-sans);
  font-size: var(--text-xs);
  color: var(--ink-3);
  cursor: pointer;
  transition: color var(--dur-fast) var(--ease-out);
  background: none;
  border: 0;
  align-self:  flex-start;
  align-items:  center;
  gap: 4px;
  padding: 0;
}

.v2-rail-reply__link:hover {
  color: var(--ink);
}

.v2-rail-reply__link:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 2px;
  border-radius: var(--r-1);
}

/* ui/src/v2/shell/VoiceRail.css */
.v2-rail {
  display: flex;
  overflow: hidden;
  font-family: var(--font-sans);
  flex-direction: column;
  height: 100%;
}

.v2-rail__head {
  display: flex;
  padding: var(--s-5) var(--s-4) var(--s-4);
  border-bottom: var(--hair-soft);
  flex-direction: column;
  align-items:  center;
}

.v2-rail__label {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--ink-3);
  margin-bottom: var(--s-4);
  align-self:  flex-start;
  font-weight: 600;
}

.v2-rail__orb-wrap {
  margin-bottom: var(--s-3);
}

.v2-rail__ctrl-row {
  display: flex;
  gap: var(--s-2);
  margin-top: var(--s-2);
}

.v2-rail__ctrl {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--ink-3);
  background: var(--paper);
  border: 1px solid var(--rule);
  border-radius: var(--r-1);
  cursor: pointer;
  transition: background var(--dur-fast) var(--ease-out), color var(--dur-fast) var(--ease-out);
  padding: 4px 10px;
}

.v2-rail__ctrl:hover {
  background: var(--paper-3);
  color: var(--ink);
}

.v2-rail__ctrl:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 2px;
}

.v2-rail__ctrl[data-active="true"] {
  color: var(--accent);
  border-color: var(--accent);
  background: #c23a2a14;
}

.v2-rail__hint {
  padding: var(--s-3) var(--s-4);
  border-bottom: var(--hair-soft);
}

.v2-rail__hint-text {
  font-family: var(--font-display);
  font-size: var(--text-sm);
  color: var(--ink-2);
  font-style: italic;
  line-height: var(--lh-body);
}

.v2-rail__hint-meta {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--ink-3);
  margin-top: var(--s-2);
}

.v2-rail__awaiting {
  margin: var(--s-3) var(--s-4) 0;
  padding: var(--s-2) var(--s-3);
  border: 1px solid var(--warn);
  border-radius: var(--r-2);
  display: flex;
  align-items:  center;
  gap: var(--s-2);
  background: #8a6a1f14;
}

.v2-rail__awaiting-dot {
  border-radius: var(--r-pill);
  background: var(--warn);
  animation: v2-awaiting-pulse 1.4s ease-in-out infinite;
  flex-shrink: 0;
  width: 6px;
  height: 6px;
}

@keyframes v2-awaiting-pulse {
  0%, 100% {
    opacity: 1;
  }

  50% {
    opacity: .35;
  }
}

@media (prefers-reduced-motion: reduce) {
  .v2-rail__awaiting-dot {
    animation: none;
    opacity: 1;
  }
}

.v2-rail__awaiting-title {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--warn);
  font-weight: 600;
}

.v2-rail__awaiting-body {
  font-family: var(--font-display);
  font-size: var(--text-xs);
  color: var(--ink-2);
  font-style: italic;
}

.v2-rail__spacer {
  flex: 1;
  min-height: 0;
}

.v2-rail__sugs {
  padding: var(--s-3) var(--s-4) var(--s-3);
}

.v2-rail__sugs-label {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--ink-3);
  margin-bottom: var(--s-2);
  font-weight: 600;
}

.v2-rail__sugs-list {
  display: flex;
  gap: var(--s-2);
  flex-direction: column;
}

.v2-rail__sug {
  background: var(--paper);
  border: 1px solid var(--rule);
  border-radius: var(--r-1);
  font-family: var(--font-display);
  font-size: var(--text-sm);
  color: var(--ink-2);
  text-align: left;
  cursor: pointer;
  transition: background var(--dur-fast) var(--ease-out), color var(--dur-fast) var(--ease-out);
  padding: 6px 10px;
  font-style: italic;
}

.v2-rail__sug:hover {
  background: var(--paper-3);
  color: var(--ink);
}

.v2-rail__sug:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 2px;
}

.v2-rail__mic {
  padding: var(--s-3) var(--s-4);
  border-top: var(--hair-soft);
}

.v2-rail__mic-head {
  display: flex;
  align-items:  center;
  gap: var(--s-2);
  margin-bottom: 4px;
}

.v2-rail__mic-label {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--ink-3);
  flex: 1;
  font-weight: 600;
}

.v2-rail__mic-label[data-live="true"] {
  color: var(--accent);
}

.v2-rail__mic-vu {
  display: flex;
  align-items:  flex-end;
  gap: 2px;
  height: 6px;
}

.v2-rail__mic-vu-bar {
  background: var(--rule);
  opacity: .25;
  transition: opacity var(--dur-fast) var(--ease-out), height var(--dur-fast) var(--ease-out), background var(--dur-fast) var(--ease-out);
  flex: 1;
  height: 2px;
}

.v2-rail__mic-vu-bar[data-active="true"] {
  opacity: 1;
  background: var(--accent);
  height: 100%;
}

.v2-rail__mic-vu-bar[data-hot="true"] {
  background: var(--warn);
}

.v2-rail__mic-device {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: var(--ink-3);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  margin-top: 4px;
}

/* ui/src/v2/palette/CommandPalette.css */
.v2-palette__scrim {
  position: fixed;
  z-index: var(--z-palette);
  display: flex;
  backdrop-filter: blur(2px);
  background: #1a1a1a2e;
  justify-content: center;
  align-items:  flex-start;
  padding-top: 12vh;
  inset: 0;
}

.v2-palette__scrim-catcher {
  position: absolute;
  z-index: -1;
  cursor: default;
  background: none;
  border: 0;
  inset: 0;
}

.v2-palette {
  position: relative;
  background: var(--paper);
  border: 1.5px solid var(--rule);
  border-radius: var(--r-2);
  display: flex;
  overflow: hidden;
  flex-direction: column;
  width: min(640px, 92vw);
  max-height: 70vh;
  box-shadow: 6px 6px #1a1a1a1f;
}

.v2-palette__head {
  display: flex;
  align-items:  center;
  gap: var(--s-3);
  padding: var(--s-3) var(--s-4);
  border-bottom: var(--hair-soft);
  color: var(--ink-3);
}

.v2-palette__input {
  outline: none;
  font-family: var(--font-display);
  font-size: var(--text-md);
  color: var(--ink);
  background: none;
  border: 0;
  flex: 1;
  padding: 4px 0;
}

.v2-palette__input::placeholder {
  color: var(--ink-3);
  font-style: italic;
}

.v2-palette__list {
  overflow-y: auto;
  padding: var(--s-2) 0;
  flex: 1;
}

.v2-palette__empty {
  padding: var(--s-6) var(--s-5);
  font-family: var(--font-display);
  color: var(--ink-3);
  text-align: center;
  font-style: italic;
}

.v2-palette__group {
  padding: var(--s-2) 0;
}

.v2-palette__group + .v2-palette__group {
  border-top: var(--hair-soft);
}

.v2-palette__group-label {
  padding: var(--s-1) var(--s-5);
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--ink-3);
  font-weight: 600;
}

.v2-palette__group-rows {
  display: flex;
  flex-direction: column;
}

.v2-palette__row {
  display: grid;
  grid-template-columns: 28px 1fr auto auto;
  align-items:  center;
  gap: var(--s-3);
  cursor: pointer;
  background: none;
  border-left: 2px solid #0000;
  padding: 8px 18px;
}

.v2-palette__row--active {
  background: var(--paper-2);
  border-left-color: var(--accent);
}

.v2-palette__row-icon {
  background: var(--paper-2);
  border-radius: var(--r-1);
  display: flex;
  color: var(--ink);
  justify-content: center;
  align-items:  center;
  width: 28px;
  height: 28px;
}

.v2-palette__row--active .v2-palette__row-icon {
  background: var(--paper);
}

.v2-palette__row-body {
  min-width: 0;
}

.v2-palette__row-title {
  font-family: var(--font-display);
  font-size: var(--text-md);
  color: var(--ink);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.v2-palette__row-hint {
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  color: var(--ink-3);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.v2-palette__row-type {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--ink-3);
}

.v2-palette__row-enter {
  display: inline-flex;
  color: var(--ink-3);
  visibility: hidden;
  align-items:  center;
}

.v2-palette__row--active .v2-palette__row-enter {
  visibility: visible;
  color: var(--accent);
}

.v2-palette__foot {
  display: flex;
  align-items:  center;
  gap: var(--s-4);
  padding: var(--s-2) var(--s-4);
  border-top: var(--hair-soft);
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: var(--ink-3);
  background: var(--paper-2);
}

.v2-palette__hint {
  display: inline-flex;
  align-items:  center;
  gap: var(--s-1);
  letter-spacing: .06em;
}

.v2-palette__hint--right {
  margin-left: auto;
}

/* ui/src/v2/rooms/FloatingWindowsLayer.css */
.v2-floating-layer {
  position: fixed;
  top: 0;
  left: 0;
  right: var(--v2-rail-width);
  z-index: 30;
  pointer-events: none;
  bottom: 0;
}

.v2-floating-layer > .v2-roomwin {
  pointer-events: auto;
}

@media (max-width: 900px) {
  .v2-floating-layer {
    display: none;
  }
}

/* ui/src/v2/notifications/NotificationDrawer.css */
.v2-notif-drawer {
  position: absolute;
  background: var(--paper);
  border: 1px solid var(--rule);
  border-radius: var(--r-2);
  display: flex;
  z-index: 65;
  overflow: hidden;
  animation: v2-notif-drawer-in var(--dur-fast) var(--ease-out);
  flex-direction: column;
  width: 360px;
  max-height: min(70vh, 560px);
  top: calc(100% + 6px);
  right: 0;
  box-shadow: 0 12px 32px -16px #1a1a1a2e;
}

@keyframes v2-notif-drawer-in {
  from {
    opacity: 0;
    transform: translateY(-4px);
  }

  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@media (prefers-reduced-motion: reduce) {
  .v2-notif-drawer {
    animation: none;
  }
}

.v2-notif-drawer__head {
  display: flex;
  padding: var(--s-3) var(--s-4);
  border-bottom: var(--hair);
  background: var(--paper-2);
  justify-content: space-between;
  align-items:  center;
}

.v2-notif-drawer__title {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--ink-3);
}

.v2-notif-drawer__markall {
  display: inline-flex;
  align-items:  center;
  gap: var(--s-2);
  color: var(--ink-2);
  font-family: var(--font-sans);
  font-size: var(--text-xs);
  cursor: pointer;
  border-radius: var(--r-1);
  transition: background var(--dur-fast) var(--ease-out), color var(--dur-fast) var(--ease-out);
  background: none;
  border: 0;
  padding: 4px 8px;
}

.v2-notif-drawer__markall:hover:not(:disabled) {
  background: var(--paper-3);
  color: var(--ink);
}

.v2-notif-drawer__markall:disabled {
  opacity: .4;
  cursor: default;
}

.v2-notif-drawer__markall:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 2px;
}

.v2-notif-drawer__empty {
  display: flex;
  align-items:  center;
  gap: var(--s-2);
  padding: var(--s-8) var(--s-4);
  text-align: center;
  color: var(--ink-3);
  flex-direction: column;
}

.v2-notif-drawer__empty p {
  font-size: var(--text-sm);
  color: var(--ink-2);
  margin: 0;
}

.v2-notif-drawer__empty-hint {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  line-height: var(--lh-body);
  max-width: 220px;
  color: var(--ink-3) !important;
}

.v2-notif-drawer__list {
  list-style: none;
  overflow-y: auto;
  flex: 1;
  margin: 0;
  padding: 0;
}

.v2-notif-drawer__list li + li .v2-notif-drawer__row {
  border-top: var(--hair-soft);
}

.v2-notif-drawer__row {
  position: relative;
  display: grid;
  grid-template-columns: 28px 1fr 16px;
  gap: var(--s-3);
  padding: var(--s-3) var(--s-4);
  text-align: left;
  cursor: pointer;
  transition: background var(--dur-fast) var(--ease-out);
  background: none;
  border: 0;
  align-items:  flex-start;
  width: 100%;
}

.v2-notif-drawer__row:hover {
  background: var(--paper-2);
}

.v2-notif-drawer__row:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: -2px;
}

.v2-notif-drawer__row[data-unread="true"] {
  background: var(--paper-2);
}

.v2-notif-drawer__row[data-unread="true"]:hover {
  background: var(--paper-3);
}

.v2-notif-drawer__row-icon {
  display: inline-flex;
  border-radius: var(--r-pill);
  background: var(--paper-3);
  color: var(--ink-2);
  flex-shrink: 0;
  justify-content: center;
  align-items:  center;
  width: 28px;
  height: 28px;
}

.v2-notif-drawer__row[data-tone="accent"] .v2-notif-drawer__row-icon {
  background: color-mix(in srgb, var(--accent) 14%, transparent);
  color: var(--accent);
}

.v2-notif-drawer__row[data-tone="warn"] .v2-notif-drawer__row-icon {
  background: color-mix(in srgb, var(--warn) 14%, transparent);
  color: var(--warn);
}

.v2-notif-drawer__row[data-tone="ok"] .v2-notif-drawer__row-icon {
  background: color-mix(in srgb, var(--ok) 14%, transparent);
  color: var(--ok);
}

.v2-notif-drawer__row-body {
  display: flex;
  flex-direction: column;
  gap: 2px;
  min-width: 0;
}

.v2-notif-drawer__row-meta {
  display: flex;
  align-items:  center;
  gap: var(--s-2);
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: var(--ink-3);
  letter-spacing: .05em;
  text-transform: uppercase;
}

.v2-notif-drawer__row-kind {
  color: var(--ink-2);
}

.v2-notif-drawer__row-time {
  color: var(--ink-3);
  text-transform: none;
  letter-spacing: 0;
}

.v2-notif-drawer__row-title {
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  color: var(--ink);
  line-height: var(--lh-body);
  display: -webkit-box;
  -webkit-line-clamp: 2;
  overflow: hidden;
  -webkit-box-orient: vertical;
}

.v2-notif-drawer__row[data-unread="true"] .v2-notif-drawer__row-title {
  font-weight: 600;
}

.v2-notif-drawer__row-text {
  font-family: var(--font-sans);
  font-size: var(--text-xs);
  color: var(--ink-3);
  line-height: var(--lh-body);
  display: -webkit-box;
  -webkit-line-clamp: 2;
  overflow: hidden;
  -webkit-box-orient: vertical;
}

.v2-notif-drawer__row-cta {
  display: inline-flex;
  color: var(--ink-3);
  justify-content: center;
  align-items:  center;
  margin-top: 2px;
}

.v2-notif-drawer__row-dot {
  position: absolute;
  top: 12px;
  right: var(--s-2);
  border-radius: var(--r-pill);
  background: var(--accent);
  width: 6px;
  height: 6px;
}

@media (max-width: 540px) {
  .v2-notif-drawer {
    position: fixed;
    top: 56px;
    right: var(--s-2);
    left: var(--s-2);
    width: auto;
    max-height: 70vh;
  }
}

/* ui/src/v2/shell/AppShell.css */
.v2-shell {
  display: grid;
  grid-template-columns: 1fr var(--v2-rail-width);
  grid-template-rows: auto 1fr auto;
  grid-template-areas: "header   rail" "thread   rail" "composer rail";
  overflow: hidden;
  background: var(--paper);
  width: 100%;
  height: 100%;
}

.v2-shell__header {
  grid-area: header;
  border-bottom: var(--hair);
}

.v2-shell__thread {
  grid-area: thread;
  overflow-y: auto;
  overflow-x: hidden;
}

.v2-shell__composer {
  grid-area: composer;
  border-top: var(--hair);
}

.v2-shell__rail {
  grid-area: rail;
  border-left: var(--hair);
  background: var(--paper-2);
  overflow: hidden;
  display: flex;
  flex-direction: column;
}

/* ui/src/v2/pages/primitives.css */
.v2-primitives {
  display: grid;
  grid-template-rows: auto 1fr;
  overflow: hidden;
  height: 100%;
}

.v2-primitives__topbar {
  display: flex;
  justify-content: space-between;
  align-items:  center;
  gap: var(--s-6);
  padding: var(--s-5) var(--s-8);
  border-bottom: var(--hair);
  background: var(--paper);
}

.v2-primitives__brand {
  display: flex;
  align-items:  center;
  gap: var(--s-3);
}

.v2-primitives__brand-dot {
  border-radius: var(--r-pill);
  background: var(--accent);
  display: inline-block;
  width: 10px;
  height: 10px;
}

.v2-primitives__title {
  font-family: var(--font-display);
  font-size: var(--text-xl);
  letter-spacing: -.01em;
  font-weight: 500;
}

.v2-primitives__content {
  overflow-y: auto;
  padding: var(--s-10) var(--s-8);
}

.v2-primitives__grid {
  display: flex;
  gap: var(--s-12);
  flex-direction: column;
  max-width: 960px;
  margin: 0 auto;
}

.v2-section {
  display: flex;
  gap: var(--s-5);
  flex-direction: column;
}

.v2-section__head {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: var(--s-4);
}

.v2-section__title {
  font-family: var(--font-display);
  font-size: var(--text-lg);
  letter-spacing: -.01em;
  font-weight: 500;
}

.v2-section__note {
  font-size: var(--text-sm);
  color: var(--ink-2);
  line-height: var(--lh-body);
  max-width: 52ch;
}

.v2-demo {
  padding: var(--s-5) var(--s-6);
  background: var(--paper-2);
  border: var(--hair);
  border-radius: var(--r-2);
  display: flex;
  align-items:  center;
  gap: var(--s-4);
  flex-wrap: wrap;
}

.v2-demo--col {
  align-items:  flex-start;
  gap: var(--s-3);
  flex-direction: column;
}

.v2-demo__row {
  display: flex;
  align-items:  center;
  gap: var(--s-3);
  flex-wrap: wrap;
}

.v2-demo__label {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--ink-3);
  min-width: 60px;
}

/* ui/src/v2/rooms/RoomPlaceholder.css */
.v2-room-placeholder {
  display: flex;
  justify-content: center;
  align-items:  center;
  gap: var(--s-4);
  padding: var(--s-12);
  text-align: center;
  flex-direction: column;
  max-width: 540px;
  height: 100%;
  margin: 0 auto;
}

.v2-room-placeholder__icon {
  display: inline-flex;
  border-radius: var(--r-pill);
  background: var(--paper-2);
  border: var(--hair-soft);
  color: var(--ink-2);
  justify-content: center;
  align-items:  center;
  width: 56px;
  height: 56px;
}

.v2-room-placeholder__phase {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  letter-spacing: .16em;
  text-transform: uppercase;
  color: var(--ink-3);
}

.v2-room-placeholder__title {
  font-family: var(--font-display);
  font-size: var(--text-2xl);
  letter-spacing: -.01em;
  color: var(--ink);
  margin: 0;
  font-weight: 500;
  line-height: 1.2;
}

.v2-room-placeholder__title em {
  color: var(--accent);
  font-style: italic;
}

.v2-room-placeholder__body {
  font-family: var(--font-display);
  font-size: var(--text-md);
  color: var(--ink-2);
  max-width: 44ch;
  margin: 0;
  line-height: 1.5;
}

.v2-room-placeholder__meta {
  display: inline-flex;
  align-items:  center;
  gap: var(--s-2);
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  letter-spacing: .1em;
  color: var(--ink-3);
  background: var(--paper-2);
  border: var(--hair-soft);
  border-radius: var(--r-pill);
  padding: 4px 10px;
}

.v2-room-placeholder__meta-key {
  text-transform: uppercase;
}

.v2-room-placeholder__meta code {
  font-family: var(--font-mono);
  color: var(--ink);
}

/* ui/src/v2/onboarding/SetupRoom.css */
.v2-setup {
  position: fixed;
  background: var(--paper);
  color: var(--ink);
  font-family: var(--font-sans);
  z-index: 1000;
  overflow-y: auto;
  display: flex;
  justify-content: center;
  align-items:  flex-start;
  inset: 0;
}

.v2-setup__wrap {
  padding: var(--s-8) var(--s-6) var(--s-8);
  width: 100%;
  max-width: 640px;
}

@media (max-width: 720px) {
  .v2-setup__wrap {
    padding: var(--s-5) var(--s-4);
  }
}

@media (max-width: 600px) {
  .v2-setup__wrap {
    padding: var(--s-4) var(--s-3);
  }

  .v2-setup__head {
    gap: var(--s-2);
    margin-bottom: var(--s-5);
    flex-wrap: wrap;
  }

  .v2-setup__brand {
    font-size: var(--text-sm);
    letter-spacing: .1em;
  }

  .v2-setup__progress {
    font-size: 11px;
  }
}

.v2-setup__head {
  display: flex;
  margin-bottom: var(--s-7);
  justify-content: space-between;
  align-items:  center;
}

.v2-setup__brand {
  font-family: var(--font-display);
  font-size: var(--text-md);
  letter-spacing: .15em;
  color: var(--ink);
  font-weight: 600;
}

.v2-setup__progress {
  display: inline-flex;
  align-items:  center;
  gap: var(--s-2);
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--ink-3);
}

.v2-setup__progress-step[data-active="true"] {
  color: var(--ink);
}

.v2-setup__progress-step[data-done="true"] {
  color: var(--ok);
}

.v2-setup__progress-sep {
  opacity: .4;
}

.v2-setup__screen {
  display: flex;
  gap: var(--s-5);
  flex-direction: column;
}

.v2-setup__title {
  font-family: var(--font-display);
  font-size: var(--text-2xl);
  color: var(--ink);
  margin: 0;
  font-weight: 600;
  line-height: 1.2;
}

.v2-setup__sub {
  font-family: var(--font-display);
  font-size: var(--text-md);
  color: var(--ink-2);
  line-height: var(--lh-body);
  margin: 0;
}

.v2-setup__field {
  display: flex;
  gap: var(--s-2);
  flex-direction: column;
}

.v2-setup__label {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--ink-3);
}

.v2-setup__input, .v2-setup__select {
  background: var(--paper-2);
  border: 1px solid var(--rule);
  border-radius: var(--r-1);
  font-family: var(--font-sans);
  font-size: var(--text-md);
  color: var(--ink);
  outline: 0;
  box-sizing: border-box;
  width: 100%;
  padding: 10px 14px;
}

.v2-setup__select {
  cursor: pointer;
}

.v2-setup__input:focus, .v2-setup__select:focus {
  outline: 2px solid var(--accent);
  outline-offset: -2px;
}

.v2-setup__hint {
  font-family: var(--font-sans);
  font-size: var(--text-xs);
  color: var(--ink-3);
  margin: 0;
}

.v2-setup__provider-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
  gap: var(--s-2);
}

.v2-setup__provider-card {
  background: var(--paper-2);
  border: 1px solid var(--rule);
  border-radius: var(--r-2);
  padding: var(--s-3) var(--s-4);
  display: flex;
  cursor: pointer;
  text-align: left;
  transition: background var(--dur-fast) var(--ease-out), border-color var(--dur-fast) var(--ease-out);
  flex-direction: column;
  align-items:  flex-start;
  gap: 4px;
}

.v2-setup__provider-card:hover {
  background: var(--paper-3);
}

.v2-setup__provider-card[data-active="true"] {
  border-color: var(--ink);
  background: var(--paper);
}

.v2-setup__provider-card:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 2px;
}

.v2-setup__provider-name {
  font-family: var(--font-display);
  font-size: var(--text-md);
  color: var(--ink);
}

.v2-setup__provider-meta {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: var(--ink-3);
  letter-spacing: .05em;
  text-transform: uppercase;
}

.v2-setup__test-row {
  display: flex;
  align-items:  center;
  gap: var(--s-3);
  flex-wrap: wrap;
}

.v2-setup__test-ok {
  display: inline-flex;
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: var(--ok);
  align-items:  center;
  gap: 4px;
}

.v2-setup__test-err {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: var(--accent);
}

.v2-setup__cta-row {
  display: flex;
  justify-content: space-between;
  align-items:  center;
  gap: var(--s-3);
  margin-top: var(--s-4);
  padding-top: var(--s-4);
  border-top: var(--hair-soft);
}

.v2-setup__tts-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: var(--s-3);
}

.v2-setup__tts-card {
  background: var(--paper-2);
  border: 1px solid var(--rule);
  border-radius: var(--r-2);
  padding: var(--s-4);
  display: flex;
  align-items:  flex-start;
  gap: var(--s-2);
  cursor: pointer;
  text-align: left;
  transition: background var(--dur-fast) var(--ease-out), border-color var(--dur-fast) var(--ease-out);
  flex-direction: column;
}

.v2-setup__tts-card:hover {
  background: var(--paper-3);
}

.v2-setup__tts-card[data-active="true"] {
  border-color: var(--ink);
  background: var(--paper);
}

.v2-setup__tts-card:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 2px;
}

.v2-setup__tts-card > svg {
  color: var(--ink-2);
}

.v2-setup__tts-title {
  font-family: var(--font-display);
  font-size: var(--text-md);
  color: var(--ink);
}

.v2-setup__tts-body {
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  color: var(--ink-3);
  line-height: var(--lh-body);
}

.v2-setup__error {
  padding: var(--s-3) var(--s-4);
  background: color-mix(in srgb, var(--accent) 10%, transparent);
  border: 1px solid var(--accent);
  border-radius: var(--r-2);
  color: var(--accent);
  font-family: var(--font-sans);
  font-size: var(--text-sm);
}

.v2-setup__spin {
  animation: v2-setup-spin 1s linear infinite;
}

@keyframes v2-setup-spin {
  to {
    transform: rotate(360deg);
  }
}

@media (prefers-reduced-motion: reduce) {
  .v2-setup__spin {
    animation: none;
  }
}

/* ui/src/v2/onboarding/ProfileInterviewRoom.css */
.v2-interview {
  position: fixed;
  background: var(--paper);
  color: var(--ink);
  font-family: var(--font-sans);
  z-index: 1000;
  overflow: hidden;
  display: flex;
  justify-content: center;
  align-items: stretch;
  inset: 0;
}

.v2-interview__wrap {
  padding: var(--s-5) var(--s-6);
  display: flex;
  gap: var(--s-4);
  flex-direction: column;
  width: 100%;
  max-width: 760px;
  min-height: 0;
}

@media (max-width: 720px) {
  .v2-interview__wrap {
    padding: var(--s-4) var(--s-4);
  }
}

@media (max-width: 600px) {
  .v2-interview__wrap {
    padding: var(--s-3) var(--s-3);
    gap: var(--s-3);
  }

  .v2-interview__bubble {
    font-size: var(--text-sm);
    max-width: 92%;
  }

  .v2-interview__partial {
    font-size: var(--text-sm);
    max-width: 100%;
  }

  .v2-interview__head {
    gap: var(--s-2);
  }

  .v2-interview__brand {
    font-size: var(--text-sm);
    letter-spacing: .1em;
  }

  .v2-interview__skip {
    padding: 4px 8px;
  }
}

.v2-interview__head {
  display: flex;
  flex-shrink: 0;
  justify-content: space-between;
  align-items:  center;
}

.v2-interview__brand {
  font-family: var(--font-display);
  font-size: var(--text-md);
  letter-spacing: .15em;
  color: var(--ink);
  font-weight: 600;
}

.v2-interview__meta {
  display: inline-flex;
  align-items:  center;
  gap: var(--s-3);
}

.v2-interview__facts-count {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: var(--ink-3);
  letter-spacing: .05em;
}

.v2-interview__skip {
  display: inline-flex;
  border: 1px solid var(--rule);
  border-radius: var(--r-pill);
  color: var(--ink-2);
  font-family: var(--font-sans);
  font-size: var(--text-xs);
  cursor: pointer;
  transition: background var(--dur-fast) var(--ease-out), color var(--dur-fast) var(--ease-out);
  background: none;
  align-items:  center;
  gap: 4px;
  padding: 4px 12px;
}

.v2-interview__skip:hover {
  background: var(--paper-3);
  color: var(--ink);
}

.v2-interview__skip:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 2px;
}

.v2-interview__orb-wrap {
  display: flex;
  align-items:  center;
  gap: var(--s-2);
  padding: var(--s-3) 0;
  flex-direction: column;
  flex-shrink: 0;
}

.v2-interview__phase-label {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--ink-3);
  min-height: 1em;
}

.v2-interview__partial {
  font-family: var(--font-display);
  font-size: var(--text-md);
  color: var(--ink-2);
  text-align: center;
  padding: 0 var(--s-3);
  font-style: italic;
  line-height: var(--lh-body);
  max-width: 520px;
}

.v2-interview__messages {
  overflow-y: auto;
  display: flex;
  gap: var(--s-3);
  padding: var(--s-3) 0;
  flex-direction: column;
  flex: 1;
  min-height: 0;
}

.v2-interview__hint {
  text-align: center;
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  color: var(--ink-3);
  margin: var(--s-4) 0;
}

.v2-interview__bubble {
  padding: var(--s-3) var(--s-4);
  border-radius: var(--r-2);
  font-family: var(--font-display);
  font-size: var(--text-md);
  line-height: var(--lh-body);
  white-space: pre-wrap;
  word-break: break-word;
  max-width: 75%;
}

.v2-interview__bubble[data-role="assistant"] {
  background: var(--paper-2);
  border: 1px solid var(--rule-soft);
  color: var(--ink);
  align-self:  flex-start;
}

.v2-interview__bubble[data-role="user"] {
  background: var(--ink);
  color: var(--paper);
  border: 0;
  align-self:  flex-end;
}

.v2-interview__composer {
  display: flex;
  align-items:  center;
  gap: var(--s-2);
  padding: var(--s-2);
  background: var(--paper-2);
  border: 1px solid var(--rule);
  border-radius: var(--r-2);
  flex-shrink: 0;
}

.v2-interview__composer:focus-within {
  border-color: var(--ink-3);
}

.v2-interview__voice-pill {
  display: inline-flex;
  background: var(--paper);
  border: 1px solid var(--rule);
  border-radius: var(--r-pill);
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: var(--ink-3);
  white-space: nowrap;
  align-items:  center;
  gap: 4px;
  padding: 4px 10px;
}

.v2-interview__voice-pill[data-active="true"] {
  background: color-mix(in srgb, var(--accent) 10%, var(--paper));
  border-color: var(--accent);
  color: var(--accent);
}

.v2-interview__input {
  outline: 0;
  font-family: var(--font-sans);
  font-size: var(--text-md);
  color: var(--ink);
  background: none;
  border: 0;
  flex: 1;
  min-width: 0;
  padding: 8px 12px;
}

.v2-interview__input::placeholder {
  color: var(--ink-3);
}

.v2-interview__input:disabled {
  opacity: .5;
  cursor: not-allowed;
}

.v2-interview__toggle-text {
  font-family: var(--font-sans);
  font-size: var(--text-xs);
  color: var(--ink-3);
  cursor: pointer;
  text-decoration: underline dotted;
  background: none;
  border: 0;
  align-self:  center;
  margin-top: -4px;
}

.v2-interview__toggle-text:hover {
  color: var(--ink-2);
}

.v2-interview__error {
  padding: var(--s-3) var(--s-4);
  background: color-mix(in srgb, var(--accent) 10%, transparent);
  border: 1px solid var(--accent);
  border-radius: var(--r-2);
  color: var(--accent);
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  flex-shrink: 0;
}

.v2-interview__done {
  display: flex;
  align-items:  flex-start;
  gap: var(--s-3);
  padding: var(--s-6) 0;
  flex-direction: column;
  margin: auto 0;
}

.v2-interview__done-title {
  font-family: var(--font-display);
  font-size: var(--text-2xl);
  color: var(--ink);
  margin: 0;
}

.v2-interview__done-body {
  font-family: var(--font-display);
  font-size: var(--text-md);
  color: var(--ink-2);
  line-height: var(--lh-body);
  max-width: 560px;
  margin: 0;
}

.v2-interview__done-meta {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: var(--ink-3);
  letter-spacing: .05em;
  margin: 0;
}

/* ui/src/v2/onboarding/TutorialRoom.css */
.v2-tutorial-root {
  position: fixed;
  z-index: 1500;
  pointer-events: none;
  inset: 0;
}

.v2-spotlight, .v2-spotlight--full {
  position: fixed;
  pointer-events: none;
  inset: 0;
}

.v2-spotlight--full {
  background: #1a1a1a8c;
}

.v2-spotlight-bubble {
  pointer-events: auto;
  background: var(--paper-2);
  color: var(--ink);
  border: 1px solid var(--rule);
  border-radius: var(--r-2);
  padding: var(--s-4);
  display: flex;
  gap: var(--s-3);
  font-family: var(--font-sans);
  z-index: 1;
  animation: v2-spotlight-bubble-in var(--dur-med) var(--ease-out);
  flex-direction: column;
  box-shadow: 0 12px 32px -8px #1a1a1a59;
}

@media (prefers-reduced-motion: reduce) {
  .v2-spotlight-bubble {
    animation: none;
  }
}

@keyframes v2-spotlight-bubble-in {
  from {
    opacity: 0;
    transform: translateY(4px);
  }

  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.v2-spotlight-bubble__head {
  display: flex;
  align-items:  center;
  gap: var(--s-2);
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--ink-3);
}

.v2-spotlight-bubble__avatar {
  background: var(--accent);
  border-radius: 50%;
  flex-shrink: 0;
  width: 10px;
  height: 10px;
}

.v2-spotlight-bubble__avatar--speaking {
  animation: v2-spotlight-pulse 1.2s ease-in-out infinite;
}

@keyframes v2-spotlight-pulse {
  0%, 100% {
    opacity: 1;
    transform: scale(1);
  }

  50% {
    opacity: .45;
    transform: scale(.7);
  }
}

@media (prefers-reduced-motion: reduce) {
  .v2-spotlight-bubble__avatar--speaking {
    animation: none;
    opacity: .7;
  }
}

.v2-spotlight-bubble__brand {
  flex: 1;
}

.v2-spotlight-bubble__progress {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: var(--ink-3);
}

.v2-spotlight-bubble__narration {
  font-family: var(--font-display);
  font-size: var(--text-md);
  line-height: var(--lh-body);
  color: var(--ink);
  margin: 0;
}

.v2-spotlight-bubble__hint {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: var(--accent);
  letter-spacing: .02em;
  margin: 0;
}

.v2-spotlight-bubble__actions {
  display: flex;
  align-items:  center;
  gap: var(--s-2);
  margin-top: var(--s-2);
  padding-top: var(--s-3);
  border-top: var(--hair-soft);
}

.v2-spotlight-bubble__actions-spacer {
  flex: 1;
}

.v2-spotlight-bubble__btn {
  display: inline-flex;
  border-radius: var(--r-pill);
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  cursor: pointer;
  border: 1px solid var(--rule);
  color: var(--ink-2);
  transition: background var(--dur-fast) var(--ease-out), color var(--dur-fast) var(--ease-out), border-color var(--dur-fast) var(--ease-out);
  background: none;
  align-items:  center;
  gap: 4px;
  padding: 6px 12px;
}

.v2-spotlight-bubble__btn--ghost:hover {
  background: var(--paper-3);
  color: var(--ink);
}

.v2-spotlight-bubble__btn--primary {
  background: var(--ink);
  color: var(--paper);
  border-color: var(--ink);
}

.v2-spotlight-bubble__btn--primary:hover {
  background: var(--ink-2);
}

.v2-spotlight-bubble__btn:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 2px;
}

@media (max-width: 600px) {
  .v2-spotlight-bubble {
    padding: var(--s-3);
    gap: var(--s-2);
  }

  .v2-spotlight-bubble__narration {
    font-size: var(--text-sm);
  }

  .v2-spotlight-bubble__actions {
    flex-wrap: wrap;
    gap: 6px;
  }

  .v2-spotlight-bubble__btn {
    font-size: var(--text-xs);
    padding: 6px 10px;
  }
}

/* ui/src/v2/v2.css */
.jarvis-v2-root {
  background: var(--paper);
  color: var(--ink);
  font-family: var(--font-sans);
  font-size: var(--text-md);
  line-height: var(--lh-body);
  overflow: hidden;
  font-feature-settings: "ss01", "cv11";
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  width: 100vw;
  height: 100vh;
}

.jarvis-v2-root *, .jarvis-v2-root *:before, .jarvis-v2-root *:after {
  box-sizing: border-box;
}

.v2-shell-frame {
  display: grid;
  grid-template-rows: auto 1fr;
  overflow: hidden;
  height: 100%;
  min-height: 0;
}

.v2-sr-only {
  position: absolute;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
  width: 1px;
  height: 1px;
  margin: -1px;
  padding: 0;
}

.jarvis-v2-root h1, .jarvis-v2-root h2, .jarvis-v2-root h3 {
  font-family: var(--font-display);
  letter-spacing: -.01em;
  font-weight: 500;
  line-height: var(--lh-tight);
  color: var(--ink);
}

.jarvis-v2-root code, .jarvis-v2-root pre, .jarvis-v2-root kbd {
  font-family: var(--font-mono);
}

.jarvis-v2-root ::selection {
  background: var(--accent);
  color: var(--accent-ink);
}

.v2-placeholder {
  display: grid;
  grid-template-rows: auto 1fr auto;
  padding: var(--s-10) var(--s-12);
  height: 100%;
}

.v2-placeholder__brand {
  display: flex;
  align-items:  center;
  gap: var(--s-3);
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--ink-3);
}

.v2-placeholder__brand-dot {
  border-radius: var(--r-pill);
  background: var(--accent);
  display: inline-block;
  width: 10px;
  height: 10px;
}

.v2-placeholder__body {
  display: flex;
  justify-content: center;
  gap: var(--s-6);
  flex-direction: column;
  max-width: 720px;
}

.v2-placeholder__eyebrow {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--ink-2);
}

.v2-placeholder__title {
  font-size: var(--text-3xl);
  max-width: 18ch;
  font-weight: 500;
}

.v2-placeholder__title em {
  color: var(--accent);
  font-style: italic;
}

.v2-placeholder__lede {
  font-size: var(--text-lg);
  color: var(--ink-2);
  line-height: var(--lh-body);
  max-width: 52ch;
}

.v2-placeholder__actions {
  display: flex;
  align-items:  center;
  gap: var(--s-4);
  flex-wrap: wrap;
}

.v2-placeholder__hint {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--ink-3);
}

.v2-placeholder__meta {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: var(--s-6);
  padding-top: var(--s-6);
  border-top: var(--hair);
  max-width: 640px;
}

.v2-placeholder__meta-cell dt {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--ink-3);
  margin-bottom: var(--s-1);
}

.v2-placeholder__meta-cell dd {
  font-size: var(--text-md);
  color: var(--ink);
}

.v2-placeholder__footer {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: var(--s-6);
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--ink-3);
}

.v2-placeholder__back {
  border: var(--hair);
  padding: var(--s-2) var(--s-4);
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--ink);
  cursor: pointer;
  border-radius: var(--r-0);
  transition: background var(--dur-fast) var(--ease-out);
  background: none;
}

.v2-placeholder__back:hover {
  background: var(--paper-3);
}

.v2-placeholder__back:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 2px;
}

/* ui/src/v2/ui/primitives.css */
.v2-btn {
  display: inline-flex;
  justify-content: center;
  align-items:  center;
  gap: var(--s-2);
  font-family: var(--font-sans);
  cursor: pointer;
  border-radius: var(--r-2);
  transition: background var(--dur-fast) var(--ease-out), color var(--dur-fast) var(--ease-out), border-color var(--dur-fast) var(--ease-out);
  white-space: nowrap;
  user-select: none;
  font-weight: 500;
  line-height: 1;
}

.v2-btn:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 2px;
}

.v2-btn:disabled {
  opacity: .5;
  cursor: not-allowed;
}

.v2-chip:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 2px;
}

.v2-kbd:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 2px;
}

.v2-btn--sm {
  font-size: var(--text-xs);
  min-height: 26px;
  padding: 6px 10px;
}

.v2-btn--md {
  font-size: var(--text-sm);
  min-height: 32px;
  padding: 8px 14px;
}

.v2-btn--primary {
  background: var(--accent);
  color: var(--accent-ink);
  border: 1px solid var(--accent);
}

.v2-btn--primary:hover:not(:disabled) {
  background: #a62f22;
  border-color: #a62f22;
}

.v2-btn--ghost {
  color: var(--ink);
  border: 1px solid var(--rule);
  background: none;
}

.v2-btn--ghost:hover:not(:disabled) {
  background: var(--paper-3);
}

.v2-btn--danger {
  color: var(--warn);
  border: 1px solid var(--warn);
  background: none;
}

.v2-btn--danger:hover:not(:disabled) {
  background: #8a6a1f14;
}

.v2-chip {
  display: inline-flex;
  align-items:  center;
  gap: var(--s-2);
  font-family: var(--font-sans);
  font-size: var(--text-xs);
  border-radius: var(--r-pill);
  background: var(--paper-2);
  white-space: nowrap;
  border: 1px solid #0000;
  padding: 4px 10px;
  font-weight: 500;
  line-height: 1;
}

.v2-chip__dot {
  border-radius: var(--r-pill);
  flex-shrink: 0;
  width: 6px;
  height: 6px;
}

.v2-chip--neutral {
  color: var(--ink);
  border-color: var(--rule);
}

.v2-chip--neutral .v2-chip__dot {
  background: var(--ink-3);
}

.v2-chip--ok {
  color: var(--ok);
  border-color: var(--ok);
}

.v2-chip--ok .v2-chip__dot {
  background: var(--ok);
}

.v2-chip--warn {
  color: var(--warn);
  border-color: var(--warn);
}

.v2-chip--warn .v2-chip__dot {
  background: var(--warn);
}

.v2-chip--accent {
  color: var(--accent-ink);
  background: var(--accent);
  border-color: var(--accent);
}

.v2-chip--accent .v2-chip__dot {
  background: var(--accent-ink);
}

.v2-kbd {
  display: inline-flex;
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: var(--ink-2);
  background: var(--paper-2);
  border: 1px solid var(--rule);
  border-radius: var(--r-2);
  vertical-align: middle;
  justify-content: center;
  align-items:  center;
  min-width: 20px;
  padding: 2px 6px;
  line-height: 1.2;
}

.v2-rule {
  display: block;
  border: 0;
  border-top: var(--hair);
  width: 100%;
  height: 0;
  margin: 0;
}

.v2-rule--bold {
  border-top: var(--hair-2);
}

.v2-meta {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--ink-3);
  line-height: 1.4;
}

.v2-meta--inline {
  display: inline-flex;
  align-items:  center;
  gap: var(--s-2);
}

.v2-icon {
  display: inline-flex;
  color: currentColor;
  flex-shrink: 0;
  justify-content: center;
  align-items:  center;
}
