@import url('https://fonts.googleapis.com/css2?family=JetBrains+Mono:wght@500;600;700;800&family=Inter:wght@700;800;900&display=swap');

/* Google Fonts MUST be imported before Tailwind. `@import "tailwindcss"`
   expands inline into thousands of rules, so any @import that follows it
   ends up "after other rules" and gets rejected by the CSS parser. */
@layer theme, base, components, utilities;
@layer theme {
  @theme default {
    --font-sans:
      ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji",
      "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";
    --font-serif: ui-serif, Georgia, Cambria, "Times New Roman", Times, serif;
    --font-mono:
      ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono",
      "Courier New", monospace;

    --color-red-50: oklch(97.1% 0.013 17.38);
    --color-red-100: oklch(93.6% 0.032 17.717);
    --color-red-200: oklch(88.5% 0.062 18.334);
    --color-red-300: oklch(80.8% 0.114 19.571);
    --color-red-400: oklch(70.4% 0.191 22.216);
    --color-red-500: oklch(63.7% 0.237 25.331);
    --color-red-600: oklch(57.7% 0.245 27.325);
    --color-red-700: oklch(50.5% 0.213 27.518);
    --color-red-800: oklch(44.4% 0.177 26.899);
    --color-red-900: oklch(39.6% 0.141 25.723);
    --color-red-950: oklch(25.8% 0.092 26.042);

    --color-orange-50: oklch(98% 0.016 73.684);
    --color-orange-100: oklch(95.4% 0.038 75.164);
    --color-orange-200: oklch(90.1% 0.076 70.697);
    --color-orange-300: oklch(83.7% 0.128 66.29);
    --color-orange-400: oklch(75% 0.183 55.934);
    --color-orange-500: oklch(70.5% 0.213 47.604);
    --color-orange-600: oklch(64.6% 0.222 41.116);
    --color-orange-700: oklch(55.3% 0.195 38.402);
    --color-orange-800: oklch(47% 0.157 37.304);
    --color-orange-900: oklch(40.8% 0.123 38.172);
    --color-orange-950: oklch(26.6% 0.079 36.259);

    --color-amber-50: oklch(98.7% 0.022 95.277);
    --color-amber-100: oklch(96.2% 0.059 95.617);
    --color-amber-200: oklch(92.4% 0.12 95.746);
    --color-amber-300: oklch(87.9% 0.169 91.605);
    --color-amber-400: oklch(82.8% 0.189 84.429);
    --color-amber-500: oklch(76.9% 0.188 70.08);
    --color-amber-600: oklch(66.6% 0.179 58.318);
    --color-amber-700: oklch(55.5% 0.163 48.998);
    --color-amber-800: oklch(47.3% 0.137 46.201);
    --color-amber-900: oklch(41.4% 0.112 45.904);
    --color-amber-950: oklch(27.9% 0.077 45.635);

    --color-yellow-50: oklch(98.7% 0.026 102.212);
    --color-yellow-100: oklch(97.3% 0.071 103.193);
    --color-yellow-200: oklch(94.5% 0.129 101.54);
    --color-yellow-300: oklch(90.5% 0.182 98.111);
    --color-yellow-400: oklch(85.2% 0.199 91.936);
    --color-yellow-500: oklch(79.5% 0.184 86.047);
    --color-yellow-600: oklch(68.1% 0.162 75.834);
    --color-yellow-700: oklch(55.4% 0.135 66.442);
    --color-yellow-800: oklch(47.6% 0.114 61.907);
    --color-yellow-900: oklch(42.1% 0.095 57.708);
    --color-yellow-950: oklch(28.6% 0.066 53.813);

    --color-lime-50: oklch(98.6% 0.031 120.757);
    --color-lime-100: oklch(96.7% 0.067 122.328);
    --color-lime-200: oklch(93.8% 0.127 124.321);
    --color-lime-300: oklch(89.7% 0.196 126.665);
    --color-lime-400: oklch(84.1% 0.238 128.85);
    --color-lime-500: oklch(76.8% 0.233 130.85);
    --color-lime-600: oklch(64.8% 0.2 131.684);
    --color-lime-700: oklch(53.2% 0.157 131.589);
    --color-lime-800: oklch(45.3% 0.124 130.933);
    --color-lime-900: oklch(40.5% 0.101 131.063);
    --color-lime-950: oklch(27.4% 0.072 132.109);

    --color-green-50: oklch(98.2% 0.018 155.826);
    --color-green-100: oklch(96.2% 0.044 156.743);
    --color-green-200: oklch(92.5% 0.084 155.995);
    --color-green-300: oklch(87.1% 0.15 154.449);
    --color-green-400: oklch(79.2% 0.209 151.711);
    --color-green-500: oklch(72.3% 0.219 149.579);
    --color-green-600: oklch(62.7% 0.194 149.214);
    --color-green-700: oklch(52.7% 0.154 150.069);
    --color-green-800: oklch(44.8% 0.119 151.328);
    --color-green-900: oklch(39.3% 0.095 152.535);
    --color-green-950: oklch(26.6% 0.065 152.934);

    --color-emerald-50: oklch(97.9% 0.021 166.113);
    --color-emerald-100: oklch(95% 0.052 163.051);
    --color-emerald-200: oklch(90.5% 0.093 164.15);
    --color-emerald-300: oklch(84.5% 0.143 164.978);
    --color-emerald-400: oklch(76.5% 0.177 163.223);
    --color-emerald-500: oklch(69.6% 0.17 162.48);
    --color-emerald-600: oklch(59.6% 0.145 163.225);
    --color-emerald-700: oklch(50.8% 0.118 165.612);
    --color-emerald-800: oklch(43.2% 0.095 166.913);
    --color-emerald-900: oklch(37.8% 0.077 168.94);
    --color-emerald-950: oklch(26.2% 0.051 172.552);

    --color-teal-50: oklch(98.4% 0.014 180.72);
    --color-teal-100: oklch(95.3% 0.051 180.801);
    --color-teal-200: oklch(91% 0.096 180.426);
    --color-teal-300: oklch(85.5% 0.138 181.071);
    --color-teal-400: oklch(77.7% 0.152 181.912);
    --color-teal-500: oklch(70.4% 0.14 182.503);
    --color-teal-600: oklch(60% 0.118 184.704);
    --color-teal-700: oklch(51.1% 0.096 186.391);
    --color-teal-800: oklch(43.7% 0.078 188.216);
    --color-teal-900: oklch(38.6% 0.063 188.416);
    --color-teal-950: oklch(27.7% 0.046 192.524);

    --color-cyan-50: oklch(98.4% 0.019 200.873);
    --color-cyan-100: oklch(95.6% 0.045 203.388);
    --color-cyan-200: oklch(91.7% 0.08 205.041);
    --color-cyan-300: oklch(86.5% 0.127 207.078);
    --color-cyan-400: oklch(78.9% 0.154 211.53);
    --color-cyan-500: oklch(71.5% 0.143 215.221);
    --color-cyan-600: oklch(60.9% 0.126 221.723);
    --color-cyan-700: oklch(52% 0.105 223.128);
    --color-cyan-800: oklch(45% 0.085 224.283);
    --color-cyan-900: oklch(39.8% 0.07 227.392);
    --color-cyan-950: oklch(30.2% 0.056 229.695);

    --color-sky-50: oklch(97.7% 0.013 236.62);
    --color-sky-100: oklch(95.1% 0.026 236.824);
    --color-sky-200: oklch(90.1% 0.058 230.902);
    --color-sky-300: oklch(82.8% 0.111 230.318);
    --color-sky-400: oklch(74.6% 0.16 232.661);
    --color-sky-500: oklch(68.5% 0.169 237.323);
    --color-sky-600: oklch(58.8% 0.158 241.966);
    --color-sky-700: oklch(50% 0.134 242.749);
    --color-sky-800: oklch(44.3% 0.11 240.79);
    --color-sky-900: oklch(39.1% 0.09 240.876);
    --color-sky-950: oklch(29.3% 0.066 243.157);

    --color-blue-50: oklch(97% 0.014 254.604);
    --color-blue-100: oklch(93.2% 0.032 255.585);
    --color-blue-200: oklch(88.2% 0.059 254.128);
    --color-blue-300: oklch(80.9% 0.105 251.813);
    --color-blue-400: oklch(70.7% 0.165 254.624);
    --color-blue-500: oklch(62.3% 0.214 259.815);
    --color-blue-600: oklch(54.6% 0.245 262.881);
    --color-blue-700: oklch(48.8% 0.243 264.376);
    --color-blue-800: oklch(42.4% 0.199 265.638);
    --color-blue-900: oklch(37.9% 0.146 265.522);
    --color-blue-950: oklch(28.2% 0.091 267.935);

    --color-indigo-50: oklch(96.2% 0.018 272.314);
    --color-indigo-100: oklch(93% 0.034 272.788);
    --color-indigo-200: oklch(87% 0.065 274.039);
    --color-indigo-300: oklch(78.5% 0.115 274.713);
    --color-indigo-400: oklch(67.3% 0.182 276.935);
    --color-indigo-500: oklch(58.5% 0.233 277.117);
    --color-indigo-600: oklch(51.1% 0.262 276.966);
    --color-indigo-700: oklch(45.7% 0.24 277.023);
    --color-indigo-800: oklch(39.8% 0.195 277.366);
    --color-indigo-900: oklch(35.9% 0.144 278.697);
    --color-indigo-950: oklch(25.7% 0.09 281.288);

    --color-violet-50: oklch(96.9% 0.016 293.756);
    --color-violet-100: oklch(94.3% 0.029 294.588);
    --color-violet-200: oklch(89.4% 0.057 293.283);
    --color-violet-300: oklch(81.1% 0.111 293.571);
    --color-violet-400: oklch(70.2% 0.183 293.541);
    --color-violet-500: oklch(60.6% 0.25 292.717);
    --color-violet-600: oklch(54.1% 0.281 293.009);
    --color-violet-700: oklch(49.1% 0.27 292.581);
    --color-violet-800: oklch(43.2% 0.232 292.759);
    --color-violet-900: oklch(38% 0.189 293.745);
    --color-violet-950: oklch(28.3% 0.141 291.089);

    --color-purple-50: oklch(97.7% 0.014 308.299);
    --color-purple-100: oklch(94.6% 0.033 307.174);
    --color-purple-200: oklch(90.2% 0.063 306.703);
    --color-purple-300: oklch(82.7% 0.119 306.383);
    --color-purple-400: oklch(71.4% 0.203 305.504);
    --color-purple-500: oklch(62.7% 0.265 303.9);
    --color-purple-600: oklch(55.8% 0.288 302.321);
    --color-purple-700: oklch(49.6% 0.265 301.924);
    --color-purple-800: oklch(43.8% 0.218 303.724);
    --color-purple-900: oklch(38.1% 0.176 304.987);
    --color-purple-950: oklch(29.1% 0.149 302.717);

    --color-fuchsia-50: oklch(97.7% 0.017 320.058);
    --color-fuchsia-100: oklch(95.2% 0.037 318.852);
    --color-fuchsia-200: oklch(90.3% 0.076 319.62);
    --color-fuchsia-300: oklch(83.3% 0.145 321.434);
    --color-fuchsia-400: oklch(74% 0.238 322.16);
    --color-fuchsia-500: oklch(66.7% 0.295 322.15);
    --color-fuchsia-600: oklch(59.1% 0.293 322.896);
    --color-fuchsia-700: oklch(51.8% 0.253 323.949);
    --color-fuchsia-800: oklch(45.2% 0.211 324.591);
    --color-fuchsia-900: oklch(40.1% 0.17 325.612);
    --color-fuchsia-950: oklch(29.3% 0.136 325.661);

    --color-pink-50: oklch(97.1% 0.014 343.198);
    --color-pink-100: oklch(94.8% 0.028 342.258);
    --color-pink-200: oklch(89.9% 0.061 343.231);
    --color-pink-300: oklch(82.3% 0.12 346.018);
    --color-pink-400: oklch(71.8% 0.202 349.761);
    --color-pink-500: oklch(65.6% 0.241 354.308);
    --color-pink-600: oklch(59.2% 0.249 0.584);
    --color-pink-700: oklch(52.5% 0.223 3.958);
    --color-pink-800: oklch(45.9% 0.187 3.815);
    --color-pink-900: oklch(40.8% 0.153 2.432);
    --color-pink-950: oklch(28.4% 0.109 3.907);

    --color-rose-50: oklch(96.9% 0.015 12.422);
    --color-rose-100: oklch(94.1% 0.03 12.58);
    --color-rose-200: oklch(89.2% 0.058 10.001);
    --color-rose-300: oklch(81% 0.117 11.638);
    --color-rose-400: oklch(71.2% 0.194 13.428);
    --color-rose-500: oklch(64.5% 0.246 16.439);
    --color-rose-600: oklch(58.6% 0.253 17.585);
    --color-rose-700: oklch(51.4% 0.222 16.935);
    --color-rose-800: oklch(45.5% 0.188 13.697);
    --color-rose-900: oklch(41% 0.159 10.272);
    --color-rose-950: oklch(27.1% 0.105 12.094);

    --color-slate-50: oklch(98.4% 0.003 247.858);
    --color-slate-100: oklch(96.8% 0.007 247.896);
    --color-slate-200: oklch(92.9% 0.013 255.508);
    --color-slate-300: oklch(86.9% 0.022 252.894);
    --color-slate-400: oklch(70.4% 0.04 256.788);
    --color-slate-500: oklch(55.4% 0.046 257.417);
    --color-slate-600: oklch(44.6% 0.043 257.281);
    --color-slate-700: oklch(37.2% 0.044 257.287);
    --color-slate-800: oklch(27.9% 0.041 260.031);
    --color-slate-900: oklch(20.8% 0.042 265.755);
    --color-slate-950: oklch(12.9% 0.042 264.695);

    --color-gray-50: oklch(98.5% 0.002 247.839);
    --color-gray-100: oklch(96.7% 0.003 264.542);
    --color-gray-200: oklch(92.8% 0.006 264.531);
    --color-gray-300: oklch(87.2% 0.01 258.338);
    --color-gray-400: oklch(70.7% 0.022 261.325);
    --color-gray-500: oklch(55.1% 0.027 264.364);
    --color-gray-600: oklch(44.6% 0.03 256.802);
    --color-gray-700: oklch(37.3% 0.034 259.733);
    --color-gray-800: oklch(27.8% 0.033 256.848);
    --color-gray-900: oklch(21% 0.034 264.665);
    --color-gray-950: oklch(13% 0.028 261.692);

    --color-zinc-50: oklch(98.5% 0 0);
    --color-zinc-100: oklch(96.7% 0.001 286.375);
    --color-zinc-200: oklch(92% 0.004 286.32);
    --color-zinc-300: oklch(87.1% 0.006 286.286);
    --color-zinc-400: oklch(70.5% 0.015 286.067);
    --color-zinc-500: oklch(55.2% 0.016 285.938);
    --color-zinc-600: oklch(44.2% 0.017 285.786);
    --color-zinc-700: oklch(37% 0.013 285.805);
    --color-zinc-800: oklch(27.4% 0.006 286.033);
    --color-zinc-900: oklch(21% 0.006 285.885);
    --color-zinc-950: oklch(14.1% 0.005 285.823);

    --color-neutral-50: oklch(98.5% 0 0);
    --color-neutral-100: oklch(97% 0 0);
    --color-neutral-200: oklch(92.2% 0 0);
    --color-neutral-300: oklch(87% 0 0);
    --color-neutral-400: oklch(70.8% 0 0);
    --color-neutral-500: oklch(55.6% 0 0);
    --color-neutral-600: oklch(43.9% 0 0);
    --color-neutral-700: oklch(37.1% 0 0);
    --color-neutral-800: oklch(26.9% 0 0);
    --color-neutral-900: oklch(20.5% 0 0);
    --color-neutral-950: oklch(14.5% 0 0);

    --color-stone-50: oklch(98.5% 0.001 106.423);
    --color-stone-100: oklch(97% 0.001 106.424);
    --color-stone-200: oklch(92.3% 0.003 48.717);
    --color-stone-300: oklch(86.9% 0.005 56.366);
    --color-stone-400: oklch(70.9% 0.01 56.259);
    --color-stone-500: oklch(55.3% 0.013 58.071);
    --color-stone-600: oklch(44.4% 0.011 73.639);
    --color-stone-700: oklch(37.4% 0.01 67.558);
    --color-stone-800: oklch(26.8% 0.007 34.298);
    --color-stone-900: oklch(21.6% 0.006 56.043);
    --color-stone-950: oklch(14.7% 0.004 49.25);

    --color-mauve-50: oklch(98.5% 0 0);
    --color-mauve-100: oklch(96% 0.003 325.6);
    --color-mauve-200: oklch(92.2% 0.005 325.62);
    --color-mauve-300: oklch(86.5% 0.012 325.68);
    --color-mauve-400: oklch(71.1% 0.019 323.02);
    --color-mauve-500: oklch(54.2% 0.034 322.5);
    --color-mauve-600: oklch(43.5% 0.029 321.78);
    --color-mauve-700: oklch(36.4% 0.029 323.89);
    --color-mauve-800: oklch(26.3% 0.024 320.12);
    --color-mauve-900: oklch(21.2% 0.019 322.12);
    --color-mauve-950: oklch(14.5% 0.008 326);

    --color-olive-50: oklch(98.8% 0.003 106.5);
    --color-olive-100: oklch(96.6% 0.005 106.5);
    --color-olive-200: oklch(93% 0.007 106.5);
    --color-olive-300: oklch(88% 0.011 106.6);
    --color-olive-400: oklch(73.7% 0.021 106.9);
    --color-olive-500: oklch(58% 0.031 107.3);
    --color-olive-600: oklch(46.6% 0.025 107.3);
    --color-olive-700: oklch(39.4% 0.023 107.4);
    --color-olive-800: oklch(28.6% 0.016 107.4);
    --color-olive-900: oklch(22.8% 0.013 107.4);
    --color-olive-950: oklch(15.3% 0.006 107.1);

    --color-mist-50: oklch(98.7% 0.002 197.1);
    --color-mist-100: oklch(96.3% 0.002 197.1);
    --color-mist-200: oklch(92.5% 0.005 214.3);
    --color-mist-300: oklch(87.2% 0.007 219.6);
    --color-mist-400: oklch(72.3% 0.014 214.4);
    --color-mist-500: oklch(56% 0.021 213.5);
    --color-mist-600: oklch(45% 0.017 213.2);
    --color-mist-700: oklch(37.8% 0.015 216);
    --color-mist-800: oklch(27.5% 0.011 216.9);
    --color-mist-900: oklch(21.8% 0.008 223.9);
    --color-mist-950: oklch(14.8% 0.004 228.8);

    --color-taupe-50: oklch(98.6% 0.002 67.8);
    --color-taupe-100: oklch(96% 0.002 17.2);
    --color-taupe-200: oklch(92.2% 0.005 34.3);
    --color-taupe-300: oklch(86.8% 0.007 39.5);
    --color-taupe-400: oklch(71.4% 0.014 41.2);
    --color-taupe-500: oklch(54.7% 0.021 43.1);
    --color-taupe-600: oklch(43.8% 0.017 39.3);
    --color-taupe-700: oklch(36.7% 0.016 35.7);
    --color-taupe-800: oklch(26.8% 0.011 36.5);
    --color-taupe-900: oklch(21.4% 0.009 43.1);
    --color-taupe-950: oklch(14.7% 0.004 49.3);

    --color-black: #000;
    --color-white: #fff;

    --spacing: 0.25rem;

    --breakpoint-sm: 40rem;
    --breakpoint-md: 48rem;
    --breakpoint-lg: 64rem;
    --breakpoint-xl: 80rem;
    --breakpoint-2xl: 96rem;

    --container-3xs: 16rem;
    --container-2xs: 18rem;
    --container-xs: 20rem;
    --container-sm: 24rem;
    --container-md: 28rem;
    --container-lg: 32rem;
    --container-xl: 36rem;
    --container-2xl: 42rem;
    --container-3xl: 48rem;
    --container-4xl: 56rem;
    --container-5xl: 64rem;
    --container-6xl: 72rem;
    --container-7xl: 80rem;

    --text-xs: 0.75rem;
    --text-xs--line-height: calc(1 / 0.75);
    --text-sm: 0.875rem;
    --text-sm--line-height: calc(1.25 / 0.875);
    --text-base: 1rem;
    --text-base--line-height: calc(1.5 / 1);
    --text-lg: 1.125rem;
    --text-lg--line-height: calc(1.75 / 1.125);
    --text-xl: 1.25rem;
    --text-xl--line-height: calc(1.75 / 1.25);
    --text-2xl: 1.5rem;
    --text-2xl--line-height: calc(2 / 1.5);
    --text-3xl: 1.875rem;
    --text-3xl--line-height: calc(2.25 / 1.875);
    --text-4xl: 2.25rem;
    --text-4xl--line-height: calc(2.5 / 2.25);
    --text-5xl: 3rem;
    --text-5xl--line-height: 1;
    --text-6xl: 3.75rem;
    --text-6xl--line-height: 1;
    --text-7xl: 4.5rem;
    --text-7xl--line-height: 1;
    --text-8xl: 6rem;
    --text-8xl--line-height: 1;
    --text-9xl: 8rem;
    --text-9xl--line-height: 1;

    --font-weight-thin: 100;
    --font-weight-extralight: 200;
    --font-weight-light: 300;
    --font-weight-normal: 400;
    --font-weight-medium: 500;
    --font-weight-semibold: 600;
    --font-weight-bold: 700;
    --font-weight-extrabold: 800;
    --font-weight-black: 900;

    --tracking-tighter: -0.05em;
    --tracking-tight: -0.025em;
    --tracking-normal: 0em;
    --tracking-wide: 0.025em;
    --tracking-wider: 0.05em;
    --tracking-widest: 0.1em;

    --leading-tight: 1.25;
    --leading-snug: 1.375;
    --leading-normal: 1.5;
    --leading-relaxed: 1.625;
    --leading-loose: 2;

    --radius-xs: 0.125rem;
    --radius-sm: 0.25rem;
    --radius-md: 0.375rem;
    --radius-lg: 0.5rem;
    --radius-xl: 0.75rem;
    --radius-2xl: 1rem;
    --radius-3xl: 1.5rem;
    --radius-4xl: 2rem;

    --shadow-2xs: 0 1px rgb(0 0 0 / 0.05);
    --shadow-xs: 0 1px 2px 0 rgb(0 0 0 / 0.05);
    --shadow-sm: 0 1px 3px 0 rgb(0 0 0 / 0.1), 0 1px 2px -1px rgb(0 0 0 / 0.1);
    --shadow-md:
      0 4px 6px -1px rgb(0 0 0 / 0.1), 0 2px 4px -2px rgb(0 0 0 / 0.1);
    --shadow-lg:
      0 10px 15px -3px rgb(0 0 0 / 0.1), 0 4px 6px -4px rgb(0 0 0 / 0.1);
    --shadow-xl:
      0 20px 25px -5px rgb(0 0 0 / 0.1), 0 8px 10px -6px rgb(0 0 0 / 0.1);
    --shadow-2xl: 0 25px 50px -12px rgb(0 0 0 / 0.25);

    --inset-shadow-2xs: inset 0 1px rgb(0 0 0 / 0.05);
    --inset-shadow-xs: inset 0 1px 1px rgb(0 0 0 / 0.05);
    --inset-shadow-sm: inset 0 2px 4px rgb(0 0 0 / 0.05);

    --drop-shadow-xs: 0 1px 1px rgb(0 0 0 / 0.05);
    --drop-shadow-sm: 0 1px 2px rgb(0 0 0 / 0.15);
    --drop-shadow-md: 0 3px 3px rgb(0 0 0 / 0.12);
    --drop-shadow-lg: 0 4px 4px rgb(0 0 0 / 0.15);
    --drop-shadow-xl: 0 9px 7px rgb(0 0 0 / 0.1);
    --drop-shadow-2xl: 0 25px 25px rgb(0 0 0 / 0.15);

    --text-shadow-2xs: 0px 1px 0px rgb(0 0 0 / 0.15);
    --text-shadow-xs: 0px 1px 1px rgb(0 0 0 / 0.2);
    --text-shadow-sm:
      0px 1px 0px rgb(0 0 0 / 0.075), 0px 1px 1px rgb(0 0 0 / 0.075),
      0px 2px 2px rgb(0 0 0 / 0.075);
    --text-shadow-md:
      0px 1px 1px rgb(0 0 0 / 0.1), 0px 1px 2px rgb(0 0 0 / 0.1),
      0px 2px 4px rgb(0 0 0 / 0.1);
    --text-shadow-lg:
      0px 1px 2px rgb(0 0 0 / 0.1), 0px 3px 2px rgb(0 0 0 / 0.1),
      0px 4px 8px rgb(0 0 0 / 0.1);

    --ease-in: cubic-bezier(0.4, 0, 1, 1);
    --ease-out: cubic-bezier(0, 0, 0.2, 1);
    --ease-in-out: cubic-bezier(0.4, 0, 0.2, 1);

    --animate-spin: spin 1s linear infinite;
    --animate-ping: ping 1s cubic-bezier(0, 0, 0.2, 1) infinite;
    --animate-pulse: pulse 2s cubic-bezier(0.4, 0, 0.6, 1) infinite;
    --animate-bounce: bounce 1s infinite;

    @keyframes spin {
      to {
        transform: rotate(360deg);
      }
    }

    @keyframes ping {
      75%,
      100% {
        transform: scale(2);
        opacity: 0;
      }
    }

    @keyframes pulse {
      50% {
        opacity: 0.5;
      }
    }

    @keyframes bounce {
      0%,
      100% {
        transform: translateY(-25%);
        animation-timing-function: cubic-bezier(0.8, 0, 1, 1);
      }

      50% {
        transform: none;
        animation-timing-function: cubic-bezier(0, 0, 0.2, 1);
      }
    }

    --blur-xs: 4px;
    --blur-sm: 8px;
    --blur-md: 12px;
    --blur-lg: 16px;
    --blur-xl: 24px;
    --blur-2xl: 40px;
    --blur-3xl: 64px;

    --perspective-dramatic: 100px;
    --perspective-near: 300px;
    --perspective-normal: 500px;
    --perspective-midrange: 800px;
    --perspective-distant: 1200px;

    --aspect-video: 16 / 9;

    --default-transition-duration: 150ms;
    --default-transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
    --default-font-family: --theme(--font-sans, initial);
    --default-font-feature-settings: --theme(
      --font-sans--font-feature-settings,
      initial
    );
    --default-font-variation-settings: --theme(
      --font-sans--font-variation-settings,
      initial
    );
    --default-mono-font-family: --theme(--font-mono, initial);
    --default-mono-font-feature-settings: --theme(
      --font-mono--font-feature-settings,
      initial
    );
    --default-mono-font-variation-settings: --theme(
      --font-mono--font-variation-settings,
      initial
    );
  }

  /* Deprecated */
  @theme default inline reference {
    --blur: 8px;
    --shadow: 0 1px 3px 0 rgb(0 0 0 / 0.1), 0 1px 2px -1px rgb(0 0 0 / 0.1);
    --shadow-inner: inset 0 2px 4px 0 rgb(0 0 0 / 0.05);
    --drop-shadow: 0 1px 2px rgb(0 0 0 / 0.1), 0 1px 1px rgb(0 0 0 / 0.06);
    --radius: 0.25rem;
    --max-width-prose: 65ch;
  }
}
@layer base {
  /*
  1. Prevent padding and border from affecting element width. (https://github.com/mozdevs/cssremedy/issues/4)
  2. Remove default margins and padding
  3. Reset all borders.
*/

  *,
  ::after,
  ::before,
  ::backdrop,
  ::file-selector-button {
    box-sizing: border-box; /* 1 */
    margin: 0; /* 2 */
    padding: 0; /* 2 */
    border: 0 solid; /* 3 */
  }

  /*
  1. Use a consistent sensible line-height in all browsers.
  2. Prevent adjustments of font size after orientation changes in iOS.
  3. Use a more readable tab size.
  4. Use the user's configured `sans` font-family by default.
  5. Use the user's configured `sans` font-feature-settings by default.
  6. Use the user's configured `sans` font-variation-settings by default.
  7. Disable tap highlights on iOS.
*/

  html,
  :host {
    line-height: 1.5; /* 1 */
    -webkit-text-size-adjust: 100%; /* 2 */
    tab-size: 4; /* 3 */
    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"
    ); /* 4 */
    font-feature-settings: --theme(
      --default-font-feature-settings,
      normal
    ); /* 5 */
    font-variation-settings: --theme(
      --default-font-variation-settings,
      normal
    ); /* 6 */
    -webkit-tap-highlight-color: transparent; /* 7 */
  }

  /*
  1. Add the correct height in Firefox.
  2. Correct the inheritance of border color in Firefox. (https://bugzilla.mozilla.org/show_bug.cgi?id=190655)
  3. Reset the default border style to a 1px solid border.
*/

  hr {
    height: 0; /* 1 */
    color: inherit; /* 2 */
    border-top-width: 1px; /* 3 */
  }

  /*
  Add the correct text decoration in Chrome, Edge, and Safari.
*/

  abbr:where([title]) {
    -webkit-text-decoration: underline dotted;
    text-decoration: underline dotted;
  }

  /*
  Remove the default font size and weight for headings.
*/

  h1,
  h2,
  h3,
  h4,
  h5,
  h6 {
    font-size: inherit;
    font-weight: inherit;
  }

  /*
  Reset links to optimize for opt-in styling instead of opt-out.
*/

  a {
    color: inherit;
    -webkit-text-decoration: inherit;
    text-decoration: inherit;
  }

  /*
  Add the correct font weight in Edge and Safari.
*/

  b,
  strong {
    font-weight: bolder;
  }

  /*
  1. Use the user's configured `mono` font-family by default.
  2. Use the user's configured `mono` font-feature-settings by default.
  3. Use the user's configured `mono` font-variation-settings by default.
  4. Correct the odd `em` font sizing in all browsers.
*/

  code,
  kbd,
  samp,
  pre {
    font-family: --theme(
      --default-mono-font-family,
      ui-monospace,
      SFMono-Regular,
      Menlo,
      Monaco,
      Consolas,
      "Liberation Mono",
      "Courier New",
      monospace
    ); /* 1 */
    font-feature-settings: --theme(
      --default-mono-font-feature-settings,
      normal
    ); /* 2 */
    font-variation-settings: --theme(
      --default-mono-font-variation-settings,
      normal
    ); /* 3 */
    font-size: 1em; /* 4 */
  }

  /*
  Add the correct font size in all browsers.
*/

  small {
    font-size: 80%;
  }

  /*
  Prevent `sub` and `sup` elements from affecting the line height in all browsers.
*/

  sub,
  sup {
    font-size: 75%;
    line-height: 0;
    position: relative;
    vertical-align: baseline;
  }

  sub {
    bottom: -0.25em;
  }

  sup {
    top: -0.5em;
  }

  /*
  1. Remove text indentation from table contents in Chrome and Safari. (https://bugs.chromium.org/p/chromium/issues/detail?id=999088, https://bugs.webkit.org/show_bug.cgi?id=201297)
  2. Correct table border color inheritance in all Chrome and Safari. (https://bugs.chromium.org/p/chromium/issues/detail?id=935729, https://bugs.webkit.org/show_bug.cgi?id=195016)
  3. Remove gaps between table borders by default.
*/

  table {
    text-indent: 0; /* 1 */
    border-color: inherit; /* 2 */
    border-collapse: collapse; /* 3 */
  }

  /*
  Use the modern Firefox focus style for all focusable elements.
*/

  :-moz-focusring {
    outline: auto;
  }

  /*
  Add the correct vertical alignment in Chrome and Firefox.
*/

  progress {
    vertical-align: baseline;
  }

  /*
  Add the correct display in Chrome and Safari.
*/

  summary {
    display: list-item;
  }

  /*
  Make lists unstyled by default.
*/

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

  /*
  1. Make replaced elements `display: block` by default. (https://github.com/mozdevs/cssremedy/issues/14)
  2. Add `vertical-align: middle` to align replaced elements more sensibly by default. (https://github.com/jensimmons/cssremedy/issues/14#issuecomment-634934210)
      This can trigger a poorly considered lint error in some tools but is included by design.
*/

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

  /*
  Constrain images and videos to the parent width and preserve their intrinsic aspect ratio. (https://github.com/mozdevs/cssremedy/issues/14)
*/

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

  /*
  1. Inherit font styles in all browsers.
  2. Remove border radius in all browsers.
  3. Remove background color in all browsers.
  4. Ensure consistent opacity for disabled states in all browsers.
*/

  button,
  input,
  select,
  optgroup,
  textarea,
  ::file-selector-button {
    font: inherit; /* 1 */
    font-feature-settings: inherit; /* 1 */
    font-variation-settings: inherit; /* 1 */
    letter-spacing: inherit; /* 1 */
    color: inherit; /* 1 */
    border-radius: 0; /* 2 */
    background-color: transparent; /* 3 */
    opacity: 1; /* 4 */
  }

  /*
  Restore default font weight.
*/

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

  /*
  Restore indentation.
*/

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

  /*
  Restore space after button.
*/

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

  /*
  Reset the default placeholder opacity in Firefox. (https://github.com/tailwindlabs/tailwindcss/issues/3300)
*/

  ::placeholder {
    opacity: 1;
  }

  /*
  Set the default placeholder color to a semi-transparent version of the current text color in browsers that do not
  crash when using `color-mix(…)` with `currentcolor`. (https://github.com/tailwindlabs/tailwindcss/issues/17194)
*/

  @supports (not (-webkit-appearance: -apple-pay-button)) /* Not Safari */ or
    (contain-intrinsic-size: 1px) /* Safari 17+ */ {
    ::placeholder {
      color: color-mix(in oklab, currentcolor 50%, transparent);
    }
  }

  /*
  Prevent resizing textareas horizontally by default.
*/

  textarea {
    resize: vertical;
  }

  /*
  Remove the inner padding in Chrome and Safari on macOS.
*/

  ::-webkit-search-decoration {
    -webkit-appearance: none;
  }

  /*
  1. Ensure date/time inputs have the same height when empty in iOS Safari.
  2. Ensure text alignment can be changed on date/time inputs in iOS Safari.
*/

  ::-webkit-date-and-time-value {
    min-height: 1lh; /* 1 */
    text-align: inherit; /* 2 */
  }

  /*
  Prevent height from changing on date/time inputs in macOS Safari when the input is set to `display: block`.
*/

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

  /*
  Remove excess padding from pseudo-elements in date/time inputs to ensure consistent height across browsers.
*/

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

  ::-webkit-datetime-edit,
  ::-webkit-datetime-edit-year-field,
  ::-webkit-datetime-edit-month-field,
  ::-webkit-datetime-edit-day-field,
  ::-webkit-datetime-edit-hour-field,
  ::-webkit-datetime-edit-minute-field,
  ::-webkit-datetime-edit-second-field,
  ::-webkit-datetime-edit-millisecond-field,
  ::-webkit-datetime-edit-meridiem-field {
    padding-block: 0;
  }

  /*
  Center dropdown marker shown on inputs with paired `<datalist>`s in Chrome. (https://github.com/tailwindlabs/tailwindcss/issues/18499)
*/

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

  /*
  Remove the additional `:invalid` styles in Firefox. (https://github.com/mozilla/gecko-dev/blob/2f9eacd9d3d995c937b4251a5557d95d494c9be1/layout/style/res/forms.css#L728-L737)
*/

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

  /*
  Correct the inability to style the border radius in iOS Safari.
*/

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

  /*
  Correct the cursor style of increment and decrement buttons in Safari.
*/

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

  /*
  Make elements with the HTML hidden attribute stay hidden by default.
*/

  [hidden]:where(:not([hidden="until-found"])) {
    display: none !important;
  }
}
@layer utilities {
  @tailwind utilities;
}
/* ═══════════════════════════════════════════════════════
   NEURAL CORE — DEEP SPACE DESIGN SYSTEM
   Avero
   Midnight Black · Electric Cyan · Neon Violet
════════════════════════════════════════════════════════ */
/* ── LOCAL WEBFONTS ────────────────────────────────────
   Brand-supplied font files live in /public/fonts/.
   Inter (UI sans), JetBrains Mono (numerics + terminal),
   Space Grotesk (display headers). The Google Fonts import
   above covers heavier weights (Inter 700/800/900, JetBrains
   Mono 500–800) not present in the local files. */
@font-face {
  font-family: 'Inter';
  src: url('/fonts/Inter-Regular.woff2') format('woff2');
  font-weight: 400; font-style: normal; font-display: swap;
}
@font-face {
  font-family: 'Inter';
  src: url('/fonts/Inter-SemiBold.woff2') format('woff2');
  font-weight: 600; font-style: normal; font-display: swap;
}
@font-face {
  font-family: 'JetBrains Mono';
  src: url('/fonts/JetBrainsMono-Regular.woff2') format('woff2'),
       url('/fonts/JetBrainsMono-Regular.ttf') format('truetype');
  font-weight: 400; font-style: normal; font-display: swap;
}
@font-face {
  font-family: 'Space Grotesk';
  src: url('/fonts/SpaceGrotesk-Regular.woff2') format('woff2');
  font-weight: 400; font-style: normal; font-display: swap;
}
@font-face {
  font-family: 'Space Grotesk';
  src: url('/fonts/SpaceGrotesk-Bold.woff2') format('woff2');
  font-weight: 700; font-style: normal; font-display: swap;
}
/* ── GLOBAL RESET ──────────────────────────────────── */
*, *::before, *::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}
/* ── DESIGN TOKENS ─────────────────────────────────── */
:root {
  /* ── CORE PALETTE ─────────────────────────────────── */
  --bg:          #020408;
  --bg-card:     rgba(4, 10, 18, 0.97);
  --bg-deep:     #010206;
  --bg-glass:    rgba(0, 245, 255, 0.03);
  --bg-elev1:    rgba(5, 11, 20, 0.98);
  --bg-elev2:    rgba(8, 14, 24, 0.99);

  /* ── BORDERS ──────────────────────────────────────── */
  --border:        rgba(0, 245, 255, 0.10);
  --border2:       rgba(0, 245, 255, 0.22);
  --border-strong: rgba(0, 245, 255, 0.40);

  /* ── ELECTRIC CYAN (primary accent) ───────────────── */
  --cyan:        #00f5ff;
  --cyan-dim:    #00b8c4;
  --cyan-glow:   rgba(0, 245, 255, 0.35);

  /* ── NEON VIOLET (secondary accent) ───────────────── */
  --violet:      #a78bfa;
  --violet-hi:   #c4b5fd;
  --violet-glow: rgba(167, 139, 250, 0.35);

  /* ── MARKET STATES ────────────────────────────────── */
  --green:       #00ffaa;
  --green-glow:  rgba(0, 255, 170, 0.45);
  --green-dim:   rgba(0, 255, 136, 0.35);

  --red:         #ff4477;
  --red-glow:    rgba(255, 68, 119, 0.45);
  --red-dim:     rgba(255, 51, 102, 0.35);

  --amber:       #ffaa00;
  --amber-glow:  rgba(255, 170, 0, 0.35);
  --orange-dim:  rgba(245, 158, 11, 0.35);

  /* ── TEXT ─────────────────────────────────────────── */
  --text:        #e0f7ff;
  --text-dim:    #94a3b8;
  --text-faint:  #64748b;

  /* Dynamic state (overridden by JS via data-market) */
  --state:       var(--cyan);
  --state-glow:  var(--cyan-glow);

  /* ── TYPOGRAPHY ───────────────────────────────────── */
  --font-sans:    'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  --font-mono:    'JetBrains Mono', 'SF Mono', 'Fira Code', 'Cascadia Code', monospace;
  --font-display: 'Space Grotesk', 'Inter', -apple-system, sans-serif;

  /* Type scale */
  --fs-xs:   10px;
  --fs-sm:   11px;
  --fs-md:   12px;
  --fs-base: 13px;
  --fs-lg:   14px;
  --fs-xl:   16px;
  --fs-2xl:  18px;
  --fs-3xl:  22px;
  --fs-4xl:  28px;
  --fs-5xl:  34px;

  /* Tracking */
  --tracking-caps:    1.4px;
  --tracking-display: 2.5px;

  /* Weights */
  --fw-regular: 400;
  --fw-medium:  500;
  --fw-bold:    700;
  --fw-heavy:   800;
  --fw-black:   900;

  /* Line heights */
  --lh-tight: 1.1;
  --lh-snug:  1.3;
  --lh-base:  1.5;
  --lh-relax: 1.65;

  /* ── SPACING ──────────────────────────────────────── */
  --sp-1:   4px;
  --sp-2:   6px;
  --sp-3:   8px;
  --sp-4:  10px;
  --sp-5:  12px;
  --sp-6:  14px;
  --sp-7:  16px;
  --sp-8:  18px;
  --sp-9:  20px;
  --sp-10: 24px;
  --sp-12: 32px;
  --sp-16: 48px;

  /* ── RADII ────────────────────────────────────────── */
  --r-xs:   4px;
  --r-sm:   6px;
  --r-md:   8px;
  --r-lg:  12px;
  --r-xl:  16px;
  --r-pill: 999px;

  /* ── ELEVATION (glow shadows) ─────────────────────── */
  --shadow-glow-cyan:   0 0 24px rgba(0, 245, 255, 0.18);
  --shadow-glow-green:  0 0 24px rgba(0, 255, 136, 0.18);
  --shadow-glow-red:    0 0 24px rgba(255, 51, 102, 0.18);
  --shadow-glow-violet: 0 0 24px rgba(139, 92, 246, 0.18);
  --shadow-card:        0 8px 32px rgba(0, 0, 0, 0.40);
  --shadow-modal:       0 0 80px rgba(0, 245, 255, 0.10), 0 40px 80px rgba(0, 0, 0, 0.50);
  --inset-cyan:         inset 0 0 0 1px rgba(0, 245, 255, 0.10);
  --accent-line:        rgba(0, 245, 255, 0.12);

  /* ── MOTION ───────────────────────────────────────── */
  --ease-out:    cubic-bezier(0.16, 1, 0.3, 1);
  --ease-in:     cubic-bezier(0.7, 0, 0.84, 0);
  --ease-spring: cubic-bezier(0.34, 1.56, 0.64, 1);

  --dur-fast: 180ms;
  --dur-base: 280ms;
  --dur-slow: 600ms;

  /* ── BLUR ─────────────────────────────────────────── */
  --blur-sm:    blur(12px);
  --blur-card:  blur(16px);       /* glass card — standard */
  --blur-deep:  blur(22px);       /* glass card — elevated */
  --blur-modal: blur(24px);       /* overlays / modals */

  /* ── GLASS BACKGROUNDS ────────────────────────────── */
  /* These layer: inner glow  ·  gradient base  ·  transparent */
  --glass-bg-card:
    radial-gradient(ellipse at 18% 8%, rgba(0,245,255,0.028) 0%, transparent 52%),
    linear-gradient(135deg, rgba(4,10,18,0.80) 0%, rgba(6,14,24,0.74) 100%);
  --glass-bg-glow:
    radial-gradient(ellipse at 28% 14%, rgba(0,245,255,0.065) 0%,
      rgba(139,92,246,0.045) 40%, transparent 66%),
    linear-gradient(135deg, rgba(4,10,18,0.80) 0%, rgba(6,14,24,0.74) 100%);
  --glass-bg-metric:
    linear-gradient(135deg, rgba(4,10,18,0.82) 0%, rgba(6,14,24,0.76) 100%);
  --glass-bg-surface:
    linear-gradient(180deg, rgba(5,11,20,0.88) 0%, rgba(4,10,18,0.92) 100%);

  /* ── GLASS BORDERS ────────────────────────────────── */
  --glass-border:      rgba(0, 245, 255, 0.09);
  --glass-border-glow: rgba(0, 245, 255, 0.20);
  --glass-highlight:   rgba(255, 255, 255, 0.05);   /* inner top edge */

  /* ── GLASS SHADOWS — multi-layer depth system ─────── */
  /* Layer order: outer glow · depth shadow · outer rim · inner top · inner bot */
  --shadow-glass:
    0 8px 32px rgba(0,0,0,0.50),
    0 0 0 0.5px rgba(0,245,255,0.055),
    inset 0 1px 0 rgba(255,255,255,0.05),
    inset 0 -1px 0 rgba(0,0,0,0.25);
  --shadow-glass-hover:
    0 10px 36px rgba(0,0,0,0.55),
    0 0 24px rgba(0,245,255,0.055),
    0 0 0 0.5px rgba(0,245,255,0.10),
    inset 0 1px 0 rgba(255,255,255,0.07),
    inset 0 -1px 0 rgba(0,0,0,0.28);
  --shadow-glass-glow:
    0 0 52px rgba(0,245,255,0.11),
    0 10px 40px rgba(0,0,0,0.55),
    0 0 0 0.5px rgba(0,245,255,0.16),
    inset 0 1px 0 rgba(0,245,255,0.09),
    inset 0 -1px 0 rgba(0,0,0,0.30);
  --shadow-glass-metric:
    0 4px 20px rgba(0,0,0,0.44),
    inset 0 1px 0 rgba(255,255,255,0.045),
    inset 0 -1px 0 rgba(0,0,0,0.18);
}
/* ── MARKET STATE OVERRIDES ────────────────────────── */
[data-market="boom"]    { --state: var(--green);  --state-glow: var(--green-glow); }
[data-market="crash"]   { --state: var(--amber);  --state-glow: var(--amber-glow); }
[data-market="neutral"] { --state: var(--cyan);   --state-glow: var(--cyan-glow);  }
/* ── BASE ──────────────────────────────────────────── */
html, body {
  background: var(--bg);
  color: var(--text);
  font-family: var(--font-sans);
  min-height: 100vh;
  font-size: 14px;
  line-height: var(--lh-base);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}
#root { min-height: 100vh; }
/* ── SCROLLBAR ─────────────────────────────────────── */
::-webkit-scrollbar         { width: 4px; height: 4px; }
::-webkit-scrollbar-track   { background: transparent; }
::-webkit-scrollbar-thumb   { background: rgba(0, 245, 255, 0.18); border-radius: 2px; }
::-webkit-scrollbar-thumb:hover { background: rgba(0, 245, 255, 0.35); }
/* ── FOCUS RING ────────────────────────────────────── */
:focus-visible { outline: 2px solid var(--cyan); outline-offset: 2px; }
/* ── BUTTONS BASE ──────────────────────────────────── */
button { font-family: inherit; cursor: pointer; border: none; background: none; }
button:disabled { cursor: not-allowed; opacity: 0.4; }
button:active { transform: scale(0.97) translateY(0); }
button:focus-visible { outline: 2px solid var(--cyan); outline-offset: 2px; }
a:focus-visible, [tabIndex]:focus-visible { outline: 2px solid var(--cyan); outline-offset: 2px; }
/* ── TABLES ────────────────────────────────────────── */
table  { border-collapse: collapse; width: 100%; }
td, th { word-break: break-word; }
/* ── SELECTION ─────────────────────────────────────── */
::selection { background: rgba(0, 245, 255, 0.2); color: var(--text); }
/* ── NOISE TEXTURE OVERLAY ─────────────────────────── */
body::before {
  content: '';
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 1;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)' opacity='0.025'/%3E%3C/svg%3E");
  opacity: 0.4;
}
/* ── SEMANTIC TYPE CLASSES ─────────────────────────── */
/* Display — Space Grotesk, hero numerics, big section titles */
.type-display {
  font-family: var(--font-display);
  font-size: var(--fs-5xl);
  font-weight: var(--fw-bold);
  letter-spacing: -0.6px;
  line-height: var(--lh-tight);
  color: var(--text);
}
.type-display-mono {
  font-family: var(--font-display);
  font-size: var(--fs-3xl);
  font-weight: var(--fw-bold);
  letter-spacing: 0.2px;
  line-height: var(--lh-snug);
  text-transform: uppercase;
  color: var(--text);
}
/* Headings */
.type-h1 {
  font-family: var(--font-sans);
  font-size: var(--fs-4xl);
  font-weight: var(--fw-black);
  letter-spacing: -0.3px;
  line-height: var(--lh-tight);
  color: var(--text);
}
.type-h2 {
  font-family: var(--font-sans);
  font-size: var(--fs-3xl);
  font-weight: var(--fw-heavy);
  letter-spacing: -0.2px;
  line-height: var(--lh-snug);
  color: var(--text);
}
.type-h3 {
  font-family: var(--font-sans);
  font-size: var(--fs-2xl);
  font-weight: var(--fw-heavy);
  line-height: var(--lh-snug);
  color: var(--text);
}
/* Body */
.type-body {
  font-family: var(--font-sans);
  font-size: var(--fs-base);
  font-weight: var(--fw-regular);
  line-height: var(--lh-relax);
  color: var(--text);
}
.type-body-dim {
  font-family: var(--font-sans);
  font-size: var(--fs-md);
  color: var(--text-dim);
  line-height: var(--lh-base);
}
/* SECTION EYEBROW — small caps, tracked, faint. Used on every GlassCard header */
.type-eyebrow {
  font-family: var(--font-sans);
  font-size: var(--fs-xs);
  font-weight: var(--fw-bold);
  text-transform: uppercase;
  letter-spacing: var(--tracking-caps);
  color: var(--text-faint);
}
/* TERMINAL — JetBrains Mono for system text, log lines, tickers */
.type-terminal {
  font-family: var(--font-mono);
  font-size: var(--fs-md);
  font-weight: var(--fw-regular);
  color: var(--cyan);
  letter-spacing: 0.3px;
}
/* MONO DATA — tabular numerics for prices, percentages, timestamps */
.type-mono-data {
  font-family: var(--font-mono);
  font-size: var(--fs-md);
  font-weight: var(--fw-medium);
  color: var(--text);
  font-variant-numeric: tabular-nums;
}
/* NUMERIC LARGE — hero equity/P&L figures */
.type-numeric-large {
  font-family: var(--font-mono);
  font-size: var(--fs-4xl);
  font-weight: var(--fw-black);
  color: var(--text);
  font-variant-numeric: tabular-nums;
  letter-spacing: -0.5px;
}
/* BRAND WORDMARK — header lockup sub-line */
.type-brand {
  font-family: var(--font-mono);
  font-size: var(--fs-sm);
  font-weight: var(--fw-bold);
  letter-spacing: var(--tracking-display);
  color: var(--text-faint);
  text-transform: uppercase;
}
/* ── GLASS CARD ────────────────────────────────────── */
.glass {
  background: var(--bg-card);
  backdrop-filter: var(--blur-card);
  -webkit-backdrop-filter: var(--blur-card);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
}
/* ── GLOW TEXT UTILITIES ───────────────────────────── */
.glow-cyan   { text-shadow: 0 0 12px var(--cyan-glow); }
.glow-green  { text-shadow: 0 0 12px var(--green-glow); }
.glow-red    { text-shadow: 0 0 12px var(--red-glow); }
.glow-amber  { text-shadow: 0 0 12px var(--amber-glow); }
.glow-violet { text-shadow: 0 0 12px var(--violet-glow); }
/* ── MONO SHORTHAND ────────────────────────────────── */
.mono { font-family: var(--font-mono); font-variant-numeric: tabular-nums; }
/* ── ANIMATIONS ────────────────────────────────────── */
@keyframes scanline {
  0%   { transform: translateY(-100%); }
  100% { transform: translateY(100vh); }
}
@keyframes pulse-glow {
  0%, 100% { opacity: 1; }
  50%       { opacity: 0.25; }
}
@keyframes pulse-scale {
  0%, 100% { transform: scale(1); }
  50%       { transform: scale(1.06); }
}
@keyframes ticker-scroll {
  0%   { transform: translateX(0); }
  100% { transform: translateX(-50%); }
}
/* ═══════════════════════════════════════════════════════
   LAYOUT — App shell, topbar, tabs, main, footer
════════════════════════════════════════════════════════ */
/* ── PARTICLE CANVAS ───────────────────────────────── */
#particle-canvas {
  position: fixed;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  width: 100%;
  height: 100%;
}
/* ── SCANLINES OVERLAY ─────────────────────────────── */
.scanlines {
  position: fixed;
  inset: 0;
  z-index: 1;
  pointer-events: none;
  background: repeating-linear-gradient(
    0deg,
    transparent,
    transparent 2px,
    rgba(0, 0, 0, 0.04) 2px,
    rgba(0, 0, 0, 0.04) 4px
  );
}
/* ── APP SHELL ─────────────────────────────────────── */
.app {
  position: relative;
  z-index: 2;
  display: flex;
  flex-direction: column;
  min-height: 100vh;
  background: transparent;
}
/* ── TOPBAR — glass surface ────────────────────────── */
.topbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--sp-5);
  padding: var(--sp-3) var(--sp-9);
  height: 56px;
  border-bottom: 1px solid var(--glass-border);
  /* Glass surface: moderate opacity + blur */
  background: var(--glass-bg-surface);
  backdrop-filter: var(--blur-deep) saturate(1.2);
  -webkit-backdrop-filter: var(--blur-deep) saturate(1.2);
  box-shadow:
    0 1px 0 rgba(0,245,255,0.06),
    0 4px 24px rgba(0,0,0,0.35),
    inset 0 -1px 0 rgba(0,0,0,0.20);
  flex-shrink: 0;
  position: relative;
  z-index: 10;
}
.brand {
  display: flex;
  align-items: center;
  gap: var(--sp-4);
  min-width: 160px;
}
.brand-name {
  font-family: var(--font-display);
  font-size: var(--fs-xl);
  font-weight: var(--fw-heavy);
  letter-spacing: var(--tracking-display);
  color: var(--cyan);
  line-height: 1;
}
.brand-sub {
  font-family: var(--font-mono);
  font-size: 9px;
  letter-spacing: 0.8px;
  color: var(--text-faint);
  text-transform: uppercase;
  margin-top: 2px;
}
.topbar-strip {
  display: flex;
  align-items: center;
  gap: var(--sp-8);
  flex: 1;
  justify-content: center;
}
.tb-stat {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 2px;
}
.tb-stat .label {
  font-family: var(--font-mono);
  font-size: 9px;
  font-weight: var(--fw-bold);
  letter-spacing: 0.8px;
  color: var(--text-faint);
  text-transform: uppercase;
}
.tb-stat .v {
  font-family: var(--font-mono);
  font-size: var(--fs-lg);
  font-weight: var(--fw-bold);
  color: var(--text);
  font-variant-numeric: tabular-nums;
}
.topbar-right {
  display: flex;
  align-items: center;
  gap: var(--sp-7);
  min-width: 160px;
  justify-content: flex-end;
}
.market-pill {
  display: flex;
  align-items: center;
  gap: var(--sp-2);
  font-family: var(--font-mono);
  font-size: var(--fs-xs);
  font-weight: var(--fw-bold);
  letter-spacing: var(--tracking-caps);
  color: var(--state);
  text-transform: uppercase;
}
/* ── E-STOP pulse animation ──────────────────────────────────────────────────── */
@keyframes estopPulse {
  0%, 100% { box-shadow: 0 0 4px rgba(255,51,102,0.2); }
  50%      { box-shadow: 0 0 14px rgba(255,51,102,0.6); }
}
.estop-pulse {
  animation: estopPulse 2s ease-in-out infinite;
}
/* ── Toast notifications ─────────────────────────────────────────────────────── */
.toast-container {
  position: fixed; top: 56px; right: 16px; z-index: 9999;
  display: flex; flex-direction: column; gap: 6px;
  pointer-events: none;
}
.toast {
  padding: 8px 16px; border-radius: 6px; font-size: 11px;
  font-family: var(--font-mono); font-weight: 500;
  backdrop-filter: blur(8px); pointer-events: auto;
  max-width: 380px; line-height: 1.4;
}
.toast-success { background: rgba(0,255,136,0.12); border: 1px solid rgba(0,255,136,0.3); color: var(--green); }
.toast-error   { background: rgba(255,51,102,0.12); border: 1px solid rgba(255,51,102,0.3); color: var(--red); }
.toast-info    { background: rgba(0,245,255,0.10); border: 1px solid rgba(0,245,255,0.2); color: var(--cyan); }
/* ── Bot status pill ───────────────────────────────────────────────────── */
.bot-status-pill {
  display: inline-flex; align-items: center; gap: 5px;
  padding: 3px 10px; border-radius: 20px; font-size: 10px;
  font-weight: 700; letter-spacing: 0.06em; text-transform: uppercase;
}
.bot-status-pill.live  { background: rgba(0,255,136,0.1); border: 1px solid rgba(0,255,136,0.3); color: var(--green); }
.bot-status-pill.idle  { background: rgba(255,255,255,0.04); border: 1px solid rgba(255,255,255,0.1); color: var(--text-faint); }
.bot-status-pill.error { background: rgba(255,51,102,0.1); border: 1px solid rgba(255,51,102,0.3); color: var(--red); }
.clock {
  display: flex;
  align-items: center;
  gap: var(--sp-2);
  font-family: var(--font-mono);
  font-size: var(--fs-sm);
  color: var(--text-dim);
}
.clock .label {
  color: var(--text-faint);
  font-size: var(--fs-xs);
  letter-spacing: 1px;
}
.stale-indicator {
  color: var(--amber);
  font-size: 12px;
  margin-left: 4px;
  animation: pulse-glow 1s ease-in-out infinite;
}
/* ── TABS — glass surface ──────────────────────────── */
.tabs {
  display: flex;
  align-items: center;
  gap: 2px;
  padding: 0 var(--sp-9);
  height: 40px;
  border-bottom: 1px solid var(--glass-border);
  background: linear-gradient(180deg,
    rgba(4,10,18,0.86) 0%,
    rgba(3,8,16,0.90) 100%
  );
  backdrop-filter: var(--blur-card) saturate(1.15);
  -webkit-backdrop-filter: var(--blur-card) saturate(1.15);
  box-shadow:
    0 1px 0 rgba(0,245,255,0.05),
    inset 0 -1px 0 rgba(0,0,0,0.15);
  flex-shrink: 0;
  position: relative;
  z-index: 10;
}
.tab {
  background: none;
  border: none;
  display: flex;
  align-items: center;
  gap: 6px;
  color: var(--text-dim);
  font-size: 11px;
  font-weight: 700;
  padding: 10px 14px;
  cursor: pointer;
  border-radius: 0;
  transition: color 0.2s, background 0.2s;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  white-space: nowrap;
  border-bottom: 2px solid transparent;
  position: relative;
}
.tab:hover {
  background: rgba(0,245,255,0.04);
  color: var(--text);
}
.tab-active-line {
  position: absolute;
  bottom: -1px;
  left: 4px;
  right: 4px;
  height: 2px;
  background: linear-gradient(90deg, var(--accent), var(--accent-glow, rgba(0,245,255,0.6)));
  border-radius: 1px;
}
.tab:hover { color: var(--text); }
.tab[data-active="true"] { color: var(--accent); border-bottom-color: var(--accent); }
.tab .num {
  color: var(--text-faint);
  font-size: 9px;
}
.tabs-right {
  margin-left: auto;
  display: flex;
  align-items: center;
  gap: var(--sp-9);
  font-family: var(--font-mono);
  font-size: var(--fs-xs);
  font-weight: var(--fw-bold);
  letter-spacing: var(--tracking-caps);
  text-transform: uppercase;
  color: var(--text-faint);
}
.ws-status {
  display: flex;
  align-items: center;
  gap: var(--sp-2);
  color: var(--green);
}
/* ── MAIN CONTENT ──────────────────────────────────── */
.main {
  flex: 1;
  overflow-y: auto;
  overflow-x: hidden;
  padding: var(--sp-7) var(--sp-9) var(--sp-10);
  background: transparent;
  position: relative;
  z-index: 2;
}
/* ── FOOTER ────────────────────────────────────────── */
.footer {
  display: flex;
  align-items: center;
  gap: var(--sp-9);
  padding: 0 var(--sp-9);
  height: 32px;
  border-top: 1px solid var(--border);
  background: rgba(5, 11, 20, 0.99);
  font-family: var(--font-mono);
  font-size: var(--fs-xs);
  font-weight: var(--fw-bold);
  letter-spacing: var(--tracking-caps);
  text-transform: uppercase;
  color: var(--text-faint);
  flex-shrink: 0;
}
.footer .seg {
  display: flex;
  align-items: center;
  gap: var(--sp-2);
}
.footer .right {
  margin-left: auto;
  display: flex;
  align-items: center;
  gap: var(--sp-7);
}
/* (LED defined in component section below) */
/* ── COMMON DIM SPAN ───────────────────────────────── */
.dim { color: var(--text-faint); }
/* ── BUTTON VARIANTS ───────────────────────────────── */
.btn {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-2);
  padding: var(--sp-3) var(--sp-7);
  border-radius: var(--r-sm);
  font-family: var(--font-mono);
  font-size: var(--fs-xs);
  font-weight: var(--fw-bold);
  letter-spacing: var(--tracking-caps);
  text-transform: uppercase;
  transition: background var(--dur-fast), box-shadow var(--dur-fast);
  cursor: pointer;
  border: none;
}
.btn-cyan {
  background: rgba(0, 245, 255, 0.12);
  color: var(--cyan);
  border: 1px solid var(--border2);
}
.btn-cyan:hover {
  background: rgba(0, 245, 255, 0.20);
  box-shadow: 0 0 16px rgba(0, 245, 255, 0.15);
}
.btn-danger {
  background: rgba(255, 51, 102, 0.12);
  color: var(--red);
  border: 1px solid rgba(255, 51, 102, 0.22);
}
.btn-danger:hover {
  background: rgba(255, 51, 102, 0.22);
  box-shadow: 0 0 16px var(--red-glow);
}
/* ── STAT ROW ──────────────────────────────────────── */
.stat-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--sp-2) 0;
  border-bottom: 1px solid var(--border);
  font-family: var(--font-mono);
  font-size: var(--fs-xs);
}
.stat-row:last-child { border-bottom: none; }
.stat-row .s-label { color: var(--text-faint); text-transform: uppercase; letter-spacing: 0.8px; }
.stat-row .s-val   { color: var(--text); font-weight: var(--fw-bold); }
/* ── ACTIVITY LOG ──────────────────────────────────── */
.log-line {
  display: grid;
  grid-template-columns: 60px 40px 1fr;
  gap: var(--sp-3);
  padding: var(--sp-1) 0;
  font-family: var(--font-mono);
  font-size: var(--fs-xs);
  border-bottom: 1px solid rgba(0, 245, 255, 0.04);
}
.log-ts   { color: var(--text-faint); }
.log-ok   { color: var(--green); }
.log-warn { color: var(--amber); }
.log-info { color: var(--cyan-dim); }
.log-err  { color: var(--red); }
/* ── POSITION TABLE ────────────────────────────────── */
.pos-table { width: 100%; }
.pos-table th {
  font-family: var(--font-mono);
  font-size: var(--fs-xs);
  font-weight: var(--fw-bold);
  letter-spacing: var(--tracking-caps);
  text-transform: uppercase;
  color: var(--text-faint);
  padding: var(--sp-2) var(--sp-3);
  text-align: left;
  border-bottom: 1px solid var(--border);
}
.pos-table td {
  font-family: var(--font-mono);
  font-size: var(--fs-xs);
  padding: var(--sp-2) var(--sp-3);
  border-bottom: 1px solid rgba(0, 245, 255, 0.04);
  color: var(--text);
  font-variant-numeric: tabular-nums;
}
.pos-table tr:hover td { background: rgba(0, 245, 255, 0.03); }
/* ── BADGE / PILL ──────────────────────────────────── */
.badge {
  display: inline-flex;
  align-items: center;
  padding: 2px 6px;
  border-radius: var(--r-pill);
  font-family: var(--font-mono);
  font-size: 9px;
  font-weight: var(--fw-bold);
  letter-spacing: 0.6px;
  text-transform: uppercase;
}
.badge-buy   { background: rgba(0, 255, 136, 0.12); color: var(--green); border: 1px solid rgba(0, 255, 136, 0.2); }
.badge-sell  { background: rgba(255, 51, 102, 0.12); color: var(--red);  border: 1px solid rgba(255, 51, 102, 0.2);}
.badge-hold  { background: rgba(0, 245, 255, 0.08); color: var(--cyan-dim); border: 1px solid var(--border); }
.badge-long  { background: rgba(0, 255, 136, 0.10); color: var(--green); }
.badge-short { background: rgba(255, 51, 102, 0.10); color: var(--red); }
/* ═══════════════════════════════════════════════════════
   ACCENT ALIAS — maps --accent to current state color
════════════════════════════════════════════════════════ */
:root {
  --accent:      var(--cyan);
  --accent-glow: var(--cyan-glow);
}
[data-market="boom"]  { --accent: var(--green);  --accent-glow: var(--green-glow); }
[data-market="crash"] { --accent: var(--amber);  --accent-glow: var(--amber-glow); }
/* ── Light Theme ──────────────────────────────────────── */
[data-theme="light"] {
  --bg: #f8fafc;
  --bg-glass: #ffffff;
  --bg-card: #ffffff;
  --card-bg: #ffffff;
  --border: #e2e8f0;
  --text: #0f172a;
  --text-dim: #475569;
  --text-faint: #94a3b8;
  --shadow-glass: 0 1px 3px rgba(0,0,0,0.06);
}
/* ═══════════════════════════════════════════════════════
   CARD — glassmorphism panel — the beating heart of the UI
   Three depth tiers: default · .glow · .deep
════════════════════════════════════════════════════════ */
/* ── Base glass card ──────────────────────────────────────
   backdrop-filter creates the frosted-glass blur.
   Multi-layer background:
     1. radial inner glow (top-left origin)
     2. dark gradient base
   Multi-layer box-shadow:
     1. outer depth shadow
     2. hair-line outer rim (gives "floating" appearance)
     3. inset top highlight (frosted glass top edge)
     4. inset bottom shadow (depth baseline)
──────────────────────────────────────────────────────── */
.card {
  background:           var(--glass-bg-card);
  backdrop-filter:      var(--blur-card) saturate(1.15);
  -webkit-backdrop-filter: var(--blur-card) saturate(1.15);
  border:               1px solid var(--glass-border);
  border-radius:        var(--r-lg);
  padding:              var(--sp-5);
  display:              flex;
  flex-direction:       column;
  min-height:           0;
  box-shadow:           var(--shadow-glass);
  position:             relative;
  z-index:              1;
  transition:
    border-color var(--dur-fast),
    box-shadow   var(--dur-base),
    transform    var(--dur-fast);
}
.card:hover {
  transform: translateY(-1px) scale(1.002);
  box-shadow: var(--shadow-glass-hover);
}
/* ── Glow variant — used on AI confidence, reasoning ── */
.card.glow {
  background:   var(--glass-bg-glow);
  border-color: var(--glass-border-glow);
  box-shadow:   var(--shadow-glass-glow);
}
/* ── Deep variant — elevated overlay cards ─────────── */
.card.deep {
  backdrop-filter: var(--blur-deep) saturate(1.2);
  -webkit-backdrop-filter: var(--blur-deep) saturate(1.2);
  box-shadow:
    0 16px 48px rgba(0,0,0,0.60),
    0 0 0 0.5px rgba(0,245,255,0.08),
    inset 0 1px 0 rgba(255,255,255,0.06),
    inset 0 -1px 0 rgba(0,0,0,0.30);
}
/* ── Bracketed variant — left accent stripe ─────────── */
.card.bracketed {
  border-left:   2px solid var(--accent);
  border-radius: 0 var(--r-lg) var(--r-lg) 0;
}
.card-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding-bottom: var(--sp-4);
  margin-bottom: var(--sp-4);
  border-bottom: 1px solid var(--border);
  flex-shrink: 0;
  gap: var(--sp-4);
}
.card-title {
  display: flex;
  align-items: center;
  gap: var(--sp-3);
  font-family: var(--font-mono);
  font-size: var(--fs-xs);
  font-weight: var(--fw-bold);
  letter-spacing: var(--tracking-caps);
  text-transform: uppercase;
  color: var(--text-faint);
}
.card-title .index {
  color: var(--accent);
  font-size: 9px;
  letter-spacing: 0.8px;
}
.card-actions {
  display: flex;
  align-items: center;
  gap: var(--sp-3);
  font-family: var(--font-mono);
  font-size: var(--fs-xs);
  font-weight: var(--fw-bold);
  letter-spacing: var(--tracking-caps);
  text-transform: uppercase;
  color: var(--text-faint);
}
/* ═══════════════════════════════════════════════════════
   LED — revised to use class selectors (not data-tone)
════════════════════════════════════════════════════════ */
.led {
  display: inline-block;
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--cyan);
  box-shadow: 0 0 6px var(--cyan-glow);
  animation: pulse-glow 2s ease-in-out infinite;
  flex-shrink: 0;
  vertical-align: middle;
}
.led.green  { background: var(--green);  box-shadow: 0 0 6px var(--green-glow); }
.led.red    { background: var(--red);    box-shadow: 0 0 6px var(--red-glow);   }
.led.amber  { background: var(--amber);  box-shadow: 0 0 6px var(--amber-glow); }
.led.violet { background: var(--violet); box-shadow: 0 0 6px var(--violet-glow);}
.led.off    { background: var(--text-faint); box-shadow: none; animation: none; opacity: 0.4; }
/* ═══════════════════════════════════════════════════════
   CHIP / TAG
════════════════════════════════════════════════════════ */
.chip {
  display: inline-flex;
  align-items: center;
  padding: 2px 7px;
  border-radius: var(--r-pill);
  font-family: var(--font-mono);
  font-size: 9px;
  font-weight: var(--fw-bold);
  letter-spacing: 0.6px;
  text-transform: uppercase;
  border: 1px solid var(--border);
  color: var(--text-faint);
  background: var(--bg-glass);
}
.chip.cyan   { color: var(--cyan);  border-color: rgba(0,245,255,0.3); background: rgba(0,245,255,0.07); }
.chip.green  { color: var(--green); border-color: rgba(0,255,136,0.3); background: rgba(0,255,136,0.07); }
.chip.red    { color: var(--red);   border-color: rgba(255,51,102,0.3);background: rgba(255,51,102,0.07);}
.chip.amber  { color: var(--amber); border-color: rgba(255,170,0,0.3); background: rgba(255,170,0,0.07); }
.chip.violet { color: var(--violet);border-color: rgba(139,92,246,0.3);background: rgba(139,92,246,0.07);}
/* ═══════════════════════════════════════════════════════
   NUM TICKER
════════════════════════════════════════════════════════ */
.num-ticker { transition: color 180ms; }
.num-ticker.flash { color: var(--accent); text-shadow: 0 0 10px var(--accent-glow); }
/* ═══════════════════════════════════════════════════════
   SPARK
════════════════════════════════════════════════════════ */
.spark { display: block; opacity: 0.8; }
/* ═══════════════════════════════════════════════════════
   UTILITIES — used across all panels
════════════════════════════════════════════════════════ */
.row   { display: flex; align-items: center; gap: var(--sp-3); }
.spaced { justify-content: space-between; }
.faint { color: var(--text-faint); }
.v     { font-family: var(--font-mono); font-weight: var(--fw-bold); color: var(--text); font-variant-numeric: tabular-nums; }
.b     { font-weight: var(--fw-bold); }
.l     { font-family: var(--font-mono); font-size: var(--fs-xs); color: var(--text-faint); text-transform: uppercase; letter-spacing: 0.8px; }
/* Progress bar */
.bar {
  height: 4px;
  border-radius: var(--r-pill);
  background: rgba(0,245,255,0.08);
  overflow: hidden;
  position: relative;
}
.bar .fill {
  height: 100%;
  border-radius: var(--r-pill);
  background: linear-gradient(90deg, var(--accent), var(--accent-glow));
  transition: width 600ms var(--ease-out);
  box-shadow: 0 0 6px var(--accent-glow);
}
/* ═══════════════════════════════════════════════════════
   TAB PANE — fills the .main area
════════════════════════════════════════════════════════ */
.tabpane {
  width: 100%;
  height: 100%;
  display: flex;
  flex-direction: column;
  gap: 0;
}
.tab-container {
  position: relative;
  min-height: 60vh;
}
.tab-pane-inner {
  display: flex;
  flex-direction: column;
  flex: 1 1 0;
  min-height: 0;
  overflow: hidden;
  width: 100%;
}
.tab-pane-inner[data-active="false"] {
  display: none;
}
.sub-nav { scrollbar-width: none; -webkit-overflow-scrolling: touch; }
.sub-nav::-webkit-scrollbar { display: none; }
/* ═══════════════════════════════════════════════════════
   DASHBOARD GRID — F-01
════════════════════════════════════════════════════════ */
.dash-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-template-rows: auto minmax(160px, 240px) auto 1fr;
  gap: var(--sp-5);
  align-content: start;
}
/* Stats row spans full width */
.dash-stats {
  grid-column: 1 / -1;
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: var(--sp-4);
}
/* Equity chart — spans both columns */
.card.dash-chart {
  grid-column: 1 / -1;
  height: 200px;
}
/* Positions — left column */
.card.dash-positions {
  grid-column: 1;
  min-height: 160px;
}
/* Circuit breaker — right column wrapper */
.dash-breaker {
  grid-column: 2;
  display: flex;
  flex-direction: column;
  min-height: 160px;
}
.dash-breaker .card {
  flex: 1;
}
/* Activity log — full width wrapper */
.dash-log {
  grid-column: 1 / -1;
  display: flex;
  flex-direction: column;
  max-height: 220px;
  overflow: hidden;
}
.dash-log .card {
  flex: 1;
  min-height: 0;
  overflow: hidden;
}
/* ── Stat tile ─────────────────────────────────────── */
.stat {
  background: rgba(4, 10, 18, 0.97);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  padding: var(--sp-4) var(--sp-5);
  display: flex;
  flex-direction: column;
  gap: 3px;
}
.stat .label {
  font-family: var(--font-mono);
  font-size: var(--fs-xs);
  font-weight: var(--fw-bold);
  letter-spacing: var(--tracking-caps);
  text-transform: uppercase;
  color: var(--text-faint);
}
.stat .v {
  font-family: var(--font-mono);
  font-size: var(--fs-lg);
  font-weight: var(--fw-bold);
  color: var(--text);
  font-variant-numeric: tabular-nums;
  line-height: 1.2;
}
.stat .v.lg {
  font-size: var(--fs-2xl);
}
.stat .sub {
  font-family: var(--font-mono);
  font-size: var(--fs-xs);
  color: var(--text-dim);
  display: flex;
  align-items: center;
  gap: 4px;
  margin-top: 2px;
}
/* ── Equity chart ─────────────────────────────────── */
.chart-wrap {
  position: relative;
  width: 100%;
  flex: 1;
  min-height: 100px;
}
.grid-line {
  stroke: rgba(0, 245, 255, 0.07);
}
/* ── Position row ─────────────────────────────────── */
.position-row {
  display: grid;
  grid-template-columns: 1fr 2fr 72px 80px;
  gap: var(--sp-4);
  align-items: center;
  padding: var(--sp-3) 0;
  border-bottom: 1px solid rgba(0,245,255,0.05);
  font-family: var(--font-mono);
  font-size: var(--fs-xs);
}
.position-row:last-child { border-bottom: none; }
.position-row .sym {
  font-size: var(--fs-md);
  font-weight: var(--fw-bold);
  color: var(--text);
  letter-spacing: 0.6px;
}
.position-row .meta {
  font-size: 10px;
  color: var(--text-faint);
  letter-spacing: 0.4px;
  text-transform: uppercase;
  margin-top: 2px;
}
.pnl-bar {
  height: 3px;
  border-radius: 2px;
  background: rgba(0,245,255,0.08);
  margin-top: 4px;
  position: relative;
  overflow: visible;
  display: flex;
  align-items: center;
}
.pnl-bar .f {
  height: 3px;
  border-radius: 2px;
  min-width: 2px;
  transition: width 400ms var(--ease-out);
}
.pnl-sign {
  position: absolute;
  right: -14px;
  font-size: 8px;
  color: var(--text-faint);
  pointer-events: none;
}
.pnl-pct {
  font-family: var(--font-mono);
  font-size: var(--fs-xs);
  font-weight: var(--fw-bold);
  text-align: right;
  font-variant-numeric: tabular-nums;
}
/* ── Activity log ─────────────────────────────────── */
.log {
  display: flex;
  flex-direction: column;
  gap: 1px;
  overflow-y: auto;
  overflow-x: hidden;
  flex: 1;
  min-height: 0;
  max-height: 130px;
}
.log .line {
  display: grid;
  grid-template-columns: 60px 40px 1fr;
  gap: var(--sp-3);
  padding: 3px 0;
  font-family: var(--font-mono);
  font-size: var(--fs-xs);
  border-bottom: 1px solid rgba(0,245,255,0.03);
  line-height: 1.4;
}
.log .line .ts  { color: var(--text-faint); }
.log .line .lv  { color: var(--cyan-dim); text-transform: uppercase; font-weight: var(--fw-bold); }
.log .line .lv.ok   { color: var(--green); }
.log .line .lv.warn { color: var(--amber); }
.log .line .lv.err  { color: var(--red); }
.log .line .msg { color: var(--text-dim); word-break: break-word; }
/* ═══════════════════════════════════════════════════════
   AI COMMAND GRID — F-02
════════════════════════════════════════════════════════ */
.ai-grid {
  display: grid;
  grid-template-columns: 280px 1fr;
  grid-template-rows: auto auto 1fr;
  gap: var(--sp-5);
  height: 100%;
}
/* Ring / confidence meter */
.ring-wrap {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: var(--sp-4) auto;
}
.ring-bg  { stroke: rgba(0,245,255,0.08); }
.ring-fg  { stroke: var(--accent); transition: stroke-dashoffset 600ms var(--ease-out); }
.ring-center {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
}
.confidence-stack {
  display: flex;
  flex-direction: column;
  gap: var(--sp-3);
}
.risk-meter {
  display: flex;
  flex-direction: column;
  gap: var(--sp-2);
  margin-top: var(--sp-2);
}
.risk-row {
  display: flex;
  align-items: center;
  gap: var(--sp-4);
  font-family: var(--font-mono);
  font-size: var(--fs-xs);
  color: var(--text-faint);
}
.risk-row .lab { flex: 1; text-transform: uppercase; letter-spacing: 0.8px; }
.tok {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-2);
  padding: 3px 8px;
  border-radius: var(--r-pill);
  font-family: var(--font-mono);
  font-size: 10px;
  font-weight: var(--fw-bold);
  letter-spacing: 0.6px;
  text-transform: uppercase;
  background: rgba(0,245,255,0.07);
  color: var(--cyan-dim);
  border: 1px solid var(--border);
}
/* Signal list */
.ln {
  display: grid;
  grid-template-columns: 56px 52px 1fr 52px 56px;
  gap: var(--sp-3);
  align-items: center;
  padding: var(--sp-2) 0;
  border-bottom: 1px solid rgba(0,245,255,0.04);
  font-family: var(--font-mono);
  font-size: var(--fs-xs);
}
.ln .sym  { font-weight: var(--fw-bold); color: var(--text); }
.ln .reason { color: var(--text-faint); font-size: 10px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
/* Blinking cursor for terminal */
.cursor {
  display: inline-block;
  width: 7px;
  height: 13px;
  background: var(--accent);
  opacity: 0.8;
  animation: pulse-glow 1s step-start infinite;
  vertical-align: middle;
  margin-left: 2px;
  border-radius: 1px;
}
/* ═══════════════════════════════════════════════════════
   LIVE FEED GRID — F-03
════════════════════════════════════════════════════════ */
.feed-grid {
  display: grid;
  grid-template-columns: 320px 1fr;
  grid-template-rows: 1fr auto;
  gap: var(--sp-5);
  height: 100%;
}
/* Price chart */
.card.feed-chart {
  grid-column: 2;
  grid-row: 1;
  min-height: 200px;
}
/* Tick stream */
.card.feed-stream {
  grid-column: 1;
  grid-row: 1;
  overflow: hidden;
}
.tick-stream {
  display: flex;
  flex-direction: column;
  gap: 2px;
  overflow-y: auto;
  flex: 1;
  max-height: 420px;
}
.tick-stream .ts  { color: var(--text-faint); font-family: var(--font-mono); font-size: 10px; }
.tick-stream .sym { font-weight: var(--fw-bold); color: var(--text); font-size: var(--fs-xs); }
.tick-stream .px  { font-family: var(--font-mono); font-size: var(--fs-xs); font-variant-numeric: tabular-nums; font-weight: var(--fw-bold); }
.tick-stream .vol { color: var(--text-faint); font-size: 10px; }
/* Symbol grid */
.card.feed-symbols {
  grid-column: 1 / -1;
  grid-row: 2;
}
.sym-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(100px, 1fr));
  gap: var(--sp-3);
}
/* Market state badge */
.feed-state {
  display: flex;
  align-items: center;
  gap: var(--sp-3);
  font-family: var(--font-mono);
  font-size: var(--fs-xs);
  font-weight: var(--fw-bold);
  letter-spacing: var(--tracking-caps);
  text-transform: uppercase;
  color: var(--accent);
  padding: var(--sp-3) var(--sp-5);
  background: rgba(0,245,255,0.04);
  border-radius: var(--r-sm);
  border: 1px solid var(--border);
}
/* ═══════════════════════════════════════════════════════
   BUTTON VARIANTS
════════════════════════════════════════════════════════ */
.btn {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-2);
  padding: 2px var(--sp-5);
  border-radius: var(--r-xs);
  font-family: var(--font-mono);
  font-size: var(--fs-xs);
  font-weight: var(--fw-bold);
  letter-spacing: 0.8px;
  text-transform: uppercase;
  color: var(--text-faint);
  background: rgba(0,245,255,0.05);
  border: 1px solid var(--border);
  cursor: pointer;
  transition: background var(--dur-fast), color var(--dur-fast);
}
.btn:hover, .btn[data-active="true"] {
  background: rgba(0,245,255,0.12);
  color: var(--accent);
  border-color: var(--border2);
}
.btn-start {
  padding: var(--sp-3) var(--sp-9);
  border-radius: var(--r-sm);
  background: rgba(0,255,136,0.10);
  color: var(--green);
  border: 1px solid rgba(0,255,136,0.25);
  font-size: var(--fs-sm);
}
.btn-start:hover { background: rgba(0,255,136,0.18); box-shadow: 0 0 16px rgba(0,255,136,0.15); }
.btn-stop {
  padding: var(--sp-3) var(--sp-9);
  border-radius: var(--r-sm);
  background: rgba(255,51,102,0.10);
  color: var(--red);
  border: 1px solid rgba(255,51,102,0.25);
  font-size: var(--fs-sm);
}
.btn-stop:hover  { background: rgba(255,51,102,0.18); box-shadow: 0 0 16px var(--red-glow); }
/* ═══════════════════════════════════════════════════════
   RESPONSIVE COLLAPSE
════════════════════════════════════════════════════════ */
@media (max-width: 1100px) {
  .dash-stats { grid-template-columns: repeat(3, 1fr); }
  .ai-grid    { grid-template-columns: 1fr; }
  .feed-grid  { grid-template-columns: 1fr; }
}
@media (max-width: 780px) {
  .topbar          { flex-wrap: wrap; height: auto; padding: var(--sp-3); gap: var(--sp-3); }
  .topbar-strip    { justify-content: flex-start; flex-wrap: wrap; }
  .dash-grid       { grid-template-columns: 1fr; }
  .dash-stats      { grid-template-columns: repeat(2, 1fr); }
  .card.dash-chart { grid-column: 1; }
  .card.dash-positions { grid-column: 1; }
}
/* ── Mobile: ultra-compact (max 480px) ──────────────── */
@media (max-width: 480px) {
  .topbar { padding: 4px 8px; gap: 4px; height: auto; }
  .brand { min-width: auto; gap: 4px; }
  .brand-name { font-size: 14px; letter-spacing: 1.5px; }
  .brand-sub { display: none; }
  .topbar-strip { gap: 6px; }
  .tb-stat .label { font-size: 7px; letter-spacing: 0.5px; }
  .tb-stat .v { font-size: 10px; }
  .topbar-right { gap: 6px; min-width: auto; }
  .market-pill span { display: none; }
  .clock .label { display: none; }
  .tabs { padding: 0 4px; gap: 0; overflow-x: auto; }
  .tab { padding: 8px 8px; font-size: 9px; }
  .main { padding: var(--sp-3); }
  .dash-stats { grid-template-columns: 1fr 1fr; gap: 4px; }
  .dash-grid { gap: 4px; }
  .stat { padding: 6px; }
  .stat .v { font-size: 11px; }
  .stat .v.lg { font-size: 14px; }
  .card { padding: 8px; }
  .card-head { padding-bottom: 6px; margin-bottom: 6px; }
  .footer { padding: 0 8px; font-size: 8px; gap: 4px; }
  .footer .seg:nth-child(4) { display: none; }
  .btn-trading { padding: 4px 8px; font-size: 9px; }
  .btn-estop { padding: 4px 10px; font-size: 10px; }
}
/* ── Rapid-fire mode — ultra-dense layout for power users ──────────── */
.rapid-fire .topbar { height: 40px; padding: 2px 8px; gap: 2px; }
.rapid-fire .brand { min-width: auto; }
.rapid-fire .brand-name { font-size: 12px; letter-spacing: 1px; }
.rapid-fire .brand-sub { display: none; }
.rapid-fire .topbar-strip { gap: 4px; }
.rapid-fire .tb-stat .label { font-size: 7px; letter-spacing: 0.3px; }
.rapid-fire .tb-stat .v { font-size: 10px; }
.rapid-fire .tabs { height: 30px; }
.rapid-fire .tab { padding: 6px 8px; font-size: 9px; letter-spacing: 0.03em; }
.rapid-fire .main { padding: 4px 6px; }
.rapid-fire .dash-stats { grid-template-columns: repeat(6, 1fr); gap: 3px; }
.rapid-fire .stat { padding: 3px 5px; }
.rapid-fire .stat .v { font-size: 10px; }
.rapid-fire .stat .v.lg { font-size: 12px; }
.rapid-fire .stat .sub { display: none; }
.rapid-fire .card { padding: 4px 6px; border-radius: 4px; }
.rapid-fire .card-head { padding-bottom: 3px; margin-bottom: 3px; }
.rapid-fire .card-title { font-size: 8px; }
.rapid-fire .card-actions { font-size: 8px; }
.rapid-fire .footer { height: 22px; font-size: 7px; padding: 0 8px; }
.rapid-fire .footer .seg:nth-child(4) { display: none; }
.rapid-fire .log .line { font-size: 8px; padding: 1px 0; grid-template-columns: 36px 30px 1fr; }
.rapid-fire .position-row { font-size: 9px; padding: 2px 0; }
.rapid-fire .position-row .sym { font-size: 10px; }
.rapid-fire .pnl-pct { font-size: 10px; }
.rapid-fire .btn-trading { padding: 2px 6px; font-size: 8px; }
.rapid-fire .btn-estop { padding: 3px 8px; font-size: 9px; }
/* ── Personality-driven layouts ──────────────────────── */
[data-layout="trader"] .dash-stats { grid-template-columns: repeat(6, 1fr); }
[data-layout="trader"] .stat .sub { display: none; }
[data-layout="trader"] .card-head { padding-bottom: 4px; margin-bottom: 4px; }
[data-layout="trader"] .dash-breaker { display: none; }
[data-layout="trader"] .footer .seg:nth-child(4) { display: none; }
[data-layout="analyst"] .card { min-height: 200px; }
[data-layout="analyst"] .stat .v.lg { font-size: 18px; }
[data-layout="analyst"] .dash-stats { grid-template-columns: repeat(3, 1fr); }
[data-layout="manager"] .dash-stats { grid-template-columns: repeat(4, 1fr); }
[data-layout="manager"] .stat .sub { display: none; }
[data-layout="manager"] .topbar-strip { justify-content: flex-start; }
[data-layout="manager"] .feed-grid { display: none; }
/* ═══════════════════════════════════════════════════════
   PHASE 1 — GLASSMORPHISM + PREMIUM ANIMATIONS
   Deep-space visual system upgrade.
════════════════════════════════════════════════════════ */
/* ── New keyframes ──────────────────────────────────── */
@keyframes fadeSlideIn {
  from { opacity: 0; transform: translateY(6px); }
  to   { opacity: 1; transform: translateY(0); }
}
@keyframes slideInRight {
  from { opacity: 0; transform: translateX(14px); }
  to   { opacity: 1; transform: translateX(0); }
}
@keyframes logIn {
  from { opacity: 0; transform: translateY(-4px); }
  to   { opacity: 1; transform: translateY(0); }
}
@keyframes shimmer {
  0%   { background-position: -200% center; }
  100% { background-position:  200% center; }
}
@keyframes ringPulse {
  0%, 100% { filter: drop-shadow(0 0 4px var(--accent-glow)); }
  50%       { filter: drop-shadow(0 0 18px var(--accent-glow)) drop-shadow(0 0 40px rgba(0,245,255,0.12)); }
}
@keyframes orbitDash {
  from { stroke-dashoffset: 0; }
  to   { stroke-dashoffset: -120; }
}
@keyframes spinSlow {
  from { transform: rotate(0deg); }
  to   { transform: rotate(360deg); }
}
@keyframes countUp {
  from { opacity: 0; transform: translateY(4px); }
  to   { opacity: 1; transform: translateY(0); }
}
/* ── Tab pane entry animation ───────────────────────── */
.tabpane {
  animation: fadeSlideIn 220ms var(--ease-out);
}
/* ── Card gradient top-line (glassmorphism highlight) ─ */
.card {
  position: relative; /* needed for ::before */
}
.card::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 1px;
  background: linear-gradient(90deg,
    transparent 5%,
    rgba(0, 245, 255, 0.25) 50%,
    transparent 95%
  );
  border-radius: var(--r-lg) var(--r-lg) 0 0;
  pointer-events: none;
  z-index: 2;
}
.card.glow::before {
  background: linear-gradient(90deg,
    transparent 0%,
    var(--accent) 40%,
    var(--violet-hi) 60%,
    transparent 100%
  );
  background-size: 200% 100%;
  animation: shimmer 3s ease-in-out infinite;
  opacity: 0.7;
}
/* ── Position close button ─────────────────────────── */
.pos-close-zone { position: absolute; top: 4px; right: 4px; z-index: 5; }
.pos-close-btn {
  width: 20px; height: 20px; border-radius: 4px;
  border: 1px solid var(--border); background: rgba(0,0,0,0.5);
  color: var(--text-faint); font-size: 14px; cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  opacity: 0.4; transition: opacity 0.15s, background 0.15s;
  line-height: 1;
}
.pos-close-btn:hover { opacity: 1; background: rgba(255,51,102,0.15); color: var(--red); }
@media (hover: none) { .pos-close-btn { opacity: 0.7; } }
/* ── Trading action buttons ─────────────────────────── */
.btn-trading {
  display: flex; align-items: center; gap: 6px;
  padding: 5px 14px; border-radius: 6px;
  font-family: var(--font-mono); font-size: 11px;
  font-weight: 700; letter-spacing: 0.08em;
  cursor: pointer; text-transform: uppercase;
  transition: background 0.15s, color 0.2s, border-color 0.2s, opacity 0.2s;
}
.btn-trading:disabled { cursor: wait; opacity: 0.5; }
.btn-start {
  background: rgba(0,255,136,0.08);
  border: 1px solid rgba(0,255,136,0.4);
  color: var(--green);
}
.btn-start:hover:not(:disabled) { background: rgba(0,255,136,0.2); }
.btn-stop {
  background: rgba(239,68,68,0.08);
  border: 1px solid rgba(239,68,68,0.4);
  color: var(--red);
}
.btn-stop:hover:not(:disabled) { background: rgba(239,68,68,0.2); }
.btn-estop {
  padding: 7px 18px; border-radius: 8px;
  background: rgba(239,68,68,0.14);
  border: 1.5px solid rgba(239,68,68,0.7);
  color: var(--red); font-size: 12px; font-weight: 800;
  letter-spacing: 0.1em;
}
.btn-estop:hover:not(:disabled) { background: rgba(239,68,68,0.3); }
.btn-estop.btn-disabled {
  background: rgba(100,100,100,0.08);
  border-color: rgba(100,100,100,0.3);
  color: var(--text-faint); opacity: 0.35;
  cursor: not-allowed;
}
.btn-loading { cursor: wait; opacity: 0.5; }
.btn-trading:active { transform: scale(0.97); }
/* ── Icon buttons (gear, theme, audio, PWA) ─────────── */
.icon-btn {
  background: none; border: none; cursor: pointer;
  color: var(--text-faint); font-size: 16px; padding: 2px;
  opacity: 0.6; transition: opacity 0.15s; line-height: 1;
}
.icon-btn:hover { opacity: 1; }
/* ── Range slider (cross-browser) ────────────────────── */
.range-slider {
  width: 100%; height: 4px;
  appearance: none; -webkit-appearance: none;
  background: var(--border); border-radius: 2px;
  outline: none; cursor: pointer;
}
.range-slider::-webkit-slider-thumb {
  appearance: none; -webkit-appearance: none;
  width: 16px; height: 16px; border-radius: 50%;
  background: var(--accent); border: 2px solid var(--bg);
  box-shadow: 0 0 6px var(--accent-glow); cursor: pointer;
}
.range-slider::-moz-range-thumb {
  width: 16px; height: 16px; border-radius: 50%;
  background: var(--accent); border: 2px solid var(--bg);
  box-shadow: 0 0 6px var(--accent-glow); cursor: pointer;
}
/* ── Metric card — premium glassmorphism stat tile ──── */
.metric-card {
  background:           var(--glass-bg-metric);
  backdrop-filter:      var(--blur-sm) saturate(1.1);
  -webkit-backdrop-filter: var(--blur-sm) saturate(1.1);
  border:               1px solid var(--glass-border);
  border-radius:        var(--r-md);
  padding:              var(--sp-4) var(--sp-5);
  display:              flex;
  flex-direction:       column;
  gap:                  4px;
  position:             relative;
  overflow:             hidden;
  box-shadow:           var(--shadow-glass-metric);
  transition:
    border-color var(--dur-fast),
    box-shadow   var(--dur-base),
    transform    var(--dur-fast);
  cursor: default;
}
/* Coloured 2 px accent stripe at top */
.metric-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 2px;
  background: var(--mc-accent, var(--accent));
  opacity: 0.55;
  border-radius: 2px 2px 0 0;
  z-index: 2;
}
/* Frosted inner highlight — glass edge effect */
.metric-card::after {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 1px;
  background: rgba(255,255,255,0.045);
  pointer-events: none;
  z-index: 3;
}
.metric-card:hover {
  border-color: rgba(0,245,255,0.16);
  box-shadow:
    0 6px 28px rgba(0,0,0,0.50),
    0 0 20px rgba(0,245,255,0.05),
    inset 0 1px 0 rgba(255,255,255,0.07),
    inset 0 -1px 0 rgba(0,0,0,0.22);
  transform: translateY(-1px);
}
.metric-card .mc-label {
  font-family: var(--font-mono);
  font-size: var(--fs-xs);
  font-weight: var(--fw-bold);
  letter-spacing: var(--tracking-caps);
  text-transform: uppercase;
  color: var(--text-faint);
}
.metric-card .mc-value {
  font-family: var(--font-mono);
  font-size: var(--fs-2xl);
  font-weight: var(--fw-black);
  color: var(--text);
  font-variant-numeric: tabular-nums;
  line-height: 1.1;
}
.metric-card .mc-value.lg { font-size: var(--fs-3xl); }
.metric-card .mc-sub {
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--text-dim);
  display: flex;
  align-items: center;
  gap: 4px;
  margin-top: 2px;
}
/* Metric accent colour variants */
.stat-accent-green  { --mc-accent: var(--green); }
.stat-accent-red    { --mc-accent: var(--red); }
.stat-accent-amber  { --mc-accent: var(--amber); }
.stat-accent-cyan   { --mc-accent: var(--cyan); }
.stat-accent-violet { --mc-accent: var(--violet); }
/* ── Enhanced bar shimmer ────────────────────────────── */
.bar .fill {
  position: relative;
  overflow: hidden;
}
.bar .fill::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg,
    transparent 0%,
    rgba(255,255,255,0.18) 50%,
    transparent 100%
  );
  background-size: 200% 100%;
  animation: shimmer 2.2s ease-in-out infinite;
  pointer-events: none;
}
/* ── Reasoning panel ──────────────────────────────────── */
.reason {
  font-family: var(--font-mono);
  font-size: var(--fs-xs);
  line-height: 2.0;
  color: var(--text-dim);
  overflow-y: auto;
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 1px;
  padding-right: 4px;
  max-height: 310px;
}
.reason p {
  display: flex;
  gap: 12px;
  padding: 3px 0;
  border-bottom: 1px solid rgba(0,245,255,0.025);
  animation: fadeSlideIn 320ms var(--ease-out) both;
}
.reason p:last-child {
  border-bottom: none;
  color: var(--text);
}
.reason .ln {
  color: var(--text-faint);
  flex-shrink: 0;
  user-select: none;
  opacity: 0.4;
  font-size: 10px;
  min-width: 20px;
}
/* ── Position card — glass list item ───────────────── */
.pos-card {
  padding:              10px 12px 10px 16px;
  border:               1px solid var(--glass-border);
  border-radius:        var(--r-md);
  background:
    radial-gradient(ellipse at 85% 50%, rgba(var(--pos-accent-rgb,0,245,255),0.025) 0%, transparent 55%),
    linear-gradient(135deg, rgba(4,10,18,0.82) 0%, rgba(6,14,24,0.76) 100%);
  backdrop-filter:      var(--blur-sm);
  -webkit-backdrop-filter: var(--blur-sm);
  display:              grid;
  grid-template-columns: 1fr 2fr 64px 72px;
  gap:                  10px;
  align-items:          center;
  position:             relative;
  overflow:             hidden;
  box-shadow:
    0 3px 16px rgba(0,0,0,0.42),
    inset 0 1px 0 rgba(255,255,255,0.04),
    inset 0 -1px 0 rgba(0,0,0,0.18);
  transition:
    border-color var(--dur-fast),
    box-shadow   var(--dur-fast),
    transform    var(--dur-fast);
  animation: fadeSlideIn 280ms var(--ease-out) both;
}
/* Coloured left accent stripe */
.pos-card::before {
  content: '';
  position: absolute;
  left: 0; top: 0; bottom: 0;
  width: 3px;
  background: var(--pos-accent, var(--cyan));
  box-shadow: 2px 0 8px rgba(0,245,255,0.25);
  border-radius: var(--r-md) 0 0 var(--r-md);
}
/* Frosted top-edge highlight */
.pos-card::after {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 1px;
  background: rgba(255,255,255,0.04);
  pointer-events: none;
}
.pos-card:hover {
  border-color: rgba(0,245,255,0.16);
  box-shadow:
    0 5px 22px rgba(0,0,0,0.48),
    0 0 14px rgba(0,245,255,0.05),
    inset 0 1px 0 rgba(255,255,255,0.06),
    inset 0 -1px 0 rgba(0,0,0,0.20);
  transform: translateX(2px);
}
.pos-card .sym {
  font-family: var(--font-mono);
  font-size: var(--fs-md);
  font-weight: var(--fw-bold);
  color: var(--text);
  letter-spacing: 0.6px;
}
.pos-card .meta {
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--text-faint);
  letter-spacing: 0.4px;
  text-transform: uppercase;
  margin-top: 2px;
}
.pos-live-dot { display: inline-block; width: 6px; height: 6px; border-radius: 50%; margin-right: 4px; }
.pos-live-up { background: var(--green); }
.pos-live-dn { background: var(--red); }
.pos-meter-fill { height: 100%; border-radius: 3px; transition: width 0.3s ease; }
/* ── Signal entry cards — glass panels ──────────────── */
.signal-card {
  padding:              10px 12px 10px 14px;
  border:               1px solid var(--glass-border);
  border-radius:        var(--r-md);
  /* glass bg + subtle radial from left-side accent */
  background:
    radial-gradient(ellipse at 0% 50%, rgba(var(--sig-rgb,0,245,255),0.04) 0%, transparent 50%),
    linear-gradient(135deg, rgba(4,10,18,0.82) 0%, rgba(6,14,24,0.76) 100%);
  backdrop-filter:      var(--blur-sm);
  -webkit-backdrop-filter: var(--blur-sm);
  display:              flex;
  flex-direction:       column;
  gap:                  6px;
  position:             relative;
  overflow:             hidden;
  box-shadow:
    0 3px 16px rgba(0,0,0,0.40),
    inset 0 1px 0 rgba(255,255,255,0.04),
    inset 0 -1px 0 rgba(0,0,0,0.18);
  transition:
    border-color var(--dur-fast),
    box-shadow   var(--dur-fast),
    transform    var(--dur-fast);
  animation: slideInRight 380ms var(--ease-out) both;
}
/* Gradient top-line highlight */
.signal-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 1px;
  background: linear-gradient(90deg,
    var(--sig-accent, var(--accent)) 0%, transparent 80%
  );
  opacity: 0.45;
  pointer-events: none;
}
/* Frosted glass left accent stripe */
.signal-card.sig-buy {
  --sig-accent: var(--green);
  --sig-rgb: 0,255,136;
  border-left: 2px solid rgba(0,255,136,0.40);
  box-shadow:
    0 3px 16px rgba(0,0,0,0.40),
    -1px 0 12px rgba(0,255,136,0.06),
    inset 0 1px 0 rgba(255,255,255,0.04),
    inset 0 -1px 0 rgba(0,0,0,0.18);
}
.signal-card.sig-sell {
  --sig-accent: var(--red);
  --sig-rgb: 255,51,102;
  border-left: 2px solid rgba(255,51,102,0.40);
  box-shadow:
    0 3px 16px rgba(0,0,0,0.40),
    -1px 0 12px rgba(255,51,102,0.06),
    inset 0 1px 0 rgba(255,255,255,0.04),
    inset 0 -1px 0 rgba(0,0,0,0.18);
}
.signal-card.sig-hold {
  --sig-accent: var(--cyan);
  --sig-rgb: 0,245,255;
  border-left: 2px solid rgba(0,245,255,0.28);
}
.signal-card:hover {
  border-color: rgba(0,245,255,0.18);
  box-shadow:
    0 5px 22px rgba(0,0,0,0.46),
    0 0 14px rgba(0,245,255,0.04),
    inset 0 1px 0 rgba(255,255,255,0.06),
    inset 0 -1px 0 rgba(0,0,0,0.20);
  transform: translateX(-2px);
}
/* ── Confidence ring glow ───────────────────────────── */
.ring-fg {
  filter: drop-shadow(0 0 6px var(--accent-glow));
  transition: stroke-dashoffset 700ms var(--ease-out), stroke 500ms;
}
.ring-wrap svg {
  animation: ringPulse 4s ease-in-out infinite;
}
/* ── Orbit dashes (rotating decorative ring) ────────── */
.ring-orbit {
  animation: spinSlow 20s linear infinite;
  transform-origin: 100px 100px;
}
/* ── Holographic card variant ───────────────────────── */
/* Inherits all glass properties from .card; adds a dual-hue radial shimmer */
.card.holographic {
  background:
    radial-gradient(ellipse at 20% 15%, rgba(0,245,255,0.055) 0%, transparent 45%),
    radial-gradient(ellipse at 80% 85%, rgba(139,92,246,0.055) 0%, transparent 45%),
    linear-gradient(135deg, rgba(4,10,18,0.80) 0%, rgba(6,14,24,0.74) 100%);
  border-color: rgba(139,92,246,0.16);
}
/* ── Enhanced topbar gradient border ───────────────── */
.topbar::after {
  content: '';
  position: absolute;
  bottom: 0; left: 0; right: 0;
  height: 1px;
  background: linear-gradient(90deg,
    transparent 0%,
    rgba(0,245,255,0.3) 30%,
    rgba(139,92,246,0.3) 70%,
    transparent 100%
  );
  pointer-events: none;
}
/* ── Breaker gauge ring ─────────────────────────────── */
.breaker-ring-wrap {
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 6px auto 10px;
}
.breaker-ring-bg  { stroke: rgba(255,51,102,0.08); }
.breaker-ring-fg  {
  stroke: var(--breaker-color, var(--green));
  filter: drop-shadow(0 0 4px var(--green-glow));
  transition: stroke-dashoffset 700ms var(--ease-out), stroke 400ms;
}
/* ── Equity chart annotation ────────────────────────── */
.chart-current-dot {
  filter: drop-shadow(0 0 4px var(--accent-glow));
  animation: pulse-scale 2s ease-in-out infinite;
}
/* ── Stats section separator ────────────────────────── */
.stats-divider {
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--border), transparent);
  margin: var(--sp-2) 0;
}
/* ── Tick stream item ────────────────────────────────── */
.tick-row {
  display: grid;
  grid-template-columns: 48px 52px 1fr 56px;
  gap: 8px;
  align-items: center;
  padding: 4px 0;
  border-bottom: 1px solid rgba(0,245,255,0.035);
  font-family: var(--font-mono);
  font-size: var(--fs-xs);
  animation: fadeSlideIn 200ms var(--ease-out) both;
}
.tick-row.up   .px { color: var(--green); }
.tick-row.down .px { color: var(--red); }
/* ── Gradient shimmer button effect ─────────────────── */
.btn-start,
.btn-stop {
  position: relative;
  overflow: hidden;
}
.btn-start::after,
.btn-stop::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.06), transparent);
  background-size: 200% 100%;
  animation: shimmer 3s ease-in-out infinite;
  pointer-events: none;
}
/* ── Compact consensus grid ─────────────────────────── */
.consensus-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 4px;
}
.consensus-cell {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 3px;
  padding: 6px 4px;
  border-radius: var(--r-sm);
  border: 1px solid var(--border);
  background: rgba(5,12,22,0.8);
  transition: border-color var(--dur-fast), background var(--dur-fast);
}
.consensus-cell.active {
  border-color: var(--cell-accent, var(--accent));
  background: rgba(0,245,255,0.05);
  box-shadow: 0 0 12px rgba(0,245,255,0.07);
}
.consensus-cell .c-label {
  font-family: var(--font-mono);
  font-size: 9px;
  font-weight: var(--fw-bold);
  letter-spacing: 0.5px;
  color: var(--text-faint);
  text-transform: uppercase;
}
.consensus-cell .c-action {
  font-family: var(--font-mono);
  font-size: 10px;
  font-weight: var(--fw-bold);
  letter-spacing: 0.5px;
  text-transform: uppercase;
}
.consensus-cell .c-conf {
  font-family: var(--font-mono);
  font-size: 9px;
  color: var(--text-faint);
}
/* ── Gradient text utility ───────────────────────────── */
.text-gradient-cyan {
  background: linear-gradient(135deg, var(--cyan) 0%, var(--violet-hi) 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}
/* ── Log entry highlight ─────────────────────────────── */
.log .line { animation: fadeSlideIn 240ms var(--ease-out) both; }
/* ── Section heading row ─────────────────────────────── */
.section-head {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 0 0 var(--sp-3);
  margin-bottom: var(--sp-3);
  border-bottom: 1px solid var(--border);
  font-family: var(--font-mono);
  font-size: var(--fs-xs);
  font-weight: var(--fw-bold);
  letter-spacing: var(--tracking-caps);
  text-transform: uppercase;
  color: var(--text-faint);
}
.section-head .s-accent {
  color: var(--accent);
  font-size: 9px;
}
/* ── Topbar stat hover lift ──────────────────────────── */
.tb-stat {
  transition: transform var(--dur-fast);
  cursor: default;
}
.tb-stat:hover { transform: translateY(-1px); }
/* ── Live mode indicator ─────────────────────────────── */
@keyframes livePulse {
  0%, 100% { opacity: 1; transform: scale(1); }
  50%       { opacity: 0.5; transform: scale(0.85); }
}
.live-dot {
  display: inline-block;
  width: 7px; height: 7px;
  border-radius: 50%;
  background: var(--green);
  box-shadow: 0 0 8px var(--green-glow);
  animation: livePulse 1.2s ease-in-out infinite;
  flex-shrink: 0;
}
/* ── Scrollbar in .reason panel ─────────────────────── */
.reason::-webkit-scrollbar { width: 3px; }
.reason::-webkit-scrollbar-thumb { background: rgba(0,245,255,0.12); }
/* ── Card inner scroll ─────────────────────────────── */
.card-scroll {
  overflow-y: auto;
  flex: 1;
  min-height: 0;
  padding-right: 2px;
}
.card-scroll::-webkit-scrollbar { width: 3px; }
.card-scroll::-webkit-scrollbar-thumb { background: rgba(0,245,255,0.10); }
/* ═══════════════════════════════════════════════════════
   TOPBAR EQUITY SPARKLINE TICKER
════════════════════════════════════════════════════════ */
/* ── Number flash on tick direction ─────────────────── */
@keyframes eqFlashUp {
  0%   { color: var(--text);  filter: none; }
  18%  { color: var(--green); filter: drop-shadow(0 0 9px var(--green-glow)); }
  100% { color: var(--text);  filter: none; }
}
@keyframes eqFlashDown {
  0%   { color: var(--text); filter: none; }
  18%  { color: var(--red);  filter: drop-shadow(0 0 9px var(--red-glow)); }
  100% { color: var(--text); filter: none; }
}
.eq-flash-up   { animation: eqFlashUp   0.72s ease-out forwards; }
.eq-flash-down { animation: eqFlashDown 0.72s ease-out forwards; }
/* ── Layout: sparkline + value side by side ──────────── */
.tb-eq-value {
  display: flex;
  align-items: center;
  gap: 8px;
}
/* ── WS status dot on sparkline ──────────────────────── */
@keyframes tbDotBlink {
  0%, 100% { opacity: 1; }
  50%       { opacity: 0.25; }
}
.tb-spark-dot {
  width: 4px; height: 4px;
  border-radius: 50%;
  flex-shrink: 0;
  animation: tbDotBlink 1.2s ease-in-out infinite;
}
/* ── Model Accuracy Tracker ──────────────────────────────── */
.acc-tracker {
  margin-bottom: 14px;
  padding: 10px 12px;
  background: rgba(5, 12, 22, 0.7);
  border: 1px solid var(--border);
  border-radius: var(--r-sm);
}
.acc-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 10px;
}
.acc-window-btn {
  background: transparent;
  border: 1px solid var(--border);
  color: var(--text-dim);
  font-family: var(--font-mono);
  font-size: 9px;
  letter-spacing: 1px;
  padding: 2px 6px;
  border-radius: 3px;
  cursor: pointer;
  transition: color 0.15s, border-color 0.15s;
}
.acc-window-btn:hover,
.acc-window-btn.active {
  color: var(--accent);
  border-color: var(--accent);
}
.acc-row {
  display: flex;
  flex-direction: column;
  gap: 3px;
  margin-bottom: 9px;
}
.acc-row:last-child { margin-bottom: 0; }
.acc-row-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.acc-bar-track {
  position: relative;
  height: 4px;
  background: rgba(255,255,255,0.05);
  border-radius: 2px;
  overflow: visible;
}
.acc-bar-overall {
  position: absolute;
  top: 0; left: 0;
  height: 100%;
  border-radius: 2px;
  transition: width 0.5s ease;
  opacity: 0.45;
}
.acc-bar-recent {
  position: absolute;
  top: 0; left: 0;
  height: 100%;
  border-radius: 2px;
  transition: width 0.5s ease;
}
/* Drift LED pulse */
@keyframes driftPulse {
  0%, 100% { box-shadow: 0 0 0 0 var(--red); }
  50%       { box-shadow: 0 0 0 4px rgba(255,60,60,0); }
}
.led-drift {
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--red);
  flex-shrink: 0;
  animation: driftPulse 1.4s ease-in-out infinite;
}
.led-ok {
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--green);
  flex-shrink: 0;
  opacity: 0.7;
}
/* Retrain alert banner */
@keyframes retrainPulse {
  0%, 100% { opacity: 1; }
  50%       { opacity: 0.7; }
}
.acc-retrain-alert {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-top: 8px;
  padding: 6px 10px;
  background: rgba(255, 60, 60, 0.1);
  border: 1px solid rgba(255, 60, 60, 0.35);
  border-radius: var(--r-sm);
  animation: retrainPulse 2s ease-in-out infinite;
}
.acc-retrain-alert-text {
  font-family: var(--font-mono);
  font-size: 9px;
  letter-spacing: 1.2px;
  color: var(--red);
  font-weight: 700;
}
/* Empty state */
.acc-empty {
  text-align: center;
  color: var(--text-faint);
  font-family: var(--font-mono);
  font-size: 10px;
  padding: 12px 0 4px;
  letter-spacing: 0.5px;
}
/* ── P&L Waterfall Tooltip ────────────────────────────── */
.wf-tooltip {
  background: rgba(4, 10, 18, 0.96);
  border: 1px solid var(--border2);
  border-radius: var(--r-sm);
  padding: 7px 10px;
  font-family: var(--font-mono);
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.60), 0 0 12px rgba(0, 245, 255, 0.06);
  min-width: 88px;
}
.wf-tt-sym {
  font-size: var(--fs-sm);
  font-weight: var(--fw-bold);
  color: var(--text);
  letter-spacing: 0.8px;
  text-transform: uppercase;
  margin-bottom: 3px;
}
.wf-tt-pnl {
  font-size: var(--fs-md);
  font-weight: var(--fw-bold);
  font-variant-numeric: tabular-nums;
  margin-bottom: 3px;
}
.wf-tt-date {
  font-size: var(--fs-xs);
  color: var(--text-faint);
  letter-spacing: 0.5px;
}
.wf-tt-strat {
  font-size: 9px;
  color: var(--text-faint);
  letter-spacing: 0.5px;
  text-transform: uppercase;
  margin-top: 2px;
  opacity: 0.7;
}
/* ── Modern glass effect micro-interactions ──────────────────────────────── */
@keyframes glassShimmer {
  0%   { background-position: -200% 0; }
  100% { background-position: 200% 0; }
}
@keyframes floatPulse {
  0%, 100% { transform: translateY(0); }
  50%      { transform: translateY(-2px); }
}
@keyframes glowPulse {
  0%, 100% { box-shadow: 0 0 4px var(--accent-glow, rgba(0,245,255,0.2)); }
  50%      { box-shadow: 0 0 12px var(--accent-glow, rgba(0,245,255,0.5)); }
}
@keyframes slideUpFade {
  from { opacity: 0; transform: translateY(12px); }
  to   { opacity: 1; transform: translateY(0); }
}
@keyframes scaleIn {
  from { opacity: 0; transform: scale(0.96); }
  to   { opacity: 1; transform: scale(1); }
}
@keyframes borderGlow {
  0%, 100% { border-color: rgba(0,245,255,0.12); }
  50%      { border-color: rgba(0,245,255,0.35); }
}
.card:hover {
  border-color: rgba(0,245,255,0.20);
  box-shadow: 0 4px 24px rgba(0,0,0,0.3), 0 0 0 1px rgba(0,245,255,0.06);
  transition: all 0.25s ease;
}
.card {
  transition: border-color 0.25s ease, box-shadow 0.25s ease, transform 0.2s ease;
}
button:hover {
  filter: brightness(1.15);
  transform: translateY(-1px);
}
button {
  transition: filter 0.15s ease, transform 0.12s ease;
}
/* ── Modern scrollbar ────────────────────────────────────────────────────── */
::-webkit-scrollbar { width: 4px; height: 4px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb {
  background: linear-gradient(180deg, rgba(0,245,255,0.2), rgba(139,92,246,0.2));
  border-radius: 3px;
}
::-webkit-scrollbar-thumb:hover {
  background: linear-gradient(180deg, rgba(0,245,255,0.4), rgba(139,92,246,0.4));
}
/* ── Smooth number transitions ───────────────────────────────────────────── */
.num-transition {
  transition: all 0.4s cubic-bezier(0.34, 1.56, 0.64, 1);
  display: inline-block;
}
/* ── Missing variable used by LiveTradingPanel inline styles ────────────── */
/* ── F-03 LiveTradingPanel tick stream ──────────────────────────────────── */
.tick {
  display: flex; align-items: center; gap: 8px;
  padding: 4px 8px; font-size: 11px; font-family: var(--font-mono);
  border-radius: 3px; animation: fadein 300ms ease-out;
  white-space: nowrap; transition: background 0.15s;
}
.tick:hover { background: rgba(0,245,255,0.04); }
.tick .ts  { color: var(--text-faint); width: 36px; flex-shrink: 0; font-size: 10px; }
.tick .sym { color: var(--text); font-weight: 600; width: 40px; font-size: 11px; }
.tick .d   { color: var(--text-dim); width: 50px; text-align: right; font-size: 10px; font-family: var(--font-mono); }
.tick .vol { text-align: right; flex: 1; font-size: 10px; }
.tick.bid { border-left: 2px solid var(--green); }
.tick.ask { border-left: 2px solid var(--red); }
.tick.dir-up .vol { color: var(--green); }
.tick.dir-dn .vol { color: var(--red); }
.tick.up .d { color: var(--green); }
.tick.dn .d { color: var(--red); }
.sym-cell {
  display: flex; align-items: center; gap: 4px;
  padding: 2px 6px; border-radius: 4px; font-size: 10px;
  cursor: pointer; transition: background .15s;
}
.sym-cell:hover { background: rgba(0, 245, 255, 0.06); }
/* ── F-05 OrderFlowHeatmap ──────────────────────────────────────────────── */
.of-root { display: flex; flex-direction: column; height: 100%; gap: 8px; }
.of-top-bar { display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 8px; }
.of-sym-row { display: flex; align-items: center; gap: 8px; }
.of-sym-input-wrap { display: flex; gap: 4px; }
.of-sym-input {
  width: 70px; padding: 4px 8px; border-radius: 4px; border: 1px solid var(--border);
  background: var(--bg-card); color: var(--text); font-family: var(--font-mono); font-size: 11px; text-transform: uppercase;
}
.of-sym-go {
  padding: 4px 10px; border-radius: 4px; background: var(--accent); color: #000;
  font-size: 10px; font-weight: 700; border: none; cursor: pointer;
}
.of-quick-syms { display: flex; gap: 4px; flex-wrap: wrap; }
.of-quick-btn {
  padding: 2px 8px; border-radius: 4px; border: 1px solid var(--border);
  background: transparent; color: var(--text-dim); font-size: 10px; cursor: pointer;
}
.of-quick-btn[data-active="true"] { background: var(--accent); color: #000; border-color: var(--accent); font-weight: 600; }
.of-loading-dot { color: var(--accent); font-size: 9px; animation: pulse-dot 1.4s infinite; }
.of-error-badge { color: var(--red); font-size: 10px; }
.of-panels { display: flex; gap: 8px; flex: 1; min-height: 0; }
.of-ladder-card { flex: 0 0 320px; min-width: 0; }
.of-heatmap-card { flex: 1; min-width: 0; }
/* Stats bar */
.of-stats-bar { display: flex; gap: 16px; flex-wrap: wrap; padding: 4px 0; }
.of-stat { display: flex; align-items: center; gap: 4px; }
.of-label { font-size: 9px; color: var(--text-faint); letter-spacing: .5px; text-transform: uppercase; }
.of-value { font-size: 12px; font-family: var(--font-mono); }
/* Heatmap */
.heatmap-canvas-wrap { flex: 1; min-height: 0; border-radius: 4px; overflow: hidden; }
.heatmap-canvas { width: 100%; height: 100%; display: block; }
.heatmap-legend { display: flex; gap: 12px; align-items: center; }
.hml-item { display: flex; align-items: center; gap: 4px; font-size: 9px; color: var(--text-faint); }
.hml-swatch { width: 20px; height: 6px; border-radius: 2px; }
.of-empty {
  display: flex; align-items: center; justify-content: center; height: 100%;
  color: var(--text-faint); font-size: 12px; letter-spacing: .3px;
}
/* Depth ladder */
.depth-ladder-wrap { display: flex; flex-direction: column; gap: 2px; padding: 4px 0; }
.depth-imbal-row {
  display: flex; justify-content: space-between; align-items: center;
  padding: 4px 8px; margin-bottom: 4px;
}
.depth-imbal-val { font-family: var(--font-mono); font-size: 12px; font-weight: 700; }
.depth-side { display: flex; flex-direction: column; gap: 1px; }
.depth-row {
  display: flex; align-items: center; gap: 6px; padding: 2px 4px;
  position: relative; height: 18px; font-size: 10px;
}
.depth-bar {
  position: absolute; top: 0; left: 0; height: 100%; border-radius: 2px;
  transition: width 300ms ease-out; min-width: 2px;
}
.ask-bar { background: rgba(255, 68, 68, 0.12); right: auto; }
.bid-bar { background: rgba(0, 255, 136, 0.12); right: auto; }
.depth-price { font-family: var(--font-mono); color: var(--text); width: 52px; z-index: 1; }
.depth-size { font-family: var(--font-mono); color: var(--text-dim); font-size: 9px; z-index: 1; }
.depth-side-tag {
  font-size: 7px; letter-spacing: .8px; text-transform: uppercase; font-weight: 700;
  margin-left: auto; opacity: .5; z-index: 1;
}
.ask-side .depth-side-tag { color: var(--red); }
.bid-side .depth-side-tag { color: var(--green); }
.depth-mid-line {
  display: flex; justify-content: center; align-items: center;
  padding: 6px 0; border-top: 1px solid var(--border); border-bottom: 1px solid var(--border);
  margin: 2px 0;
}
.depth-mid-val { font-family: var(--font-mono); font-size: 13px; font-weight: 700; color: var(--accent); }
/* ── F-06 OptionsFlowPanel ──────────────────────────────────────────────── */
.of6-root { display: flex; flex-direction: column; height: 100%; gap: 8px; }
.of6-top { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.of6-title-row { display: flex; align-items: center; gap: 8px; }
.of6-filters { display: flex; gap: 8px; flex-wrap: wrap; align-items: center; }
.of6-filter-group { display: flex; gap: 4px; align-items: center; }
.of6-prem-label { font-size: 9px; color: var(--text-faint); letter-spacing: .3px; }
.of6-feed-card { flex: 1; min-height: 0; display: flex; flex-direction: column; }
.card-title-text { font-size: 13px; font-weight: 600; letter-spacing: .3px; }
/* Options flow rows */
.of-flow-row {
  display: flex; align-items: center; gap: 12px;
  padding: 6px 10px; font-size: 11px; border-radius: 4px;
}
.of-flow-row.bull { background: rgba(0, 255, 136, 0.04); }
.of-flow-row.bear { background: rgba(255, 68, 68, 0.04); }
.of-flow-header { display: flex; gap: 12px; padding: 4px 10px; }
.of-feed-scroll { flex: 1; overflow-y: auto; min-height: 0; }
.of-feed-empty {
  display: flex; align-items: center; justify-content: center; height: 100px;
  color: var(--text-faint); font-size: 12px;
}
.of-prem-bar-wrap { display: flex; align-items: center; gap: 8px; }
.of-prem-bar { height: 6px; border-radius: 3px; display: flex; overflow: hidden; flex: 1; }
.of-prem-bull { background: var(--green); height: 100%; transition: width .3s; }
.of-prem-bear { background: var(--red); height: 100%; transition: width .3s; }
.of-prem-divider { width: 2px; height: 12px; background: var(--border); }
.of-prem-pct { font-family: var(--font-mono); font-size: 11px; min-width: 40px; text-align: right; }
/* Cell layout */
.of-cell { display: flex; flex-direction: column; gap: 1px; }
.of-cell-sym { width: 64px; }
.of-cell-strike { width: 56px; }
.of-cell-prem { width: 56px; align-items: flex-end; }
.of-cell-vol { width: 56px; align-items: flex-end; }
.of-cell-greeks { width: 52px; align-items: flex-end; gap: 0; }
.of-cell-flags { flex: 1; flex-direction: row; gap: 3px; flex-wrap: wrap; }
.of-cell-ts { width: 44px; align-items: flex-end; }
.of-sym { font-family: var(--font-mono); font-weight: 600; color: var(--text); font-size: 11px; }
.of-type { font-size: 8px; letter-spacing: .5px; text-transform: uppercase; font-weight: 700; }
.of-strike { font-family: var(--font-mono); color: var(--text); font-size: 11px; }
.of-exp { font-size: 9px; }
.of-prem { font-family: var(--font-mono); font-size: 11px; }
.of-prem.neg { color: var(--red); }
.of-flag {
  display: inline-flex; align-items: center; gap: 2px;
  font-size: 8px; padding: 1px 4px; border-radius: 3px; border: 1px solid;
  font-weight: 600; white-space: nowrap;
}
.of-src-badge {
  font-size: 9px; padding: 2px 6px; border-radius: 4px;
  background: rgba(0, 245, 255, 0.1); color: var(--accent);
}
.confirm-overlay {
  position: fixed; inset: 0; z-index: 9999;
  background: rgba(0,0,0,0.6); backdrop-filter: blur(4px);
  display: flex; align-items: center; justify-content: center;
}
/* ── Tablet: 480-900px ─────────────────────────────── */
@media (max-width: 900px) {
  .feed-grid { grid-template-columns: 1fr; }
  .ai-grid { grid-template-columns: 1fr; }
  .of-root { gap: 4px; }
  .of-sym-row { flex-wrap: wrap; }
  .of-panels { flex-direction: column; }
  .of6-filters { flex-wrap: wrap; }
  .of6-filter-group { flex-wrap: wrap; }
  .depth-ladder-wrap { max-height: 200px; }
  .heatmap-canvas-wrap { overflow-x: auto; }
  .sym-grid { grid-template-columns: repeat(5, 1fr); font-size: 9px; }
  .tick-stream { max-height: 200px; }
}
/* ── Mobile: max 480px ─────────────────────────────── */
@media (max-width: 480px) {
  /* Topbar */
  .topbar { padding: 3px 6px; gap: 3px; }
  .brand-name { font-size: 12px; letter-spacing: 1px; }
  .brand-sub { display: none; }
  .topbar-strip { gap: 4px; flex-wrap: wrap; }
  .tb-stat { min-width: auto; }
  .tb-stat .label { font-size: 6px; }
  .tb-stat .v { font-size: 9px; }
  .topbar-right { gap: 4px; }
  .market-pill span { display: none; }
  .clock .label { display: none; }
  .clock { font-size: 8px; }

  /* Tabs */
  .tabs { padding: 0 2px; gap: 0; overflow-x: auto; -webkit-overflow-scrolling: touch; }
  .tab { padding: 6px 6px; font-size: 8px; white-space: nowrap; }
  .tab .num { display: none; }

  /* Cards */
  .card { padding: 6px; border-radius: var(--r-md); }
  .card-head { padding-bottom: 4px; margin-bottom: 4px; font-size: 9px; }
  .card-title { font-size: 9px; }

  /* Dashboard */
  .dash-stats { grid-template-columns: 1fr 1fr; gap: 3px; }
  .dash-grid { gap: 3px; }
  .stat { padding: 4px; }
  .stat .v { font-size: 10px; }
  .stat .v.lg { font-size: 12px; }
  .metric-card { padding: 6px; }
  .metric-card .mc-value { font-size: 14px; }

  /* Positions */
  .pos-card { padding: 6px; gap: 4px; }
  .pos-card .sym { font-size: 11px; }
  .pos-card .meta { font-size: 8px; }

  /* AI Command Center */
  .signal-card { padding: 6px; font-size: 9px; }
  .risk-row { flex-wrap: wrap; font-size: 9px; }

  /* Live Feed */
  .feed-grid { gap: 4px; }
  .sym-grid { grid-template-columns: repeat(3, 1fr); font-size: 8px; }
  .sym-cell { padding: 3px; }
  .tick-stream { max-height: 150px; font-size: 8px; }

  /* Order Flow */
  .of-quick-btn { font-size: 8px; padding: 2px 6px; }
  .of-sym-input { width: 50px; font-size: 9px; }
  .depth-ladder-wrap { max-height: 150px; }
  .depth-row { font-size: 8px; padding: 1px 0; }

  /* Options Flow */
  .of6-root { gap: 4px; }
  .of6-filters { flex-direction: column; gap: 4px; }
  .of6-filter-group { gap: 2px; }
  .of-flow-row { font-size: 8px; grid-template-columns: 0.8fr 0.4fr 0.4fr 0.5fr 0.4fr 0.5fr 0.5fr 0.6fr; }
  .of-flow-header { font-size: 7px; }

  /* Strategy / Rebalance tables */
  .tabpane [style*="grid-template-columns"] {
    grid-template-columns: 1fr 0.5fr 0.5fr !important;
    font-size: 8px;
  }
  .tabpane [style*="grid-template-columns"] > *:nth-child(n+4) { display: none; }

  /* Footer */
  .footer { padding: 0 6px; font-size: 7px; gap: 2px; height: 20px; }
  .footer .seg:nth-child(3),
  .footer .seg:nth-child(4) { display: none; }

  /* Buttons */
  .btn-trading { padding: 3px 6px; font-size: 8px; }
  .btn-estop { padding: 3px 8px; font-size: 9px; }

  /* Main content */
  .main { padding: var(--sp-2); }
  .tabpane { padding: var(--sp-2); }
}
/* ── Touch devices: larger hit targets ──────────────── */
@media (hover: none) and (pointer: coarse) {
  .tab, button, .of-quick-btn, .pos-card, .signal-card { min-height: 36px; }
  .pos-close-btn { opacity: 0.7; width: 28px; height: 28px; }
  input, select { font-size: 16px !important; }  /* prevent iOS zoom */
}
