/*! tailwindcss v4.2.2 | MIT License | https://tailwindcss.com */
@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-border-style:solid;--tw-outline-style:solid;--tw-blur:initial;--tw-brightness:initial;--tw-contrast:initial;--tw-grayscale:initial;--tw-hue-rotate:initial;--tw-invert:initial;--tw-opacity:initial;--tw-saturate:initial;--tw-sepia:initial;--tw-drop-shadow:initial;--tw-drop-shadow-color:initial;--tw-drop-shadow-alpha:100%;--tw-drop-shadow-size:initial;--tw-backdrop-blur:initial;--tw-backdrop-brightness:initial;--tw-backdrop-contrast:initial;--tw-backdrop-grayscale:initial;--tw-backdrop-hue-rotate:initial;--tw-backdrop-invert:initial;--tw-backdrop-opacity:initial;--tw-backdrop-saturate:initial;--tw-backdrop-sepia:initial;--tw-ease:initial;--tw-font-weight:initial;--tw-duration:initial;--tw-shadow:0 0 #0000;--tw-shadow-color:initial;--tw-shadow-alpha:100%;--tw-inset-shadow:0 0 #0000;--tw-inset-shadow-color:initial;--tw-inset-shadow-alpha:100%;--tw-ring-color:initial;--tw-ring-shadow:0 0 #0000;--tw-inset-ring-color:initial;--tw-inset-ring-shadow:0 0 #0000;--tw-ring-inset:initial;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-offset-shadow:0 0 #0000;--tw-tracking:initial;--tw-leading:initial}}}@layer theme{:root,:host{--font-sans:"Inter", "Inter Fallback", ui-sans-serif, system-ui, sans-serif;--font-mono:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace;--color-red-400:oklch(70.4% .191 22.216);--color-red-900:oklch(39.6% .141 25.723);--color-white:#fff;--spacing:.25rem;--text-xs:.75rem;--text-xs--line-height:calc(1 / .75);--text-sm:.875rem;--text-sm--line-height:calc(1.25 / .875);--text-lg:1.125rem;--text-lg--line-height:calc(1.75 / 1.125);--text-4xl:2.25rem;--text-4xl--line-height:calc(2.5 / 2.25);--font-weight-medium:500;--font-weight-semibold:600;--font-weight-bold:700;--tracking-wide:.025em;--leading-tight:1.25;--radius-sm:calc(var(--radius) - 2px);--radius-lg:calc(var(--radius) + 4px);--ease-in-out:cubic-bezier(.4, 0, .2, 1);--blur-lg:16px;--default-transition-duration:.15s;--default-transition-timing-function:cubic-bezier(.4, 0, .2, 1);--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono);--radius:.5rem;--color-primary-400:#00ceae;--color-primary-700:#006b59;--font-display:"Raleway", "Raleway Fallback", ui-sans-serif, system-ui, sans-serif}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab, red, red)){::placeholder{color:color-mix(in oklab, currentcolor 50%, transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::file-selector-button{appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.visible{visibility:visible}.absolute{position:absolute}.fixed{position:fixed}.relative{position:relative}.static{position:static}.start{inset-inline-start:var(--spacing)}.end{inset-inline-end:var(--spacing)}.end\!{inset-inline-end:var(--spacing)!important}.container{width:100%}@media (min-width:40rem){.container{max-width:40rem}}@media (min-width:48rem){.container{max-width:48rem}}@media (min-width:64rem){.container{max-width:64rem}}@media (min-width:80rem){.container{max-width:80rem}}@media (min-width:96rem){.container{max-width:96rem}}.block{display:block}.contents{display:contents}.flex{display:flex}.grid{display:grid}.hidden{display:none}.inline{display:inline}.table{display:table}.flex-shrink{flex-shrink:1}.border-collapse{border-collapse:collapse}.transform{transform:var(--tw-rotate-x,) var(--tw-rotate-y,) var(--tw-rotate-z,) var(--tw-skew-x,) var(--tw-skew-y,)}.resize{resize:both}.flex-wrap{flex-wrap:wrap}.border{border-style:var(--tw-border-style);border-width:1px}.outline{outline-style:var(--tw-outline-style);outline-width:1px}.blur{--tw-blur:blur(8px);filter:var(--tw-blur,) var(--tw-brightness,) var(--tw-contrast,) var(--tw-grayscale,) var(--tw-hue-rotate,) var(--tw-invert,) var(--tw-saturate,) var(--tw-sepia,) var(--tw-drop-shadow,)}.filter{filter:var(--tw-blur,) var(--tw-brightness,) var(--tw-contrast,) var(--tw-grayscale,) var(--tw-hue-rotate,) var(--tw-invert,) var(--tw-saturate,) var(--tw-sepia,) var(--tw-drop-shadow,)}.backdrop-filter{-webkit-backdrop-filter:var(--tw-backdrop-blur,) var(--tw-backdrop-brightness,) var(--tw-backdrop-contrast,) var(--tw-backdrop-grayscale,) var(--tw-backdrop-hue-rotate,) var(--tw-backdrop-invert,) var(--tw-backdrop-opacity,) var(--tw-backdrop-saturate,) var(--tw-backdrop-sepia,);backdrop-filter:var(--tw-backdrop-blur,) var(--tw-backdrop-brightness,) var(--tw-backdrop-contrast,) var(--tw-backdrop-grayscale,) var(--tw-backdrop-hue-rotate,) var(--tw-backdrop-invert,) var(--tw-backdrop-opacity,) var(--tw-backdrop-saturate,) var(--tw-backdrop-sepia,)}.transition{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to,opacity,box-shadow,transform,translate,scale,rotate,filter,-webkit-backdrop-filter,backdrop-filter,display,content-visibility,overlay,pointer-events;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.ease-in-out{--tw-ease:var(--ease-in-out);transition-timing-function:var(--ease-in-out)}}

/* ══════════════════════════════════════════════════════════════
   TAILWIND CSS v4 CONFIGURATION
   ══════════════════════════════════════════════════════════════ */

@theme {
  --color-primary-50: #e4fff8;
  --color-primary-100: #c2ffef;
  --color-primary-200: #00ffd7;
  --color-primary-300: #00e5c1;
  --color-primary-400: #00ceae;
  --color-primary-500: #00b296;
  --color-primary-600: #008872;
  --color-primary-700: #006b59;
  --color-primary-800: #00473a;
  --color-primary-900: #001e17;
  --color-primary-950: #000c09;
  --color-primary-foreground: #fafafa;
  --color-red-50: lab(96.5005% 4.18508 1.52328);
  --color-red-100: lab(92.243% 10.2865 3.83865);
  --color-red-200: lab(86.017% 19.8815 7.75869);
  --color-red-300: lab(76.5514% 36.422 15.5335);
  --color-red-400: lab(63.7053% 60.745 31.3109);
  --color-red-500: lab(55.4814% 75.0732 48.8528);
  --color-red-600: lab(48.4493% 77.4328 61.5452);
  --color-red-800: lab(33.7174% 55.8993 41.0293);
  --color-red-900: lab(28.5139% 44.5539 29.0463);
  --color-orange-200: lab(88.4871% 9.94918 28.8378);
  --color-orange-300: lab(80.8059% 21.7313 50.4455);
  --color-orange-400: lab(70.0429% 42.5156 75.8207);
  --color-orange-500: lab(64.272% 57.1788 90.3583);
  --color-orange-600: lab(57.1026% 64.2584 89.8886);
  --color-orange-900: lab(30.2951% 36.0434 37.671);
  --color-amber-50: lab(98.6252% -.635922 8.42309);
  --color-amber-100: lab(95.916% -1.21653 23.111);
  --color-amber-200: lab(91.7203% -.505269 49.9084);
  --color-amber-300: lab(86.4156% 6.13147 78.3961);
  --color-amber-400: lab(80.1641% 16.6016 99.2089);
  --color-amber-500: lab(72.7183% 31.8672 97.9407);
  --color-amber-600: lab(60.3514% 40.5624 87.1228);
  --color-amber-700: lab(47.2709% 42.9082 69.2966);
  --color-amber-900: lab(31.2288% 30.2627 40.0378);
  --color-amber-950: lab(15.8111% 20.9107 23.3752);
  --color-yellow-100: lab(97.3564% -4.51407 27.344);
  --color-yellow-300: lab(89.7033% -.480294 84.4917);
  --color-yellow-400: lab(83.2664% 8.65132 106.895);
  --color-yellow-500: lab(76.3898% 14.5258 98.4589);
  --color-yellow-600: lab(62.7799% 22.4197 86.1544);
  --color-yellow-900: lab(32.3865% 21.1273 38.5959);
  --color-lime-300: lab(89.9218% -35.6546 68.5254);
  --color-lime-400: lab(83.7876% -45.0447 88.4738);
  --color-lime-500: lab(75.3197% -46.6547 86.1778);
  --color-lime-600: lab(61.1055% -41.0235 73.1483);
  --color-green-100: lab(96.1861% -13.8464 6.52365);
  --color-green-200: lab(92.4222% -26.4702 12.9427);
  --color-green-300: lab(86.9953% -47.2691 25.0054);
  --color-green-400: lab(78.503% -64.9265 39.7492);
  --color-green-500: lab(70.5521% -66.5147 45.8073);
  --color-green-600: lab(59.0978% -58.6621 41.2579);
  --color-green-900: lab(30.797% -29.6927 17.382);
  --color-emerald-50: lab(97.8462% -6.94966 1.85487);
  --color-emerald-100: lab(94.9004% -17.0769 5.63836);
  --color-emerald-200: lab(90.2247% -31.039 9.47084);
  --color-emerald-300: lab(83.9203% -48.7124 13.8849);
  --color-emerald-400: lab(75.0771% -60.7313 19.4147);
  --color-emerald-500: lab(66.9756% -58.27 19.5419);
  --color-emerald-600: lab(55.0481% -49.9246 15.93);
  --color-emerald-800: lab(35.3675% -33.1188 8.04002);
  --color-emerald-900: lab(28.8637% -26.9249 5.45986);
  --color-emerald-950: lab(15.0582% -17.9507 2.38369);
  --color-teal-500: lab(67.3859% -49.0983 -2.63511);
  --color-teal-600: lab(55.0223% -41.0774 -3.90277);
  --color-cyan-50: lab(98.3304% -5.97432 -2.62108);
  --color-cyan-100: lab(95.3146% -13.8285 -6.84732);
  --color-cyan-300: lab(85.3886% -36.7636 -21.5716);
  --color-cyan-400: lab(76.6045% -40.9406 -29.6231);
  --color-cyan-500: lab(67.805% -35.3952 -30.2018);
  --color-cyan-600: lab(55.1767% -26.7496 -30.5139);
  --color-cyan-900: lab(30.372% -13.1853 -18.7887);
  --color-cyan-950: lab(19.1528% -9.68757 -15.5267);
  --color-sky-300: lab(80.3307% -20.2945 -31.385);
  --color-sky-400: lab(70.687% -23.6078 -45.9483);
  --color-sky-500: lab(63.3038% -18.433 -51.0407);
  --color-sky-600: lab(51.7754% -11.4712 -49.8349);
  --color-sky-700: lab(41.6013% -9.10804 -42.5647);
  --color-blue-200: lab(86.15% -4.04379 -21.0797);
  --color-blue-300: lab(77.5052% -6.4629 -36.42);
  --color-blue-400: lab(65.0361% -1.42065 -56.9802);
  --color-blue-500: lab(54.1736% 13.3369 -74.6839);
  --color-blue-600: lab(44.0605% 29.0279 -86.0352);
  --color-blue-900: lab(26.1542% 15.7545 -51.5504);
  --color-indigo-400: lab(59.866% 22.4834 -64.4485);
  --color-indigo-600: lab(38.4009% 52.6132 -92.3857);
  --color-violet-300: lab(76.7419% 18.3911 -37.0706);
  --color-violet-500: lab(49.9355% 55.1776 -81.8963);
  --color-violet-600: lab(41.088% 68.9966 -91.995);
  --color-violet-700: lab(35.2783% 67.9912 -88.793);
  --color-purple-400: lab(63.6946% 47.6127 -59.2066);
  --color-purple-500: lab(52.0183% 66.11 -78.2316);
  --color-fuchsia-400: lab(66.1178% 66.0652 -52.4733);
  --color-fuchsia-600: lab(47.5131% 83.4271 -63.0363);
  --color-rose-400: lab(64.4125% 63.0291 19.2068);
  --color-rose-600: lab(49.1882% 81.577 36.0311);
  --color-slate-100: lab(96.286% -.852436 -2.46847);
  --color-slate-200: lab(91.7353% -.998765 -4.76968);
  --color-slate-300: lab(84.7652% -1.94535 -7.93337);
  --color-slate-400: lab(65.5349% -2.25151 -14.5072);
  --color-slate-500: lab(48.0876% -2.03595 -16.5814);
  --color-slate-600: lab(35.5623% -1.74978 -15.4316);
  --color-slate-800: lab(16.132% -.318035 -14.6672);
  --color-slate-900: lab(7.78673% 1.82345 -15.0537);
  --color-gray-100: lab(96.1596% -.0823438 -1.13575);
  --color-gray-300: lab(85.1236% -.612259 -3.7138);
  --color-gray-400: lab(65.9269% -.832707 -8.17473);
  --color-gray-500: lab(47.7841% -.393182 -10.0268);
  --color-gray-900: lab(8.11897% .811279 -12.254);
  --color-neutral-50: lab(98.26% 0 0);
  --color-neutral-100: lab(96.52% -.0000298023 .0000119209);
  --color-neutral-200: lab(90.952% 0 -.0000119209);
  --color-neutral-300: lab(84.92% 0 -.0000119209);
  --color-neutral-400: lab(66.128% -.0000298023 .0000119209);
  --color-neutral-500: lab(48.496% 0 0);
  --color-neutral-600: lab(34.924% 0 0);
  --color-neutral-700: lab(27.036% 0 0);
  --color-neutral-800: lab(15.204% 0 -.00000596046);
  --color-neutral-900: lab(7.78201% -.0000149012 0);
  --color-neutral-950: lab(2.75381% 0 0);

  --font-sans: 'Inter', 'Inter Fallback', ui-sans-serif, system-ui, sans-serif;
  --font-display: 'Raleway', 'Raleway Fallback', ui-sans-serif, system-ui, sans-serif;
  --font-mono: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace;

  --radius: 0.5rem;
  --radius-sm: calc(var(--radius) - 2px);
  --radius-lg: calc(var(--radius) + 4px);
}

/* ══════════════════════════════════════════════════════════════
   CSS CUSTOM PROPERTIES
   ══════════════════════════════════════════════════════════════ */

:root {
  --primary-50: #e4fff8;
  --primary-100: #c2ffef;
  --primary-200: #00ffd7;
  --primary-300: #00e5c1;
  --primary-400: #00ceae;
  --primary-500: #00b296;
  --primary-600: #008872;
  --primary-700: #006b59;
  --primary-800: #00473a;
  --primary-900: #001e17;
  --primary-950: #000c09;
  --primary-foreground: #fafafa;
  --red-50: lab(96.5005% 4.18508 1.52328);
  --red-100: lab(92.243% 10.2865 3.83865);
  --red-200: lab(86.017% 19.8815 7.75869);
  --red-300: lab(76.5514% 36.422 15.5335);
  --red-400: lab(63.7053% 60.745 31.3109);
  --red-500: lab(55.4814% 75.0732 48.8528);
  --red-600: lab(48.4493% 77.4328 61.5452);
  --red-800: lab(33.7174% 55.8993 41.0293);
  --red-900: lab(28.5139% 44.5539 29.0463);
  --orange-200: lab(88.4871% 9.94918 28.8378);
  --orange-300: lab(80.8059% 21.7313 50.4455);
  --orange-400: lab(70.0429% 42.5156 75.8207);
  --orange-500: lab(64.272% 57.1788 90.3583);
  --orange-600: lab(57.1026% 64.2584 89.8886);
  --orange-900: lab(30.2951% 36.0434 37.671);
  --amber-50: lab(98.6252% -.635922 8.42309);
  --amber-100: lab(95.916% -1.21653 23.111);
  --amber-200: lab(91.7203% -.505269 49.9084);
  --amber-300: lab(86.4156% 6.13147 78.3961);
  --amber-400: lab(80.1641% 16.6016 99.2089);
  --amber-500: lab(72.7183% 31.8672 97.9407);
  --amber-600: lab(60.3514% 40.5624 87.1228);
  --amber-700: lab(47.2709% 42.9082 69.2966);
  --amber-900: lab(31.2288% 30.2627 40.0378);
  --amber-950: lab(15.8111% 20.9107 23.3752);
  --yellow-100: lab(97.3564% -4.51407 27.344);
  --yellow-300: lab(89.7033% -.480294 84.4917);
  --yellow-400: lab(83.2664% 8.65132 106.895);
  --yellow-500: lab(76.3898% 14.5258 98.4589);
  --yellow-600: lab(62.7799% 22.4197 86.1544);
  --yellow-900: lab(32.3865% 21.1273 38.5959);
  --lime-300: lab(89.9218% -35.6546 68.5254);
  --lime-400: lab(83.7876% -45.0447 88.4738);
  --lime-500: lab(75.3197% -46.6547 86.1778);
  --lime-600: lab(61.1055% -41.0235 73.1483);
  --green-100: lab(96.1861% -13.8464 6.52365);
  --green-200: lab(92.4222% -26.4702 12.9427);
  --green-300: lab(86.9953% -47.2691 25.0054);
  --green-400: lab(78.503% -64.9265 39.7492);
  --green-500: lab(70.5521% -66.5147 45.8073);
  --green-600: lab(59.0978% -58.6621 41.2579); 
  --green-900: lab(30.797% -29.6927 17.382);
  --emerald-50: lab(97.8462% -6.94966 1.85487);
  --emerald-100: lab(94.9004% -17.0769 5.63836);
  --emerald-200: lab(90.2247% -31.039 9.47084);
  --emerald-300: lab(83.9203% -48.7124 13.8849);
  --emerald-400: lab(75.0771% -60.7313 19.4147);
  --emerald-500: lab(66.9756% -58.27 19.5419);
  --emerald-600: lab(55.0481% -49.9246 15.93);
  --emerald-800: lab(35.3675% -33.1188 8.04002);
   --emerald-900: lab(28.8637% -26.9249 5.45986);
   --emerald-950: lab(15.0582% -17.9507 2.38369);
   --teal-500: lab(67.3859% -49.0983 -2.63511);
   --teal-600: lab(55.0223% -41.0774 -3.90277);
   --cyan-50: lab(98.3304% -5.97432 -2.62108);
   --cyan-100: lab(95.3146% -13.8285 -6.84732);
   --cyan-300: lab(85.3886% -36.7636 -21.5716);
   --cyan-400: lab(76.6045% -40.9406 -29.6231);
   --cyan-500: lab(67.805% -35.3952 -30.2018);
   --cyan-600: lab(55.1767% -26.7496 -30.5139);
   --cyan-900: lab(30.372% -13.1853 -18.7887);
   --cyan-950: lab(19.1528% -9.68757 -15.5267);
   --sky-300: lab(80.3307% -20.2945 -31.385);
   --sky-400: lab(70.687% -23.6078 -45.9483);
   --sky-500: lab(63.3038% -18.433 -51.0407);
   --sky-600: lab(51.7754% -11.4712 -49.8349);
   --sky-700: lab(41.6013% -9.10804 -42.5647);
   --blue-200: lab(86.15% -4.04379 -21.0797);
   --blue-300: lab(77.5052% -6.4629 -36.42);
   --blue-400: lab(65.0361% -1.42065 -56.9802);
   --blue-500: lab(54.1736% 13.3369 -74.6839);
   --blue-600: lab(44.0605% 29.0279 -86.0352);
   --blue-900: lab(26.1542% 15.7545 -51.5504);
   --indigo-400: lab(59.866% 22.4834 -64.4485);
   --indigo-600: lab(38.4009% 52.6132 -92.3857);
   --violet-300: lab(76.7419% 18.3911 -37.0706);
   --violet-500: lab(49.9355% 55.1776 -81.8963);
   --violet-600: lab(41.088% 68.9966 -91.995);
   --violet-700: lab(35.2783% 67.9912 -88.793);
   --purple-400: lab(63.6946% 47.6127 -59.2066);
   --purple-500: lab(52.0183% 66.11 -78.2316);
   --fuchsia-400: lab(66.1178% 66.0652 -52.4733);
   --fuchsia-600: lab(47.5131% 83.4271 -63.0363);
   --rose-400: lab(64.4125% 63.0291 19.2068);
   --rose-600: lab(49.1882% 81.577 36.0311);
   --slate-100: lab(96.286% -.852436 -2.46847);
   --slate-200: lab(91.7353% -.998765 -4.76968);
   --slate-300: lab(84.7652% -1.94535 -7.93337);
   --slate-400: lab(65.5349% -2.25151 -14.5072);
   --slate-500: lab(48.0876% -2.03595 -16.5814);
   --slate-600: lab(35.5623% -1.74978 -15.4316);
   --slate-800: lab(16.132% -.318035 -14.6672);
   --slate-900: lab(7.78673% 1.82345 -15.0537);
   --gray-100: lab(96.1596% -.0823438 -1.13575);
   --gray-300: lab(85.1236% -.612259 -3.7138);
   --gray-400: lab(65.9269% -.832707 -8.17473);
   --gray-500: lab(47.7841% -.393182 -10.0268);
   --gray-900: lab(8.11897% .811279 -12.254);
   --neutral-50: lab(98.26% 0 0);
   --neutral-100: lab(96.52% -.0000298023 .0000119209);
   --neutral-200: lab(90.952% 0 -.0000119209);
   --neutral-300: lab(84.92% 0 -.0000119209);
   --neutral-400: lab(66.128% -.0000298023 .0000119209);
   --neutral-500: lab(48.496% 0 0);
   --neutral-600: lab(34.924% 0 0);
   --neutral-700: lab(27.036% 0 0);
   --neutral-800: lab(15.204% 0 -.00000596046);
   --neutral-900: lab(7.78201% -.0000149012 0);
   --neutral-950: lab(2.75381% 0 0);
   
  --font-inter: 'Inter';
  --font-raleway: 'Raleway';

  --background: lab(.908428% -.133611 .0092864);
  --glow-color: 0, 90, 70;

  --background-radial: radial-gradient(
    ellipse 100% 100% at 50% 50%,
    rgba(var(--glow-color), 0.25) 0%,
    rgba(var(--glow-color), 0.18) 20%,
    rgba(var(--glow-color), 0.06) 55%,
    transparent 50%
  );
  --foreground: #0a0a0a;
  --card: #f9fafa8c;
  --card-foreground: #0a0a0a;
  --border: oklch(from var(--primary-50) l c h / 0.1);
  --border-hover: oklch(from var(--primary-50) l c h / 0.2);
  --muted: #f1f5f9;
  --muted-foreground: lab(66.128% -.0000298023 .0000119209);
  --accent: var(--primary-600);
  --accent-foreground: #ffffff;
  --accent2: #f05a7e;
  --title: #00a58a;
  --input: #cbd5e1;
  --ring: var(--primary-600);
  --sidebar: #fafafa;
  --sidebar-foreground: #0a0a0a;
  --sidebar-border: #e2e8f0;
  --sidebar-accent: var(--primary-500);
  --popover: #f9fafa;
  --popover-foreground: #0a0a0a;
  --secondary: #252626;
  --secondary-foreground: #0a0a0a;

  --bg:      var(--background);
  --surface: var(--sidebar);
  --surface2: var(--secondary);
  --text:    var(--foreground);
  --border2: var(--sidebar-border);
  --blue:    #5a9ef0;
  --orange:  #f0a028;
  --found:   #e8e8f0;
  --potential: #888898;
  --bar:     #e5e5e5;
  --fg:      var(--foreground);
  --radius-sm: calc(var(--radius) - 4px);
  --card-bg: rgba(90, 158, 240, 0.04);
  --nav-bg: rgba(13, 13, 13, 0.55);
  --panel-bg: rgba(13, 13, 13, 0.55);
  --macro-bg: linear-gradient(180deg, rgba(90, 158, 240, 0.08) 0%, rgba(80, 90, 105, 0.06) 55%, rgba(13, 13, 13, 0.55) 100%);
  --macro-bg-red: rgba(80, 20, 20, 0.25);
  --macro-bg-green: rgba(20, 60, 30, 0.25);
  --macro-bg-grey: rgba(120, 120, 120, 0.15);
  --macro-bg-blue: rgba(16, 95, 140, 0.15);
  --macro-bg-orange: rgba(115, 62, 10, 0.15);
  --blur-xs: 4px;
  --blur-sm: 8px;
  --blur-lg: 16px;
}

/* ── DARK MODE (DEFAULT) ── */
.dark {
  --background: lab(.908428% -.133611 .0092864);
  --glow-color: 0, 90, 70;
  --background-radial: radial-gradient(82% 82% at 50% 38%,#00221b 0%,#000c0942 48%,transparent 78%),
     radial-gradient(130% 130% at 50% 58%,#030605 0%,transparent 64%),
     linear-gradient(190deg,#020a07 0%,var(--background)82%);
  --card-bg: rgba(90, 158, 240, 0.04);
  --nav-bg: rgba(13, 13, 13, 0.55);
  --panel-bg: rgba(13, 13, 13, 0.55);
  --calendar-bg: rgba(13, 13, 13, 1);
  --macro-bg: linear-gradient(180deg, rgba(90, 158, 240, 0.08) 0%, rgba(80, 90, 105, 0.06) 55%, rgba(13, 13, 13, 0.55) 100%);
  --macro-bg-red: rgba(80, 20, 20, 0.25);
  --macro-bg-green: rgba(20, 60, 30, 0.25);
  --macro-bg-grey: rgba(120, 120, 120, 0.15);
  --macro-bg-blue: rgba(16, 95, 140, 0.15);
  --macro-bg-orange: rgba(115, 62, 10, 0.15);
  --foreground: #e2e8f0;
  --secondary: #252626;
  --secondary-2: #313232;
  --secondary-foreground: #e2e8f0;
  --card: #0d0d0d;
  --card-solid: #0d0d0d;
  --card-foreground: #e2e8f0;
  --border: oklch(from var(--primary-50) l c h / 0.1);
  --border-hover: oklch(from var(--primary-50) l c h / 0.2);
  --muted: #252626;
  --muted-foreground: lab(66.128% -.0000298023 .0000119209);
  --accent: #00b296;
  --accent-foreground: #e2e8f0;
  --accent2: #f05a7e;
  --title: #00a58a;
  --input: #3f403f;
  --ring: var(--primary-700);
  --sidebar: #111211;
  --sidebar-foreground: #e2e8f0;
  --sidebar-border: rgba(255,255,255,0.05);
  --sidebar-accent: #00b296;
  --popover: #0d0d0d;
  --popover-foreground: #e2e8f0;

  --bg:      var(--background);
  --surface: var(--sidebar);
  --surface2: var(--secondary);
  --text:    var(--foreground);
  --border2: #2a2a38;
  --blue:    #5a9ef0;
  --orange:  #f0a028;
  --found:   #e8e8f0;
  --potential: #888898;
  --bar:     #e5e5e5;
  --fg:      var(--foreground);
  --blur-xs: 4px;
  --blur-sm: 8px;
  --blur-lg: 16px;
  --animation-color: var(--slate-400);
}

/* ══════════════════════════════════════════════════════════════
   BASE RESET & BODY
   ══════════════════════════════════════════════════════════════ */

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

html {
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

body {
  background-color: #030303;
  color: var(--foreground);
  font-family: var(--font-sans);
  min-height: 100vh;
  letter-spacing: -0.01em;
  overflow-x: hidden;
  display: flex;
  flex-direction: column;
}

/* ══════════════════════════════════════════════════════════════
   PAGE GLOW - Fixed position ambient background
   ══════════════════════════════════════════════════════════════ */

#page-glow {
  position: fixed;
  top: 0;
  left: 120px;          /* sidebar width — content column only */
  right: 0;
  height: 100vh;
  pointer-events: none;
  z-index: 0;
}

/* Ensure content sits above the glow */
nav,
.sidebar,
header {
  position: relative;
  z-index: 1;
}
#main-content {
  position: relative;
  z-index: 1;
}
#side-nav {
  position: relative;
  z-index: 200;
}
#top-header {
  position: relative;
  z-index: 300;
}

a { color: inherit; text-decoration: inherit; }
h1,h2,h3,h4,h5,h6 { font-size: inherit; font-weight: inherit; }
button, input, select, optgroup, textarea { font: inherit; color: inherit; background: transparent; border-radius: 0; }
img, svg, video { display: block; max-width: 100%; }

/* ══════════════════════════════════════════════════════════════
   TYPOGRAPHY UTILITIES
   ══════════════════════════════════════════════════════════════ */

.font-sans    { font-family: var(--font-sans); }
.font-display { font-family: var(--font-display); }
.font-mono    { font-family: var(--font-mono); }

/* ══════════════════════════════════════════════════════════════
   APP LAYOUT
   ══════════════════════════════════════════════════════════════ */

#app {
  display: flex;
  flex-direction: column;
  width: 100%;
  min-height: 100vh;
}

#app-body {
  display: flex;
  flex-direction: row;
  flex: 1;
  min-height: 0;
}

/* ══════════════════════════════════════════════════════════════
   TOP HEADER BAR
   ══════════════════════════════════════════════════════════════ */

#top-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 12px 24px;
  background-color: #030303;        /* opaque base — keep this separate */
  background-image: var(--background-radial);
  background-attachment: fixed;  /* ← add this */
  border-bottom: 1px solid rgba(255, 255, 255, 0.05);
  flex-shrink: 0;
  z-index: 300;
  position: sticky;
  top: 0;
}

.top-header-logo {
  display: flex;
  align-items: center;
  gap: 10px;
  text-decoration: none;
  color: inherit;
}

.top-header-logo-text {
  font-family: var(--font-display);
  font-size: 1rem;
  font-weight: 700;
  letter-spacing: 0.15em;
  color: var(--title);
  text-transform: uppercase;
}

.top-header-right {
  display: flex;
  align-items: center;
  gap: 16px;
}

#app:has(#top-header) {
  display: flex;
  flex-direction: column;
}

/* ══════════════════════════════════════════════════════════════
   SIDE NAV
   ══════════════════════════════════════════════════════════════ */

#side-nav {
  width: 130px;
  min-width: 130px;
  height: 100%;
  background: var(--nav-bg);
  background-image: var(--background-radial);
  background-attachment: fixed; 
  border-right: 1px solid rgba(255, 255, 255, 0.04);
  display: flex;
  flex-direction: column;
  padding: 16px 0;
  flex-shrink: 0;
  z-index: 200;
  overflow: visible;
}

#side-nav-logo {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  padding: 0 16px 20px;
  text-decoration: none;
  color: inherit;
}

#side-nav-logo-text {
  font-family: var(--font-sans);
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.2em;
  color: var(--accent);
  text-transform: uppercase;
}

.nav-divider {
  height: 1px;
  background: var(--border);
  margin: 0 16px 12px;
  flex-shrink: 0;
}

#side-nav-links {
  list-style: none;
  padding: 0 8px;
  margin: 0;
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 2px;
}

/* ── Nav Items ── */
.nav-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 6px;
  padding: 16px 8px;
  text-decoration: none;
  color: #9ca3af;
  font-family: var(--font-sans);
  font-size: 0.68rem;
  font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  white-space: nowrap;
  transition: color 0.2s;
  position: relative;
  text-align: center;
  border-left: 2px solid transparent;
}

.nav-item:hover  { color: #e5e7eb; background: transparent; }
.nav-item.active { color: #00ceae; border-left-color: transparent; background: transparent; }

.nav-icon {
  flex-shrink: 0;
  width: 24px;
  height: 24px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.nav-icon svg { width: 22px; height: 22px; }

/* Draw-in animation for nav icon SVG strokes */
.nav-icon svg path,
.nav-icon svg polyline,
.nav-icon svg polygon,
.nav-icon svg line,
.nav-icon svg rect,
.nav-icon svg circle {
  stroke-dasharray: 100;
  stroke-dashoffset: 0;
  transition: stroke-dashoffset 0s;
}

.nav-item:hover .nav-icon svg path,
.nav-item:hover .nav-icon svg polyline,
.nav-item:hover .nav-icon svg polygon,
.nav-item:hover .nav-icon svg line,
.nav-item:hover .nav-icon svg rect,
.nav-item:hover .nav-icon svg circle {
  animation: nav-draw-in 1s ease-out forwards;
}

@keyframes nav-draw-in {
  0% {
    stroke-dashoffset: 100;
  }
  100% {
    stroke-dashoffset: 0;
  }
}

.nav-label { line-height: 1.3; font-size: 0.63rem; text-align: center; }
.nav-item--bottom { font-size: 0.6rem; opacity: 0.6; }
.nav-item--bottom:hover { opacity: 1; }

/* ── Bottom Nav ── */
#side-nav-bottom { padding: 0 8px; }

/* ── User Menu ── */
.nav-user-menu { position: relative; margin-top: 4px; }

.nav-user-avatar {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
  padding: 16px 8px;
  border-radius: 8px;
  background: transparent;
  border: none;
  cursor: pointer;
  width: 100%;
  font-family: var(--font-sans);
  font-size: 0.63rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--muted-foreground);
  transition: background 0.15s, color 0.15s;
  text-align: center;
}
.nav-user-avatar:hover { background: rgba(255,255,255,0.04); color: var(--foreground); }

.user-avatar-circle {
  width: 24px;
  height: 24px;
  border-radius: 50%;
  background: linear-gradient(135deg, #1a4a3a 0%, #0d2820 100%);
  border: 2px solid var(--accent);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.6rem;
  font-weight: 700;
  color: var(--accent);
  flex-shrink: 0;
}

.nav-user-dropdown {
  position: absolute;
  bottom: calc(100% + 8px);
  left: 0;
  right: 0;
  background: var(--popover);
  border: 1px solid var(--border2);
  border-radius: 8px;
  padding: 6px;
  opacity: 0;
  visibility: hidden;
  transform: translateY(8px);
  transition: opacity 0.15s, visibility 0.15s, transform 0.15s;
  z-index: 300;
  min-width: 140px;
}
.nav-user-dropdown.visible {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}

.nav-dropdown-item {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 12px;
  border-radius: 6px;
  text-decoration: none;
  color: var(--text);
  font-size: 0.7rem;
  font-weight: 500;
  transition: background 0.15s, color 0.15s;
}
.nav-dropdown-item:hover { background: rgba(255,255,255,0.05); color: var(--accent); }
.nav-dropdown-item svg { color: var(--muted-foreground); transition: color 0.15s; }
.nav-dropdown-item:hover svg { color: var(--accent); }
.nav-dropdown-item--danger:hover { color: var(--accent2); }
.nav-dropdown-item--danger:hover svg { color: var(--accent2); }

.nav-dropdown-divider { height: 1px; background: var(--border2); margin: 4px 8px; }

/* ── Header Avatar ── */
.header-user-menu { position: relative; }
.header-user-avatar { display: flex; align-items: center; justify-content: center; background: transparent; border: none; cursor: pointer; padding: 0; }
.header-avatar-circle {
  width: 36px; height: 36px; border-radius: 50%;
  background: #008872; color: #ffffff;
  font-weight: 700; font-size: 0.85rem;
  display: flex; align-items: center; justify-content: center;
  transition: transform 0.15s, box-shadow 0.15s;
}
.header-user-avatar:hover .header-avatar-circle { transform: scale(1.05); box-shadow: 0 0 0 3px rgba(0,172,136,0.2); }

.header-user-dropdown {
  position: absolute; top: calc(100% + 8px); right: 0;
  min-width: 180px; background: var(--surface);
  border: 1px solid var(--border2); border-radius: var(--radius-sm);
  padding: 8px 0; opacity: 0; visibility: hidden;
  transform: translateY(-8px);
  transition: opacity 0.15s, transform 0.15s, visibility 0.15s;
  z-index: 1000; box-shadow: 0 8px 24px rgba(0,0,0,0.4);
}
.header-user-dropdown.visible { opacity: 1; visibility: visible; transform: translateY(0); }
.header-dropdown-name { padding: 8px 16px; font-size: 0.7rem; font-weight: 600; color: var(--text); }
.header-dropdown-divider { height: 1px; background: var(--border); margin: 4px 0; }
.header-dropdown-item {
  display: flex; align-items: center; gap: 10px;
  padding: 10px 16px; font-size: 0.7rem; color: var(--muted-foreground);
  text-decoration: none; transition: background 0.15s, color 0.15s;
}
.header-dropdown-item:hover { background: rgba(255,255,255,0.04); color: var(--accent); }
.header-dropdown-item svg { color: var(--muted-foreground); transition: color 0.15s; }
.header-dropdown-item:hover svg { color: var(--accent); }
.header-dropdown-item--logout { color: #f05a7e; }
.header-dropdown-item--logout svg { color: #f05a7e; }
.header-dropdown-item--logout:hover { background: rgba(240,90,126,0.1); color: #ff6b8a; }
.header-dropdown-item--logout:hover svg { color: #ff6b8a; }

/* ── Tooltip ── */
#nav-tooltip {
  position: fixed; left: 70px;
  background: var(--popover); border: 1px solid var(--border2);
  border-radius: 6px; padding: 5px 10px;
  font-size: 0.6rem; font-weight: 700; letter-spacing: 0.1em; text-transform: uppercase;
  color: var(--text); pointer-events: none; opacity: 0; transition: opacity 0.1s;
  white-space: nowrap; z-index: 999;
}
#nav-tooltip.visible { opacity: 1; }

/* ── MT5 Account Management ── */

.mt5-accounts-section {
  margin: 0 28px 16px;
  padding: 16px 24px;
  background: var(--panel-bg);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  border: 1px solid var(--border);
  border-radius: 0.75rem;
}

.mt5-accounts-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 12px;
}

.mt5-accounts-title {
  font-size: 0.6rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.16em;
  color: var(--muted-foreground);
}

.mt5-accounts-list {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
}

.mt5-account-card {
  display: flex;
  align-items: center;
  gap: 12px;
  min-width: 200px;
  background: var(--card-bg);
  border: 1px solid rgba(255, 255, 255, 0.07);
  border-left: 3px solid var(--ring);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  border: none;
  border-radius: 14px;
  padding: 14px 16px;
  box-shadow: 0 0 0 1px rgba(60, 60, 60, 0.5), inset 0 0 20px rgba(50, 50, 50, 0.3), inset 0 0 0 1000px rgba(20, 22, 26, 0.30);
}

.mt5-account-icon {
  width: 32px;
  height: 32px;
  border-radius: 6px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(255, 255, 255, 0.05);
  border: 1px solid rgba(255, 255, 255, 0.08);
  color: var(--muted-foreground);  /* grey, not teal */
}

.mt5-account-info {
  flex: 1;
}

.mt5-account-name {
  font-size: 0.8rem;
  font-weight: 600;
  color: var(--text);
}

.mt5-account-status {
  font-size: 0.65rem;
  color: var(--muted);
}

.mt5-account-status.active { color: var(--accent); display: flex; align-items: center; }
.mt5-account-status.deploying { color: var(--blue); }
.mt5-account-status.error { color: var(--accent2); }

.mt5-account-actions {
  display: flex;
  gap: 8px;
}

.mt5-account-btn {
  width: 28px;
  height: 28px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 6px;
  color: rgba(255, 255, 255, 0.5);
  cursor: pointer;
  transition: all 0.15s;
  background: #1a1b1e;
  border: 1px solid rgba(255, 255, 255, 0.15);
}

.mt5-account-btn:hover {
  border-color: rgba(90, 158, 240, 0.5);
  color: var(--blue);
}

.mt5-account-btn.delete:hover {
  border-color: rgba(240, 90, 126, 0.5);
  color: var(--accent2);
}

.mt5-empty {
  padding: 20px;
  text-align: center;
  color: var(--muted-foreground);
  font-size: 0.75rem;
}

/* ══════════════════════════════════════════════════════════════
   MAIN CONTENT
   ══════════════════════════════════════════════════════════════ */

#main-content {
  flex: 1;
  min-width: 0;
  height: 100%;
  overflow-y: auto;
  overflow-x: hidden;
  display: flex;
  flex-direction: column;
  scrollbar-width: thin;
  scrollbar-color: var(--border2) transparent;
}
#main-content::-webkit-scrollbar { width: 4px; }
#main-content::-webkit-scrollbar-thumb { background: var(--border2); border-radius: 2px; }

/* ══════════════════════════════════════════════════════════════
   WELCOME SECTION
   ══════════════════════════════════════════════════════════════ */

.welcome-section {
  padding: 28px 32px 20px;
}

.welcome-title {
  font-family: var(--font-display);
  font-size: 2.25rem;
  font-weight: 700;
  color: #00a58a;
  letter-spacing: -0.02em;
  margin: 0 0 6px 0;
  line-height: 1.2;
}

.welcome-quote {
  font-size: 0.72rem;
  color: #94a3b8;
  letter-spacing: 0.05em;
  margin: 0;
  font-style: italic;
  opacity: 1;
  min-height: 1em;
}

/* ══════════════════════════════════════════════════════════════
   SESSIONS CARD
   ══════════════════════════════════════════════════════════════ */

.sessions-card {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin: 0 32px 20px;
  padding: 16px 24px;
  background: rgba(13, 13, 13, 0.55);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  border: 1px solid rgba(228, 255, 248, 0.1);
  border-radius: var(--radius);
  position: relative;
  z-index: 10;
}

.sessions-bar {
  display: flex;
  align-items: flex-start;
  gap: 32px;
}

.session-item {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 2px;
  font-size: 0.65rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  cursor: help;
  position: relative;
}

.session-item:hover .session-tooltip {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}

.session-tooltip {
  position: absolute;
  top: 100%; left: 0;
  margin-top: 8px; padding: 10px 14px;
  background: var(--surface2);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  font-size: 0.6rem; letter-spacing: 0.02em; text-transform: none;
  color: var(--text); white-space: nowrap;
  opacity: 0; visibility: hidden; transform: translateY(-4px);
  transition: all 0.15s ease; z-index: 100;
  box-shadow: 0 4px 12px rgba(0,0,0,0.3);
}

.session-tooltip::before {
  content: ''; position: absolute; top: -5px; left: 12px;
  width: 8px; height: 8px;
  background: var(--surface2);
  border-left: 1px solid var(--border); border-top: 1px solid var(--border);
  transform: rotate(45deg);
}

.session-header { display: flex; align-items: center; gap: 6px; }

.session-marker {
  width: 6px; height: 6px; border-radius: 50%;
  background: #6b7280;
  flex-shrink: 0;
}

.session-item.open .session-marker { background: var(--emerald-500); box-shadow: 0 0 6px var(--accent); }
.session-item.closed .session-marker { background: #6b7280; }

.session-name { color: #d1d5db; font-weight: 600; font-size: 0.68rem; letter-spacing: 0.12em; }

.session-info { display: flex; align-items: center; gap: 6px; padding-left: 12px; }

.session-status { color: #9ca3af; font-weight: 600; font-size: 0.58rem; letter-spacing: 0.1em; }
.session-item.open .session-status  { color: var(--emerald-500); }
.session-item.closed .session-status { color: #6b7280; }
.session-item.holiday .session-marker { background: var(--orange); box-shadow: 0 0 6px var(--orange); }
.session-item.holiday .session-status { color: var(--orange); }
.session-countdown { color: var(--muted-foreground); font-size: 0.55rem; font-variant-numeric: tabular-nums; }

/* ── Holiday Badge & Dropdown ── */
.holiday-badge-container {
  position: relative;
  display: none;
}
.holiday-badge-container.active { display: flex; }

.holiday-badge {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 6px 12px;
  background: rgba(245, 158, 11, 0.12);
  border: 1px solid rgba(245, 158, 11, 0.3);
  border-radius: var(--radius-sm);
  cursor: pointer;
  transition: all 0.2s;
}
.holiday-badge:hover {
  background: rgba(245, 158, 11, 0.18);
  border-color: rgba(245, 158, 11, 0.5);
}
.holiday-badge-icon {
  width: 14px;
  height: 14px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.holiday-badge-icon svg {
  width: 100%;
  height: 100%;
}
.holiday-badge-title {
  color: var(--orange);
  font-size: 0.65rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}
.holiday-badge-currencies {
  color: rgba(245, 158, 11, 0.7);
  font-size: 0.55rem;
  letter-spacing: 0.05em;
}

.holiday-dropdown {
  position: absolute;
  top: calc(100% + 8px);
  right: 0;
  min-width: 280px;
  background: var(--bg);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 16px;
  z-index: 10000;
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.4);
  display: none;
}
.holiday-dropdown.show { display: block; }

.holiday-dropdown-header {
  color: var(--foreground);
  font-size: 0.75rem;
  font-weight: 600;
  margin-bottom: 12px;
  padding-bottom: 8px;
  border-bottom: 1px solid var(--border);
}

.holiday-dropdown-item {
  margin-bottom: 12px;
}
.holiday-dropdown-item:last-child { margin-bottom: 0; }

.holiday-dropdown-name {
  color: var(--orange);
  font-size: 0.7rem;
  font-weight: 600;
  margin-bottom: 4px;
}
.holiday-dropdown-detail {
  color: var(--muted-foreground);
  font-size: 0.6rem;
}
.holiday-dropdown-detail span {
  color: var(--orange);
}

.holiday-dropdown-section {
  margin-top: 12px;
  padding-top: 12px;
  border-top: 1px solid var(--border);
}
.holiday-dropdown-section-title {
  color: var(--muted-foreground);
  font-size: 0.55rem;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  margin-bottom: 8px;
}
.holiday-dropdown-currencies {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}
.holiday-dropdown-currency {
  color: var(--orange);
  font-size: 0.6rem;
  font-weight: 600;
  padding: 2px 6px;
  background: rgba(245, 158, 11, 0.1);
  border-radius: 3px;
}

.holiday-dropdown-instruments {
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.holiday-dropdown-instrument {
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: 0.6rem;
}
.holiday-dropdown-instrument-name {
  color: var(--foreground);
  font-weight: 500;
}
.holiday-dropdown-instrument-currencies {
  color: var(--orange);
  font-size: 0.55rem;
}

/* ── Time Display ── */
.time-display {
  display: flex; align-items: center; gap: 16px;
  padding: 6px 12px;
  background: rgba(255,255,255,0.02);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
}

.time-item { display: flex; align-items: center; gap: 6px; }
.time-icon { font-size: 0.7rem; opacity: 0.7; }
.time-value { font-family: var(--font-mono); font-size: 0.85rem; color: var(--emerald-500); font-weight: 600; letter-spacing: 0.05em; font-variant-numeric: tabular-nums; }
.time-item:last-child .time-value { color: #9ca3af; }
.time-label { font-size: 0.55rem; color: var(--muted-foreground); letter-spacing: 0.1em; text-transform: uppercase; }

/* ══════════════════════════════════════════════════════════════
   INSTRUMENT / PAIR CARDS GRID
   ══════════════════════════════════════════════════════════════ */

.grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(380px, 1fr));
  gap: 20px;
  padding: 20px 32px 0;
  margin-bottom: 28px;
}

.card {
  background: var(--card-bg);
  /* backdrop-filter: blur(16px);*/
  -webkit-backdrop-filter: blur(16px);
  border: none;
  border-radius: 14px;
  padding: 24px 26px;
  display: flex; flex-direction: column;
  transition: transform 0.2s ease, box-shadow 0.2s ease;
  position: relative; 
  overflow: visible;
  /* box-shadow: 0 0 0 1px rgba(60, 60, 60, 0.5), inset 0 0 20px rgba(50, 50, 50, 0.3), inset 0 0 0 1000px rgba(20, 22, 26, 0.30);*/
}
.card::before {
  content: '';
  position: absolute;
  inset: -1px;
  border-radius: inherit;
  padding: 1px;
  background: conic-gradient(
    from -10deg,
    rgba(228, 255, 248, 0.10),
    rgba(0, 136, 114, 0.07),
    rgba(228, 255, 248, 0.02),
    rgba(0, 136, 114, 0.05)
  );
  -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  -webkit-mask-composite: xor;
  mask-composite: exclude;
  pointer-events: none;
  z-index: 1;
  opacity: 0; /* ← hidden by default */
  transition: opacity 0.3s ease;
}
.card:hover {
  transform: translateY(-1px);
}
.card:hover::before {
  opacity: 1;
  background: conic-gradient(
    from var(--gradient-border-angle),
    transparent 0deg,
    transparent 270deg,
    oklch(from var(--animation-color) l c h / 0.9) 300deg,
    transparent 360deg
  );
  animation: border-spin 1.2s linear 1;
}


.card-link-overlay { position: absolute; inset: 0; z-index: 3; border-radius: inherit; }

/* ── Card internals ── */
.card-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  margin-bottom: 14px;
  position: relative;
  z-index: 4;
  pointer-events: none;
}

.pair-name {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 1.5rem;
  color: #ffffff;
  letter-spacing: -0.01em;
  line-height: 1;
  display: flex;
  align-items: center;
  gap: 12px;
}

.pair-label { font-size: 0.6rem; color: #6b7280; letter-spacing: 0.12em; text-transform: uppercase; margin-top: 4px; font-weight: 500; }

.card-header-right { display: flex; align-items: center; gap: 8px; }


/* ── Price row ── */
.price-row { display: flex; align-items: baseline; gap: 8px; margin: 8px 0 12px; position: relative; z-index: 2; pointer-events: none; }
.price { font-family: var(--font-mono); font-size: 1.6rem; font-weight: 700; color: #ffffff; letter-spacing: -0.02em; line-height: 1; }
.price.closed { color: #525252; }
.price-change { font-size: 0.68rem; padding: 2px 6px; border-radius: var(--radius-sm); font-family: var(--font-mono); }
.price-change.up   { color: var(--green-400);  background: rgba(0,178,150,0.1); }
.price-change.down { color: var(--red-400); background: rgba(240,90,126,0.1); }

/* ── Status row & dots ── */
.status-row { display: flex; align-items: center; gap: 8px; margin-bottom: 10px; }
.status-dot { width: 6px; height: 6px; border-radius: 50%; background: #6b7280; flex-shrink: 0; }
.status-dot.found      { background: var(--found); box-shadow: 0 0 8px rgba(232,232,240,0.6); animation: pulse 2s ease-in-out infinite; }
.status-dot.potential  { background: var(--potential); }
.status-dot.looking    { background: #2a2a3a; }
.status-dot.offline    { background: #1a1a2a; }
.status-dot.bullish    { background: #00b296; box-shadow: 0 0 6px #00b296; }
.status-dot.bearish    { background: var(--accent2); box-shadow: 0 0 6px rgba(240,90,126,0.4); }
.status-dot.misaligned { background: var(--muted-foreground); }
.status-dot.open       { background: #00b296; box-shadow: 0 0 6px #00b296; }

/* ── Market status badge ── */
.market-status-badge {
  display: inline-flex; align-items: center; gap: 6px;
  font-size: 0.58rem; font-weight: 600; letter-spacing: 0.12em; text-transform: uppercase;
  padding: 6px 12px; border-radius: 6px;
  background: rgba(38, 38, 38, 0.8); color: #9ca3af;
  border: 1px solid rgba(75, 85, 99, 0.5);
}
.market-status-badge.open { background: rgba(0, 30, 23, 0.4); color: #00ceae; border-color: rgba(0, 71, 58, 0.4); }

/* ── Macro link ── */
.macro-link {
  font-size: 0.58rem; color: var(--slate-200);
  font-weight: 600;
  letter-spacing: 0.08em; border: 1px solid var(--border2);
  padding: 2px 8px; border-radius: 3px;
  text-decoration: none; transition: all 0.15s;
  position: relative; z-index: 4;
  pointer-events: auto;
}
.macro-link:hover { color: var(--accent); border-color: rgba(0,178,150,0.4); }

/* ── Accum box ── */
.accum-box {
  margin-top: 10px; padding: 8px 10px;
  border: 1px solid var(--border2); border-left: 2px solid var(--muted-foreground);
  border-radius: var(--radius-sm);
  font-size: 0.65rem; color: var(--muted-foreground);
  display: none; line-height: 1.6;
}
.accum-box.found     { border-left-color: var(--found); color: var(--text); display: block; }
.accum-box.potential { border-left-color: var(--potential); color: var(--potential); display: block; }
.accum-range { font-size: 0.7rem; color: var(--foreground); font-weight: 700; font-family: var(--font-mono); }

/* ── Bias display ── */
.bias-display-row { margin-top: 10px; }
.bias-display-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 6px; }
.bias-box {
  background: var(--bg); border: 1px solid var(--border2);
  border-radius: var(--radius-sm); padding: 8px; text-align: center;
  min-height: 48px; display: flex; flex-direction: column;
  align-items: center; justify-content: center; position: relative; cursor: pointer;
  pointer-events: auto;
}
.bias-box-label { font-size: 0.5rem; color: var(--muted-foreground); letter-spacing: 0.12em; text-transform: uppercase; margin-bottom: 2px; }
.bias-box-val { font-size: 0.68rem; font-weight: 700; letter-spacing: 0.04em; }
.bias-box.bullish { border-color: rgba(0,178,150,0.3); }
.bias-box.bullish .bias-box-val { color: var(--accent); }
.bias-box.bearish { border-color: rgba(240,90,126,0.3); }
.bias-box.bearish .bias-box-val { color: var(--accent2); }
.bias-box.neutral .bias-box-val { color: var(--text); }
.bias-box.misaligned { border-color: rgba(200,168,75,0.3); }
.bias-box.misaligned .bias-box-val { color: #c8a84b; }

.bias-box-label-row { display: inline-flex; align-items: baseline; justify-content: center; gap: 2px; }
.bias-info-btn {
  display: inline-flex; align-items: center; justify-content: center;
  width: 12px; height: 12px; margin-left: 3px;
  background: transparent; border: 1px solid var(--muted-foreground); border-radius: 50%;
  color: var(--muted-foreground); font-size: 7px; font-weight: 700; font-style: italic;
  cursor: pointer; transition: border-color 0.15s, color 0.15s;
  vertical-align: middle; padding: 0; line-height: 1; position: relative; z-index: 4; flex-shrink: 0;
}
.bias-info-btn:hover { border-color: var(--fg); color: var(--fg); }

/* Bias tooltip/modal */
.bias-modal-overlay {
  display: none; position: fixed; top: 0; left: 0; right: 0; bottom: 0;
  background: rgba(0,0,0,0.85); z-index: 9998; backdrop-filter: blur(4px);
}
.bias-modal-overlay.visible { display: block; }
#bias-tooltip-portal { position: fixed; top: 0; left: 0; width: 100%; height: 100%; z-index: 9999; pointer-events: none; }
#bias-tooltip-portal .bias-box-tooltip { pointer-events: auto; }
.bias-box-tooltip {
  display: none; position: fixed; top: 50%; left: 50%;
  transform: translate(-50%, -50%);
  min-width: 280px; max-width: 400px; padding: 16px 20px;
  background: rgba(24,24,28,1); border: 1px solid var(--border2);
  border-radius: var(--radius); box-shadow: 0 8px 32px rgba(0,0,0,0.7);
  font-size: 0.75rem; line-height: 1.6; z-index: 9999; pointer-events: auto;
}
.bias-box .bias-box-tooltip { display: none !important; }
#bias-tooltip-portal .bias-box-tooltip.visible { display: block; }

.bias-modal-close { position: absolute; top: 8px; right: 10px; background: transparent; border: none; color: var(--muted-foreground); font-size: 1rem; cursor: pointer; padding: 4px; line-height: 1; }
.bias-modal-close:hover { color: var(--fg); }
.bias-tooltip-title { font-weight: 700; font-size: 0.7rem; margin-bottom: 6px; color: var(--fg); }
.bias-tooltip-row { display: flex; justify-content: space-between; margin-bottom: 3px; }
.bias-tooltip-label { color: var(--muted-foreground); }
.bias-tooltip-value { color: var(--fg); font-weight: 500; }
.bias-tooltip-reason { margin-top: 6px; padding-top: 6px; border-top: 1px solid var(--border2); color: var(--fg); font-style: italic; }

/* Looking for row - status bar container */
.looking-for-row {
  display: flex; flex-direction: column; gap: 6px; margin: 8px 0 4px;
  position: relative; z-index: 5; pointer-events: auto;
}
.status-bar {
  display: flex; align-items: center; padding: 6px 10px;
  border-radius: var(--radius-sm);
}
.status-bar-label { font-size: 0.65rem; letter-spacing: 0.04em; }

/* Looking for accumulation - blue */
.status-bar.looking {
  background: rgba(90,158,240,0.06); border: 1px solid rgba(90,158,240,0.2);
}
.status-bar.looking .status-bar-label { color: var(--blue); }

/* Out of session - grey */
.status-bar.out-of-session {
  background: rgba(148,163,184,0.06); border: 1px solid rgba(148,163,184,0.2);
}
.status-bar.out-of-session .status-bar-label { color: #94a3b8; }

/* Cooldown - grey */
.status-bar.cooldown {
  background: rgba(148,163,184,0.06); border: 1px solid rgba(148,163,184,0.2);
}
.status-bar.cooldown .status-bar-label { color: #94a3b8; }

/* Accumulation found - blue (same as looking but with different icon) */
.status-bar.found {
  background: rgba(90,158,240,0.08); border: 1px solid rgba(90,158,240,0.3);
}
.status-bar.found .status-bar-label { color: var(--blue); font-weight: 500; }

/* LVP aggressor found - cyan/teal (higher priority than regular found) */
.status-bar.lvp-found {
  background: rgba(6,182,212,0.1); border: 1px solid rgba(6,182,212,0.35);
}
.status-bar.lvp-found .status-bar-label { color: #06b6d4; font-weight: 500; }

/* Accumulation forming - amber */
.status-bar.forming {
  background: rgba(251,191,36,0.06); border: 1px solid rgba(251,191,36,0.2);
}
.status-bar.forming .status-bar-label { color: var(--amber-400); }

/* Weekend - red/pink tint */
.status-bar.weekend {
  background: rgba(240,90,126,0.04); border: 1px solid rgba(240,90,126,0.15);
}
.status-bar.weekend .status-bar-label { color: #f05a7e; }

/* Accumulation found but no LVP aggressor - amber warning */
.status-bar.no-lvp {
  background: rgba(251,191,36,0.08); border: 1px solid rgba(251,191,36,0.3);
}
.status-bar.no-lvp .status-bar-label { color: var(--amber-400); font-weight: 500; }

/* Price in zone - amber (same styling as accumulation forming) */
.status-bar.in-supply,
.status-bar.in-demand {
  background: rgba(251,191,36,0.06); border: 1px solid rgba(251,191,36,0.2);
}
.status-bar.in-supply .status-bar-label,
.status-bar.in-demand .status-bar-label { color: var(--amber-400); }

/* Legacy support */
.looking-for-label { font-size: 0.65rem; color: var(--blue); letter-spacing: 0.04em; }

/* ── Multi-Detector Status Bar (Option 2: Horizontal compact display) ── */
.multi-detector-status-bar {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
  position: relative;
  z-index: 5;
}

.detector-status-pill {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 5px 10px;
  border-radius: var(--radius-sm);
  font-size: 0.58rem;
  letter-spacing: 0.04em;
  cursor: pointer;
  transition: all 0.15s ease;
  position: relative;
  pointer-events: auto;
}

.detector-status-type {
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  opacity: 0.85;
}

.detector-status-label {
  font-weight: 500;
}

/* CVDD detector styles */
.detector-status-pill.cvdd {
  background: rgba(90,158,240,0.06);
  border: 1px solid rgba(90,158,240,0.2);
  border-left: 2px solid rgba(90,158,240,0.5);
  color: var(--blue-400);
}
.detector-status-pill.cvdd.found {
  background: rgba(46,204,113,0.06);
  border: 1px solid rgba(46,204,113,0.25);
  border-left: 2px solid rgba(46,204,113,0.6);
  color: #2ecc71;
}
.detector-status-pill.cvdd.lvp-found {
  background: rgba(6,182,212,0.08);
  border: 1px solid rgba(6,182,212,0.3);
  border-left: 2px solid rgba(6,182,212,0.7);
  color: #06b6d4;
}
.detector-status-pill.cvdd.forming {
  background: rgba(251,191,36,0.06);
  border: 1px solid rgba(251,191,36,0.2);
  border-left: 2px solid rgba(251,191,36,0.5);
  color: var(--amber-400);
}
.detector-status-pill.cvdd.cooldown,
.detector-status-pill.cvdd.out-of-session,
.detector-status-pill.cvdd.looking {
  background: rgba(148,163,184,0.05);
  border: 1px solid rgba(148,163,184,0.2);
  border-left: 2px solid rgba(148,163,184,0.4);
  color: #94a3b8;
}
.detector-status-pill.cvdd.weekend {
  background: rgba(240,90,126,0.05);
  border: 1px solid rgba(240,90,126,0.2);
  border-left: 2px solid rgba(240,90,126,0.5);
  color: #f05a7e;
}
.detector-status-pill.cvdd.no-lvp {
  background: rgba(251,191,36,0.06);
  border: 1px solid rgba(251,191,36,0.25);
  border-left: 2px solid rgba(251,191,36,0.5);
  color: var(--amber-400);
}

/* Supply/Demand detector styles */
.detector-status-pill.sd {
  background: rgba(249,115,22,0.06);
  border: 1px solid rgba(249,115,22,0.2);
  border-left: 2px solid rgba(249,115,22,0.5);
  color: var(--orange-400);
}
.detector-status-pill.sd.active {
  background: rgba(59,130,246,0.06);
  border: 1px solid rgba(59,130,246,0.25);
  border-left: 2px solid rgba(59,130,246,0.6);
  color: var(--blue-400);
}
.detector-status-pill.sd.in-supply {
  background: rgba(240,90,126,0.06);
  border: 1px solid rgba(240,90,126,0.25);
  border-left: 2px solid rgba(240,90,126,0.6);
  color: #f05a7e;
}
.detector-status-pill.sd.in-demand {
  background: rgba(46,204,113,0.06);
  border: 1px solid rgba(46,204,113,0.25);
  border-left: 2px solid rgba(46,204,113,0.6);
  color: #2ecc71;
}
.detector-status-pill.sd.looking {
  background: rgba(148,163,184,0.05);
  border: 1px solid rgba(148,163,184,0.2);
  border-left: 2px solid rgba(148,163,184,0.4);
  color: #94a3b8;
}

/* FVG detector styles (future support) */
.detector-status-pill.fvg {
  background: rgba(192,132,252,0.06);
  border: 1px solid rgba(192,132,252,0.2);
  border-left: 2px solid rgba(192,132,252,0.5);
  color: #c084fc;
}

/* Weekend badge */
.weekend-card-badge {
  margin-top: 10px; padding: 5px 10px;
  font-size: 0.58rem; letter-spacing: 0.18em; text-transform: uppercase;
  color: #f05a7e; border: 1px solid rgba(240,90,126,0.25); border-left: 2px solid rgba(240,90,126,0.5);
  border-radius: var(--radius-sm); display: inline-block;
  pointer-events: none;
}

/* Bias pills */
.bias-pill { font-size: 0.6rem; letter-spacing: 0.08em; padding: 3px 8px; border-radius: var(--radius-sm); border: 1px solid var(--border2); color: var(--muted-foreground); }
.bias-pill.strong_bullish { border-color: rgba(46,204,113,0.5);  color: #2ecc71; background: rgba(46,204,113,0.08); font-weight: 700; }
.bias-pill.bullish        { border-color: rgba(0,178,150,0.4);   color: var(--accent); background: rgba(0,178,150,0.06); }
.bias-pill.bearish        { border-color: rgba(240,90,126,0.4);  color: var(--accent2); background: rgba(240,90,126,0.06); }
.bias-pill.strong_bearish { border-color: rgba(231,76,60,0.5);   color: #e74c3c; background: rgba(231,76,60,0.08); font-weight: 700; }
.bias-pill.misaligned     { border-color: var(--border2); color: var(--muted-foreground); }

/* Card meta */
.card-divider { height: 1px; background: var(--border); margin: 12px 0; }
.card-meta { display: flex; justify-content: space-between; font-size: 0.6rem; color: var(--muted-foreground); letter-spacing: 0.08em; margin-top: 8px; pointer-events: none; }
.status-text { font-size: 0.72rem; color: var(--text); letter-spacing: 0.05em; }
.status-text.dim { color: var(--muted-foreground); }

/* ══════════════════════════════════════════════════════════════
   INTEL ROW
   ══════════════════════════════════════════════════════════════ */

#intel-row {
  display: grid;
  grid-template-columns: 1fr 400px;
  gap: 12px;
  padding: 0 32px;
  align-items: stretch;
}

#cstrength-panel, #fj-panel {
  background: var(--panel-bg);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  border: 1px solid var(--border);
  border-radius: 0.75rem;
  overflow: visible;
  position: relative;
  transition: background 0.25s, box-shadow 0.25s, transform 0.25s;
}

#cstrength-panel::before, #fj-panel::before {
  content: '';
  position: absolute;
  inset: -1px;
  border-radius: inherit;
  padding: 1px;
  background: conic-gradient(
    from var(--gradient-border-angle),
    transparent 0deg,
    transparent 270deg,
    oklch(from var(--animation-color) l c h / 0.9) 300deg,
    transparent 360deg
  );
  -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  -webkit-mask-composite: xor;
  mask-composite: exclude;
  pointer-events: none;
  z-index: 0;
  opacity: 0;
}

#cstrength-panel:hover, #fj-panel:hover {
  transform: translateY(-2px);
}

#cstrength-panel:hover::before, #fj-panel:hover::before {
  animation: border-spin 1.2s linear 1;
  opacity: 1;
}

#cstrength-panel {
  padding: 20px 24px 16px;
  display: flex; flex-direction: column;
  height: 360px; min-height: 360px; max-height: 360px;
}

.intel-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 16px; flex-shrink: 0; }
.intel-title-group { display: flex; align-items: center; gap: 10px; }
.intel-icon { font-size: 1rem; opacity: 0.45; }
.intel-title { font-family: var(--font-display); font-weight: 700; font-size: 1rem; color: var(--foreground); letter-spacing: 0.04em; }
.intel-sub { font-size: 0.62rem; color: var(--muted-foreground); letter-spacing: 0.12em; text-transform: uppercase; margin-top: 2px; }
.live-badge { display: flex; align-items: center; gap: 5px; font-size: 0.6rem; font-weight: 700; letter-spacing: 0.12em; color: var(--accent); border: 1px solid rgba(0,178,150,0.35); padding: 3px 10px; border-radius: var(--radius-sm); background: rgba(0,178,150,0.05); }
.live-badge .ldot { width: 6px; height: 6px; border-radius: 50%; background: var(--accent); animation: pulse 1.4s ease-in-out infinite; }

#cs-legend { display: flex; gap: 6px; margin-bottom: 12px; flex-shrink: 0; }
.cs-pill { display: flex; align-items: center; gap: 5px; font-size: 0.65rem; font-weight: 700; letter-spacing: 0.08em; padding: 3px 10px; border-radius: var(--radius-sm); cursor: pointer; transition: opacity 0.2s; border: 1px solid transparent; user-select: none; }
.cs-pill.hidden-curr { opacity: 0.25; }
.cs-pill[data-curr="USD"] { background: rgba(90,90,240,0.15); color: #6060f0; border-color: rgba(90,90,240,0.35); }
.cs-pill[data-curr="EUR"] { background: rgba(90,200,80,0.12); color: #50c840; border-color: rgba(90,200,80,0.35); }
.cs-pill[data-curr="GBP"] { background: rgba(240,50,80,0.12); color: #f03050; border-color: rgba(240,50,80,0.35); }
.cs-pill[data-curr="JPY"] { background: rgba(240,180,40,0.12); color: #f0b428; border-color: rgba(240,180,40,0.35); }

#cs-values { display: flex; gap: 22px; margin-bottom: 12px; flex-shrink: 0; }
.cs-val-item { display: flex; flex-direction: column; gap: 2px; }
.cs-val-label { display: flex; align-items: center; gap: 4px; font-size: 0.52rem; color: var(--muted-foreground); letter-spacing: 0.14em; text-transform: uppercase; }
.cs-val-box { width: 12px; height: 12px; border-radius: 2px; flex-shrink: 0; }
.cs-val-box.USD { background: #6060f0; }
.cs-val-box.EUR { background: #50c840; }
.cs-val-box.GBP { background: #f03050; }
.cs-val-box.JPY { background: #f0b428; }
.cs-val-num { font-size: 0.9rem; font-weight: 700; font-variant-numeric: tabular-nums; }
.cs-val-num.USD { color: #6060f0; }
.cs-val-num.EUR { color: #50c840; }
.cs-val-num.GBP { color: #f03050; }
.cs-val-num.JPY { color: #f0b428; }

#cs-chart-wrap { flex: 1; position: relative; min-height: 0; overflow: hidden; }
#cs-canvas { position: absolute; top: 0; left: 0; width: 100% !important; height: 100% !important; }
#cs-error { display: none; align-items: center; justify-content: center; height: 100%; font-size: 0.65rem; color: var(--muted-foreground); letter-spacing: 0.08em; text-align: center; }

/* FJ Panel */
#fj-panel { display: flex; flex-direction: column; height: 360px; min-height: 360px; max-height: 360px; overflow: hidden; }
#fj-header { padding: 16px 20px 14px; border-bottom: 1px solid rgba(255,255,255,0.04); flex-shrink: 0; display: flex; align-items: center; justify-content: space-between; }
#fj-refresh-btn { background: none; border: 1px solid var(--border2); border-radius: var(--radius-sm); color: var(--muted-foreground); font-family: var(--font-mono); font-size: 0.6rem; letter-spacing: 0.1em; padding: 3px 10px; cursor: pointer; transition: all 0.2s; }
#fj-refresh-btn:hover { color: var(--accent); border-color: rgba(0,178,150,0.4); }
#fj-list { flex: 1; overflow-y: auto; scrollbar-width: thin; scrollbar-color: var(--border2) transparent; }
#fj-list::-webkit-scrollbar { width: 4px; }
#fj-list::-webkit-scrollbar-thumb { background: var(--border2); border-radius: 2px; }

.fj-headline { padding: 10px 20px; border-bottom: 1px solid var(--border); display: flex; flex-direction: column; gap: 4px; transition: background 0.15s; }
.fj-headline:last-child { border-bottom: none; }
.fj-headline:hover { background: rgba(255,255,255,0.02); }
.fj-headline.fj-high-impact { background: rgba(184,1,1,0.15); border-left: 3px solid #b80101; }
.fj-headline.fj-high-impact:hover { background: rgba(184,1,1,0.25); }
.fj-high-impact-badge { display: inline-flex; align-items: center; gap: 4px; background: #b80101; color: #fff; font-size: 0.45rem; font-weight: 700; letter-spacing: 0.08em; padding: 2px 6px; border-radius: 3px; margin-left: 6px; animation: fj-pulse 2s ease-in-out infinite; }
@keyframes fj-pulse { 0%, 100% { opacity: 1; } 50% { opacity: 0.7; } }
.fj-headline-meta { display: flex; align-items: center; justify-content: space-between; gap: 8px; font-size: 0.54rem; }
.fj-category { font-weight: 600; letter-spacing: 0.08em; text-transform: uppercase; padding: 2px 6px; border-radius: 3px; font-size: 0.5rem; }
.fj-category-data         { color: #00ac88; background: rgba(0,172,136,0.1); }
.fj-category-central_bank { color: #f0c45a; background: rgba(240,196,90,0.1); }
.fj-category-geopolitical { color: #f05a7a; background: rgba(240,90,122,0.1); }
.fj-category-markets      { color: #5a9ef0; background: rgba(90,158,240,0.1); }
.fj-category-commodities  { color: #c45af0; background: rgba(196,90,240,0.1); }
.fj-category-crypto       { color: #f0a45a; background: rgba(240,164,90,0.1); }
.fj-category-fx           { color: #5af0a4; background: rgba(90,240,164,0.1); }
.fj-category-general      { color: var(--muted-foreground); background: rgba(200,200,216,0.08); }
.fj-age { color: var(--muted-foreground); font-size: 0.52rem; }
.fj-headline-text { font-size: 0.7rem; color: var(--text); line-height: 1.55; font-weight: 400; letter-spacing: -0.01em; }
.fj-headline-row { display: flex; align-items: flex-start; justify-content: space-between; gap: 8px; }
.fj-open-btn {
  flex-shrink: 0; background: none; border: 1px solid var(--border2);
  border-radius: var(--radius-sm); color: var(--muted-foreground); font-family: var(--font-mono);
  font-size: 0.48rem; letter-spacing: 0.1em; padding: 2px 6px; cursor: pointer; transition: all 0.2s;
  text-decoration: none; white-space: nowrap;
}
.fj-open-btn:hover { color: var(--accent); border-color: rgba(0,178,150,0.4); }

/* ══════════════════════════════════════════════════════════════
   TRUMP + ASSISTANT ROW
   ══════════════════════════════════════════════════════════════ */

#trump-assistant-row {
  display: grid; grid-template-columns: 1fr 1fr; gap: 12px;
  padding: 0 32px; margin-top: 12px; align-items: stretch;
}

#trump-panel, #assistant-panel {
  background: var(--panel-bg);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  border: 1px solid var(--border);
  border-radius: 0.75rem;
  overflow: visible; display: flex;
  flex-direction: column; height: 360px; min-height: 360px; max-height: 360px;
  position: relative;
  transition: background 0.25s, box-shadow 0.25s, transform 0.25s;
}

#trump-panel::before, #assistant-panel::before {
  content: '';
  position: absolute;
  inset: -1px;
  border-radius: inherit;
  padding: 1px;
  background: conic-gradient(
    from var(--gradient-border-angle),
    transparent 0deg,
    transparent 270deg,
    oklch(from var(--animation-color) l c h / 0.9) 300deg,
    transparent 360deg
  );
  -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  -webkit-mask-composite: xor;
  mask-composite: exclude;
  pointer-events: none;
  z-index: 0;
  opacity: 0;
}

#trump-panel:hover, #assistant-panel:hover {
  transform: translateY(-2px);
}

#trump-panel:hover::before, #assistant-panel:hover::before {
  animation: border-spin 1.2s linear 1;
  opacity: 1;
}

#trump-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 16px 20px 14px; border-bottom: 1px solid rgba(255,255,255,0.04); flex-shrink: 0;
}
#trump-refresh-btn { background: none; border: 1px solid var(--border2); border-radius: var(--radius-sm); color: var(--muted-foreground); font-family: var(--font-sans); font-size: 0.6rem; letter-spacing: 0.1em; padding: 3px 9px; cursor: pointer; transition: all 0.2s; }
#trump-refresh-btn:hover { color: var(--accent); border-color: rgba(0,178,150,0.4); }
#trump-list { flex: 1; overflow-y: auto; min-height: 0; scrollbar-width: thin; scrollbar-color: var(--border2) transparent; }
#trump-list::-webkit-scrollbar { width: 4px; }
#trump-list::-webkit-scrollbar-thumb { background: var(--border2); border-radius: 2px; }

.trump-post { padding: 13px 20px; border-bottom: 1px solid var(--border); display: flex; flex-direction: column; gap: 8px; transition: background 0.15s; }
.trump-post:last-child { border-bottom: none; }
.trump-post:hover { background: rgba(255,255,255,0.02); }
.trump-post-meta { display: flex; align-items: center; gap: 8px; font-size: 0.58rem; color: var(--muted-foreground); }
.trump-post-link { margin-left: auto; color: var(--muted-foreground); text-decoration: none; font-size: 0.6rem; transition: color 0.15s; }
.trump-post-link:hover { color: var(--accent); }
.trump-post-text { font-size: 0.78rem; color: var(--text); line-height: 1.65; }
.trump-post-analysis { background: rgba(90,140,240,0.03); border: 1px solid rgba(90,140,240,0.1); border-radius: var(--radius-sm); padding: 9px 11px; }
.trump-analysis-label { font-size: 0.52rem; font-weight: 700; color: var(--blue); letter-spacing: 0.14em; text-transform: uppercase; margin-bottom: 4px; display: flex; align-items: center; gap: 5px; }
.trump-analysis-text { font-size: 0.66rem; color: var(--text); line-height: 1.65; opacity: 0.88; }
.trump-analysis-pending { font-size: 0.62rem; color: var(--muted-foreground); font-style: italic; }

/* Assistant */
.assistant-msg-user {
  align-self: flex-end; max-width: 85%;
  background: rgba(90,158,240,0.12); border: 1px solid rgba(90,158,240,0.25);
  border-radius: 12px 12px 3px 12px; padding: 9px 14px;
  font-size: 0.7rem; color: var(--text); line-height: 1.6;
  animation: fadeUp 0.15s ease both;
}
.assistant-msg-reply { align-self: flex-start; max-width: 100%; display: flex; flex-direction: column; gap: 4px; animation: fadeUp 0.2s ease both; }
.assistant-msg-reply-label { font-size: 0.5rem; font-weight: 700; letter-spacing: 0.16em; text-transform: uppercase; color: var(--accent); }
.assistant-msg-reply-text { font-size: 0.7rem; color: var(--text); line-height: 1.75; }
.assistant-msg-reply-meta { font-size: 0.5rem; color: #2a2a38; }
.assistant-thinking { align-self: flex-start; display: flex; align-items: center; gap: 8px; font-size: 0.62rem; color: var(--muted-foreground); font-style: italic; }
.assistant-quick-btn {
  background: none; border: 1px solid var(--border2); border-radius: 20px;
  color: var(--muted-foreground); cursor: pointer; font-family: var(--font-sans);
  font-size: 0.7rem; letter-spacing: 0; padding: 4px 10px;
  display: flex; align-items: center; gap: 5px; transition: all 0.15s;
}
.assistant-quick-btn:hover { border-color: var(--accent); color: var(--accent); background: rgba(0,178,150,0.05); }

/* ══════════════════════════════════════════════════════════════
   CALENDAR + CAPITAL FLOW ROW
   ══════════════════════════════════════════════════════════════ */

#calendar-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  padding: 28px 32px 0;
  align-items: stretch; /* calendar panel follows capital-flow-container height */
}

#calendar-panel {
  background: var(--panel-bg);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  border: 1px solid var(--border);
  border-radius: 14px;
  transition: background 0.25s, box-shadow 0.25s, transform 0.25s;
  display: flex;
  flex-direction: column;
  overflow: hidden;
  position: relative;
  height: 0;
  min-height: 100%; /* fill available space but don't push row height */
}

#calendar-panel::before {
  content: '';
  position: absolute;
  inset: -1px;
  border-radius: inherit;
  padding: 1px;
  background: conic-gradient(
    from var(--gradient-border-angle),
    transparent 0deg,
    transparent 270deg,
    oklch(from var(--animation-color) l c h / 0.9) 300deg,
    transparent 360deg
  );
  -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  -webkit-mask-composite: xor;
  mask-composite: exclude;
  pointer-events: none;
  z-index: 0;
  opacity: 0;
}

#calendar-panel:hover {
  transform: translateY(-2px);
}

#calendar-panel:hover::before {
  animation: border-spin 1.2s linear 1;
  opacity: 1;
}

#cal-header { display: flex; align-items: center; justify-content: space-between; padding: 18px 24px 14px; border-bottom: 1px solid rgba(255,255,255,0.04); flex-wrap: wrap; gap: 10px; }
.cal-icon { font-size: 1.1rem; opacity: 0.5; }
#cal-filter-bar { display: flex; gap: 4px; }
.cal-filter { background: none; border: 1px solid var(--border2); border-radius: var(--radius-sm); color: var(--muted-foreground); cursor: pointer; font-family: var(--font-mono); font-size: 0.65rem; font-weight: 700; letter-spacing: 0.08em; padding: 3px 10px; transition: all 0.15s; }
.cal-filter:hover { border-color: #888; color: #bbb; }
.cal-filter.active { border-color: var(--accent); color: var(--accent); background: rgba(0,178,150,0.06); }

#cal-list {
  flex: 1;
  overflow-y: auto;
  padding: 16px 20px 20px;
  scrollbar-width: thin;
  scrollbar-color: var(--border2) transparent;
  min-height: 0;
  max-height: none; /* remove any cap */
}

#cal-list::-webkit-scrollbar { width: 4px; }
#cal-list::-webkit-scrollbar-thumb { background: var(--border2); border-radius: 2px; }

.cal-loading { display: flex; align-items: center; gap: 12px; padding: 32px 20px; font-size: 0.65rem; color: var(--muted-foreground); letter-spacing: 0.1em; grid-column: 1 / -1; }
.cal-spinner { width: 16px; height: 16px; border: 2px solid var(--border2); border-top-color: var(--accent); border-radius: 50%; animation: spin 0.7s linear infinite; flex-shrink: 0; }
.cal-spinner-mini { width: 10px; height: 10px; border: 2px solid var(--border2); border-top-color: var(--accent); border-radius: 50%; animation: spin 0.7s linear infinite; flex-shrink: 0; }
.cal-empty { padding: 32px 20px; font-size: 0.65rem; color: var(--muted-foreground); letter-spacing: 0.08em; grid-column: 1 / -1; text-align: center; }

.cal-event-card { background: rgba(8, 8, 8, 0.7); border: 1px solid rgba(255,255,255,0.05); border-radius: var(--radius-sm); padding: 14px 16px; display: flex; flex-direction: column; gap: 10px; transition: border-color 0.15s; }
.cal-event-card:hover { border-color: #3a3a50; }
.cal-event-card.countdown-mode { border-color: rgba(240,80,80,0.4); box-shadow: 0 0 12px rgba(240,80,80,0.15); }

.cal-event-top { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.cal-impact { font-size: 0.58rem; font-weight: 700; letter-spacing: 0.1em; text-transform: uppercase; padding: 2px 8px; border-radius: 20px; border: 1px solid; display: flex; align-items: center; gap: 4px; white-space: nowrap; }
.cal-impact.High   { border-color: rgba(240,80,80,0.5);  color: #f05050; background: rgba(240,80,80,0.08); }
.cal-impact.Medium { border-color: rgba(240,160,40,0.5); color: #f0a028; background: rgba(240,160,40,0.08); }
.cal-currency { font-size: 0.65rem; font-weight: 700; letter-spacing: 0.08em; padding: 2px 9px; border-radius: var(--radius-sm); white-space: nowrap; }
.cal-currency.EUR { background: rgba(90,200,80,0.12);  color: #50c840; border: 1px solid rgba(90,200,80,0.3); }
.cal-currency.GBP { background: rgba(240,50,80,0.12);  color: #f03050; border: 1px solid rgba(240,50,80,0.3); }
.cal-currency.USD { background: rgba(90,90,240,0.12);  color: #6060f0; border: 1px solid rgba(90,90,240,0.3); }
.cal-currency.JPY { background: rgba(240,180,40,0.12); color: #f0b428; border: 1px solid rgba(240,180,40,0.3); }

.cal-time-block { display: flex; align-items: center; gap: 5px; margin-left: 4px; }
.cal-time-local { font-size: 0.82rem; font-weight: 700; color: var(--foreground); font-variant-numeric: tabular-nums; letter-spacing: 0.02em; }

.cal-countdown { margin-left: auto; font-size: 0.62rem; font-weight: 700; font-family: var(--font-mono); letter-spacing: 0.06em; padding: 2px 9px; border-radius: var(--radius-sm); white-space: nowrap; border: 1px solid rgba(0,178,150,0.3); color: var(--accent); background: rgba(0,178,150,0.05); }
.cal-countdown.past { border-color: var(--border2); color: var(--muted-foreground); background: none; }
.cal-countdown.soon { border-color: rgba(240,160,40,0.5); color: #f0a028; background: rgba(240,160,40,0.06); animation: pulse 1.2s ease-in-out infinite; }
.cal-countdown.countdown-active { border-color: rgba(240,80,80,0.6); color: #f05050; background: rgba(240,80,80,0.1); font-size: 0.68rem; animation: flash 0.5s ease-in-out infinite; }
.cal-countdown.awaiting { border-color: rgba(90,140,240,0.5); color: #5a8ef0; background: rgba(90,140,240,0.08); }

.cal-event-name { font-size: 0.85rem; font-weight: 700; color: var(--foreground); letter-spacing: 0.02em; line-height: 1.3; }
.cal-ai-box { background: rgba(90,140,240,0.03); border: 1px solid rgba(90,140,240,0.1); border-radius: var(--radius-sm); padding: 10px 12px; }
.cal-ai-label { display: flex; align-items: center; gap: 6px; font-size: 0.58rem; color: var(--blue); letter-spacing: 0.12em; text-transform: uppercase; font-weight: 700; margin-bottom: 6px; }
.cal-ai-text { font-size: 0.7rem; color: var(--text); line-height: 1.65; opacity: 0.85; }

.cal-data-row { display: flex; gap: 16px; }
.cal-data-item { display: flex; flex-direction: column; gap: 2px; }
.cal-data-label { font-size: 0.52rem; color: var(--muted-foreground); letter-spacing: 0.14em; text-transform: uppercase; }
.cal-data-val { font-size: 0.75rem; font-weight: 700; color: var(--text); font-variant-numeric: tabular-nums; }
.cal-data-val.actual { color: var(--accent); }
.cal-data-val.actual-positive { color: #50c840; font-weight: 800; }
.cal-data-val.actual-negative { color: #f05050; font-weight: 800; }
.cal-data-val.actual-neutral  { color: var(--text); }
.cal-data-val.awaiting-actual { color: var(--muted-foreground); display: flex; align-items: center; gap: 6px; font-size: 0.65rem; font-weight: 500; }
.cal-data-val.countdown-val   { color: #f05050; font-family: var(--font-mono); font-size: 0.65rem; font-weight: 700; letter-spacing: 0.04em; }

.cal-date-sep { grid-column: 1 / -1; font-size: 0.6rem; letter-spacing: 0.18em; text-transform: uppercase; color: var(--muted-foreground); padding: 4px 0 2px; border-bottom: 1px solid var(--border); margin-bottom: 4px; }

/* Date filter buttons */
.cal-date-filter { display: flex; gap: 4px; }
.cal-date-btn { background: none; border: 1px solid var(--border2); border-radius: var(--radius-sm); color: var(--muted-foreground); cursor: pointer; font-family: var(--font-mono); font-size: 0.58rem; font-weight: 700; letter-spacing: 0.04em; padding: 3px 9px; transition: all 0.15s; white-space: nowrap; }
.cal-date-btn:hover { border-color: #888; color: #bbb; }
.cal-date-btn.active { border-color: var(--accent); color: var(--accent); background: rgba(0,178,150,0.08); }

/* ══════════════════════════════════════════════════════════════
   CAPITAL FLOW PANEL (2 separate cards)
   ══════════════════════════════════════════════════════════════ */

/* Container for both cards */
#capital-flow-container {
  display: flex;
  flex-direction: column;
  gap: 8px;
  height: fit-content;
  background: var(--panel-bg);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  border: 1px solid var(--border);
  border-radius: 14px;
  position: relative;
  transition: background 0.25s, box-shadow 0.25s, transform 0.25s;
}

#capital-flow-container::before {
  content: '';
  position: absolute;
  inset: -1px;
  border-radius: inherit;
  padding: 1px;
  background: conic-gradient(
    from var(--gradient-border-angle),
    transparent 0deg,
    transparent 270deg,
    oklch(from var(--animation-color) l c h / 0.9) 300deg,
    transparent 360deg
  );
  -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  -webkit-mask-composite: xor;
  mask-composite: exclude;
  pointer-events: none;
  z-index: 0;
  opacity: 0;
}

#capital-flow-container:hover::before {
  animation: border-spin 1.2s linear 1;
  opacity: 1;
}

/* Shared card styling for both For You and Capital Flow cards */
.cf-card {
  border-radius: 14px;
  overflow: visible;
  position: relative;
  transition: background 0.25s, box-shadow 0.25s, transform 0.25s;
  padding: 20px 24px 0px;
}

.cf-card::before {
  content: '';
  position: absolute;
  inset: -1px;
  border-radius: inherit;
  padding: 1px;
  background: conic-gradient(
    from var(--gradient-border-angle),
    transparent 0deg,
    transparent 270deg,
    oklch(from var(--animation-color) l c h / 0.9) 300deg,
    transparent 360deg
  );
  -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  -webkit-mask-composite: xor;
  mask-composite: exclude;
  pointer-events: none;
  z-index: 0;
  opacity: 0;
}

/* Capital Flow list card */
#cf-list-card {
  flex: 1;
  display: flex;
  flex-direction: column;
  min-height: 0;
  padding: 0;
}

#cf-list-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 18px 24px 14px;
  flex-shrink: 0;
  flex-wrap: wrap;
  gap: 8px;
}

.cf-list-title-group {
  display: flex;
  align-items: center;
  gap: 10px;
}

.cf-list-subtitle {
  font-size: 0.55rem;
  color: var(--muted-foreground);
  letter-spacing: 0.1em;
  text-transform: uppercase;
}

#cf-list-content {
  flex: 1;
  overflow-y: auto;
  padding: 32px 20px 16px;
  scrollbar-width: thin;
  scrollbar-color: var(--border2) transparent;
  min-height: 0;
  position: relative;
}

/* Live badge positioned top right within cf-list-content */
.cf-live-badge {
  position: absolute;
  top: 0px;
  right: 20px;
  z-index: 10;
}
.cf-row { display: flex; align-items: center; gap: 10px; padding: 7px 0; border-bottom: 1px solid rgba(255,255,255,0.025); }
.cf-row:last-child { border-bottom: none; }
.cf-label { font-family: var(--font-mono); font-size: 0.65rem; font-weight: 700; color: var(--text); width: 68px; flex-shrink: 0; letter-spacing: 0.03em; }
.cf-bar-track { flex: 1; height: 5px; background: rgba(255,255,255,0.06); border-radius: 3px; position: relative; overflow: visible; }
.cf-bar-fill { position: absolute; top: 0; height: 100%; border-radius: 3px; transition: width 0.7s cubic-bezier(0.4,0,0.2,1); min-width: 2px; }
.cf-bar-fill.positive { left: 50%; background: linear-gradient(90deg, rgba(0,178,150,0.5) 0%, var(--accent) 100%); }
.cf-bar-fill.negative { right: 50%; background: linear-gradient(270deg, rgba(240,90,126,0.5) 0%, var(--accent2) 100%); }
.cf-center-line { position: absolute; left: 50%; top: -4px; bottom: -4px; width: 1px; background: rgba(255,255,255,0.1); transform: translateX(-50%); pointer-events: none; }
.cf-value { font-family: var(--font-mono); font-size: 0.65rem; font-weight: 700; width: 52px; text-align: right; flex-shrink: 0; }
.cf-value.positive { color: var(--accent); }
.cf-value.negative { color: var(--accent2); }
.cf-value.flat     { color: var(--muted-foreground); }

/* CF Briefing */
#cf-briefing-card { flex-shrink: 0; }
.cf-briefing-top { display: flex; align-items: center; justify-content: space-between; margin-bottom: 14px; gap: 8px; flex-wrap: wrap; }
.cf-briefing-title { font-family: var(--font-sans); font-weight: 700; font-size: 0.78rem; color: var(--foreground); display: flex; align-items: center; gap: 6px; }
.cf-briefing-subtitle { font-size: 0.55rem; color: var(--muted-foreground); letter-spacing: 0.1em; text-transform: uppercase; }
.cf-briefing-date { font-size: 0.58rem; color: var(--muted-foreground); letter-spacing: 0.06em; display: flex; align-items: center; gap: 4px; }
.cf-briefing-mood { display: flex; align-items: center; gap: 5px; font-size: 0.6rem; letter-spacing: 0.04em; flex-shrink: 0; }
.cf-mood-pill { padding: 2px 8px; border-radius: 20px; border: 1px solid var(--border2); color: var(--muted-foreground); font-weight: 600; }
.cf-mood-pill.neutral   { border-color: rgba(200,168,75,0.4); color: #c8a84b; background: rgba(200,168,75,0.06); }
.cf-mood-pill.risk-on   { border-color: rgba(0,178,150,0.4); color: var(--accent); background: rgba(0,178,150,0.06); }
.cf-mood-pill.bullish   { border-color: rgba(0,178,150,0.4); color: var(--accent); background: rgba(0,178,150,0.06); }
.cf-mood-pill.risk-off  { border-color: rgba(240,90,126,0.4); color: var(--accent2); background: rgba(240,90,126,0.06); }
.cf-mood-pill.bearish   { border-color: rgba(240,90,126,0.4); color: var(--accent2); background: rgba(240,90,126,0.06); }
.cf-mood-pill.cautious  { border-color: rgba(240,160,40,0.4); color: #f0a028; background: rgba(240,160,40,0.06); }
.cf-mood-arrow { color: var(--muted-foreground); font-size: 0.65rem; }
.cf-briefing-headline { font-family: var(--font-sans); font-weight: 700; font-size: 1.15rem; color: var(--foreground); line-height: 1.4; margin-bottom: 14px; letter-spacing: -0.01em; }
.cf-briefing-body { font-size: 0.72rem; color: var(--text); line-height: 1.7; opacity: 0.85; }
.cf-read-more { color: var(--accent); cursor: pointer; font-weight: 600; margin-left: 4px; }
.cf-read-more:hover { text-decoration: underline; }
.cf-briefing-sub { font-size: 0.55rem; color: var(--muted-foreground); letter-spacing: 0.1em; text-transform: uppercase; margin-bottom: 2px; }

/* ══════════════════════════════════════════════════════════════
   FOOTER
   ══════════════════════════════════════════════════════════════ */

footer {
  border-top: 1px solid var(--border);
  padding: 12px 32px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: 0.6rem;
  color: var(--muted-foreground);
  letter-spacing: 0.1em;
  margin-top: 28px;
  flex-shrink: 0;
}
.refresh-indicator { display: flex; align-items: center; gap: 6px; }
.refresh-dot { width: 5px; height: 5px; border-radius: 50%; background: var(--muted-foreground); }
.refresh-dot.active { background: var(--accent); animation: pulse 0.5s ease-in-out; }

/* ══════════════════════════════════════════════════════════════
   WEEKEND BANNER
   ══════════════════════════════════════════════════════════════ */

#weekend-banner {
  display: none;
  background: linear-gradient(180deg, rgba(20,12,6,0.98) 0%, rgba(15,9,4,0.95) 100%);
  border-bottom: 1px solid #2a1a08;
  padding: 22px 32px;
  flex-shrink: 0;
}
#weekend-banner .wk-inner    { max-width: 600px; margin: 0 auto; text-align: center; }
#weekend-banner .wk-icon     { font-size: 1.4rem; margin-bottom: 6px; }
#weekend-banner .wk-title    { font-size: 0.85rem; font-weight: 700; color: #4a3010; letter-spacing: 0.25em; text-transform: uppercase; margin-bottom: 8px; }
#weekend-banner .wk-countdown { font-size: 2.2rem; font-weight: 700; color: #3a2808; font-variant-numeric: tabular-nums; letter-spacing: 0.08em; line-height: 1; margin-bottom: 6px; }
#weekend-banner .wk-hint     { font-size: 0.6rem; color: #2a1e08; letter-spacing: 0.15em; text-transform: uppercase; }
#weekend-banner .wk-divider  { height: 1px; background: linear-gradient(90deg, transparent, #2a1a08 30%, #2a1a08 70%, transparent); margin: 12px 0; }

/* ══════════════════════════════════════════════════════════════
   MOBILE NAV
   ══════════════════════════════════════════════════════════════ */

#mobile-nav-toggle {
  display: none;
  background: transparent;
  border: 1px solid var(--border2);
  border-radius: 6px;
  padding: 8px;
  cursor: pointer;
  color: var(--text);
  flex-shrink: 0;
  transition: all 0.2s;
}
#mobile-nav-toggle:hover {
  border-color: var(--accent);
  color: var(--accent);
}

/* Header clocks (mobile only) */
.header-clocks {
  display: none;
  align-items: center;
  gap: 12px;
  margin-right: 8px;
}
.header-clock-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 1px;
}
.header-clock-value {
  font-family: var(--font-mono);
  font-size: 0.75rem;
  color: var(--emerald-500);
  font-weight: 600;
  letter-spacing: 0.03em;
  font-variant-numeric: tabular-nums;
}
.header-clock-item:last-child .header-clock-value {
  color: #9ca3af;
}
.header-clock-label {
  font-size: 0.45rem;
  color: var(--muted-foreground);
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

#nav-backdrop {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.6);
  z-index: 240;
}
#nav-backdrop.visible { display: block; }

/* ══════════════════════════════════════════════════════════════
   SHARED UTILITY CLASSES
   Design System Components
   ══════════════════════════════════════════════════════════════ */

/* ── Panel / Card with Hover Glow ── */
.panel {
  background: var(--panel-bg);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  border: 1px solid var(--border);
  border-radius: 0.75rem;
  position: relative;
  overflow: visible;
  transition: transform 0.2s ease;
}
.panel::before {
  content: '';
  position: absolute;
  inset: -1px;
  border-radius: inherit;
  padding: 1px;
  background: conic-gradient(
    from -10deg,
    rgba(228, 255, 248, 0.10),
    rgba(0, 136, 114, 0.07),
    rgba(228, 255, 248, 0.02),
    rgba(0, 136, 114, 0.05)
  );
  -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  -webkit-mask-composite: xor;
  mask-composite: exclude;
  pointer-events: none;
  z-index: 1;
  opacity: 0;
  transition: opacity 0.3s ease;
}

@keyframes glow-rotate {
  0% { background-position: 0% 50%; filter: blur(0px); }
  50% { background-position: 100% 50%; filter: blur(1px); }
  100% { background-position: 200% 50%; filter: blur(0px); }
}

/* ── Buttons ── */
.btn {
  padding: 10px 20px;
  border-radius: var(--radius-sm);
  font-family: var(--font-sans);
  font-size: 0.7rem;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  cursor: pointer;
  transition: all 0.2s;
  border: none;
  display: inline-flex;
  align-items: center;
  gap: 8px;
}
.btn:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}
.btn svg { width: 14px; height: 14px; }

.btn-primary {
  background: var(--accent);
  color: #000;
  border: none;
}
.btn-primary:hover { filter: brightness(1.1); }
.btn-primary:hover:not(:disabled) { background: #4dd8b0; }

.btn-secondary {
  background: transparent;
  border: 1px solid var(--border2);
  color: var(--muted-foreground);
}
.btn-secondary:hover { border-color: var(--accent); color: var(--accent); }

.btn-danger {
  background: transparent;
  border: 1px solid rgba(240,90,126,0.4);
  color: var(--accent2);
}
.btn-danger:hover { background: rgba(240,90,126,0.1); border-color: var(--accent2); }

.btn-link {
  background: transparent;
  color: var(--muted-foreground);
  padding: 10px;
  border: none;
}
.btn-link:hover { color: var(--accent); }

/* ── Tab Buttons ── */
.tab-btn {
  padding: 10px 20px;
  background: transparent;
  border: 1px solid var(--border);
  border-radius: 8px;
  color: var(--muted-foreground);
  font-family: var(--font-sans);
  font-size: 0.65rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  cursor: pointer;
  transition: all 0.15s;
}
.tab-btn:hover { border-color: var(--border2); color: var(--foreground); }
.tab-btn.active {
  background: rgba(90,240,196,0.1);
  border-color: rgba(90,240,196,0.3);
  color: var(--accent);
}
.tab-count {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 18px;
  height: 18px;
  padding: 0 5px;
  margin-left: 8px;
  background: rgba(255,255,255,0.1);
  border-radius: 10px;
  font-size: 0.55rem;
}
.tab-btn.active .tab-count { background: rgba(90,240,196,0.2); }

/* ── Form Elements ── */
.form-group { margin-bottom: 16px; }
.form-label {
  display: block;
  font-size: 0.65rem;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--muted-foreground);
  margin-bottom: 6px;
}
.form-input,
.form-select,
.form-textarea {
  width: 100%;
  background: var(--background);
  border: 1px solid var(--border2);
  border-radius: var(--radius-sm);
  padding: 10px 14px;
  color: var(--foreground);
  font-family: var(--font-sans);
  font-size: 0.80rem;
  outline: none;
  transition: border-color 0.15s;
}
.form-input:focus,
.form-select:focus,
.form-textarea:focus { border-color: rgba(0,178,150,0.5); }
.form-input::placeholder,
.form-textarea::placeholder { color: var(--muted-foreground); }
.form-textarea { resize: vertical; min-height: 80px; }
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }

.form-checkbox {
  display: flex;
  align-items: center;
  gap: 10px;
}
.form-checkbox input[type="checkbox"] {
  width: 18px;
  height: 18px;
  accent-color: var(--accent);
}
.form-checkbox label {
  font-size: 0.75rem;
  color: var(--foreground);
}

/* ── Modal ── */
.modal-backdrop {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.8);
  display: none;
  align-items: center;
  justify-content: center;
  z-index: 1000;
  padding: 20px;
}
.modal-backdrop.visible { display: flex; }
.modal {
  background: var(--surface);
  border: 1px solid var(--border2);
  border-radius: var(--radius-lg);
  width: 100%;
  max-width: 520px;
  max-height: 90vh;
  overflow-y: auto;
}
.modal-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 20px 24px;
  border-bottom: 1px solid var(--border);
}
.modal-title {
  font-size: 1rem;
  font-weight: 600;
  color: var(--foreground);
}
.modal-close {
  background: none;
  border: none;
  color: var(--muted-foreground);
  cursor: pointer;
  font-size: 1.2rem;
  padding: 4px;
  transition: color 0.15s;
}
.modal-close:hover { color: var(--foreground); }
.modal-body { padding: 24px; }
.modal-footer {
  display: flex;
  gap: 12px;
  justify-content: flex-end;
  padding: 16px 24px;
  border-top: 1px solid var(--border);
}

/* ── KPI / Stat Card ── */
.kpi-card {
  background: var(--card-bg);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  border: none;
  border-radius: 14px;
  padding: 20px;
  display: flex; flex-direction: column; gap: 14px;
  transition: transform 0.2s ease, box-shadow 0.2s ease;
  position: relative; 
  overflow: visible;
  box-shadow: 0 0 0 1px rgba(60, 60, 60, 0.5), inset 0 0 20px rgba(50, 50, 50, 0.3), inset 0 0 0 1000px rgba(20, 22, 26, 0.30);
}
.kpi-card::before {
  content: '';
  position: absolute;
  inset: -1px;
  border-radius: inherit;
  padding: 1px;
  background: conic-gradient(
    from -10deg,
    rgba(228, 255, 248, 0.10),
    rgba(0, 136, 114, 0.07),
    rgba(228, 255, 248, 0.02),
    rgba(0, 136, 114, 0.05)
  );
  -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  -webkit-mask-composite: xor;
  mask-composite: exclude;
  pointer-events: none;
  z-index: 1;
  opacity: 0; /* ← hidden by default */
  transition: opacity 0.3s ease;
}
.kpi-card:hover {
  transform: translateY(-1px);
}
.kpi-card:hover::before {
  opacity: 1;
  background: conic-gradient(
    from var(--gradient-border-angle),
    transparent 0deg,
    transparent 270deg,
    oklch(from var(--animation-color) l c h / 0.9) 300deg,
    transparent 360deg
  );
  animation: border-spin 1.2s linear 1;
}
.kpi-card-label {
  font-size: 0.60rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--muted-foreground);
  margin-bottom: 6px;
}
.kpi-card-value {
  font-size: 1.40rem;
  font-weight: 700;
  color: var(--foreground);
}
.kpi-card-value.accent { color: var(--accent); }
.kpi-card-value.danger { color: var(--accent2); }
.kpi-card-value.blue { color: var(--blue); }

/* ── Badges ── */
.badge {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 3px 9px;
  border-radius: 20px;
  font-size: 0.58rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  border: 1px solid;
}
.badge-success { color: var(--accent); border-color: rgba(0,178,150,0.4); background: rgba(0,178,150,0.08); }
.badge-danger { color: var(--accent2); border-color: rgba(240,90,126,0.4); background: rgba(240,90,126,0.08); }
.badge-info { color: var(--blue); border-color: rgba(90,158,240,0.4); background: rgba(90,158,240,0.08); }
.badge-warning { color: #f0a028; border-color: rgba(240,160,40,0.4); background: rgba(240,160,40,0.08); }
.badge-neutral { color: var(--muted-foreground); border-color: var(--border2); background: transparent; }

.status-badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 6px 12px;
  border-radius: 6px;
  font-size: 0.6rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}
.status-badge .status-dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: currentColor;
}
.status-badge.waiting-entry { background: rgba(90,158,240,0.15); color: var(--blue); }
.status-badge.waiting-result { background: rgba(255,200,100,0.15); color: #ffc864; }
.status-badge.take-profit { background: rgba(90,240,196,0.15); color: var(--accent); }
.status-badge.stop-loss { background: rgba(240,90,126,0.15); color: var(--accent2); }
.status-badge.expired { background: rgba(255,255,255,0.05); color: var(--muted-foreground); }
.status-badge.waiting-entry .status-dot,
.status-badge.waiting-result .status-dot { animation: pulse 1.5s ease-in-out infinite; }

/* ── Typography Helpers ── */
.page-title {
  font-family: var(--font-display);
  font-weight: 800;
  font-size: 1.1rem;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--accent);
  line-height: 1;
  margin-bottom: 0;
}
.page-subtitle {
  font-size: 0.65rem;
  color: var(--muted-foreground);
  letter-spacing: 0.2em;
  text-transform: uppercase;
  margin-top: 3px;
}
.section-title {
  font-size: 0.85rem;
  font-weight: 700;
  color: var(--foreground);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  margin-bottom: 8px;
  display: flex;
  align-items: center;
  gap: 10px;
}
.section-title svg { color: var(--accent); }
.section-description {
  font-size: 0.7rem;
  color: var(--muted-foreground);
  margin-bottom: 20px;
  line-height: 1.6;
}

/* ── Empty State ── */
.empty-state {
  text-align: center;
  padding: 60px 20px;
  color: var(--muted-foreground);
}
.empty-state svg {
  width: 48px;
  height: 48px;
  margin: 0 auto 16px;
  opacity: 0.3;
}
.empty-state-title {
  font-size: 0.9rem;
  font-weight: 600;
  margin-bottom: 8px;
  color: var(--foreground);
}
.empty-state-text {
  font-size: 0.75rem;
  max-width: 360px;
  margin: 0 auto 16px;
}
.empty-state .btn { margin-top: 8px; }

/* ── Alert Messages ── */
.alert {
  padding: 14px 18px;
  border-radius: var(--radius-sm);
  margin-bottom: 20px;
  font-size: 0.75rem;
  display: flex;
  align-items: center;
  gap: 10px;
  animation: fadeIn 0.3s ease;
}
@keyframes fadeIn {
  from { opacity: 0; transform: translateY(-10px); }
  to { opacity: 1; transform: translateY(0); }
}
.alert-success {
  background: rgba(90, 240, 196, 0.1);
  border: 1px solid rgba(90, 240, 196, 0.3);
  color: var(--accent);
}
.alert-error {
  background: rgba(240, 90, 126, 0.1);
  border: 1px solid rgba(240, 90, 126, 0.3);
  color: var(--accent2);
}
.alert-warning {
  background: rgba(240, 160, 40, 0.1);
  border: 1px solid rgba(240, 160, 40, 0.3);
  color: #f0a028;
}
.alert-info {
  background: rgba(90, 158, 240, 0.1);
  border: 1px solid rgba(90, 158, 240, 0.3);
  color: var(--blue);
}

/* ── Back Link ── */
.back-link {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  color: var(--muted-foreground);
  text-decoration: none;
  font-size: 0.7rem;
  margin-bottom: 20px;
  transition: color 0.2s;
}
.back-link:hover { color: var(--accent); }

/* ── Loading State ── */
.loading { opacity: 0.6; pointer-events: none; }
.spinner {
  width: 16px;
  height: 16px;
  border: 2px solid var(--border2);
  border-top-color: var(--accent);
  border-radius: 50%;
  animation: spin 0.8s linear infinite;
}

/* ══════════════════════════════════════════════════════════════
   ANIMATIONS
   ══════════════════════════════════════════════════════════════ */

@keyframes pulse   { 0%, 100% { opacity: 1; } 50% { opacity: 0.4; } }
@keyframes spin    { to { transform: rotate(360deg); } }
@keyframes fadeUp  { from { opacity: 0; transform: translateY(5px); } to { opacity: 1; transform: translateY(0); } }
@keyframes flash   { 0%, 100% { opacity: 1; } 50% { opacity: 0.7; } }
@keyframes shimmer { 0%{background-position:200% 0} 100%{background-position:-200% 0} }
@property --gradient-border-angle { syntax: '<angle>'; inherits: false; initial-value: -10deg; }

@keyframes border-spin {
  0%   { --gradient-border-angle: 0deg; }
  100% { --gradient-border-angle: 360deg; }
}
/* ══════════════════════════════════════════════════════════════
   SKELETON LOADER
   ══════════════════════════════════════════════════════════════ */

.skel {
  background: linear-gradient(90deg, var(--border) 0%, var(--border2) 50%, var(--border) 100%);
  background-size: 200% 100%;
  animation: shimmer 1.4s infinite;
  border-radius: 4px;
  display: block;
}

/* ══════════════════════════════════════════════════════════════
   SCROLLBAR GLOBAL
   ══════════════════════════════════════════════════════════════ */

* { scrollbar-width: thin; scrollbar-color: var(--border2) transparent; }
*::-webkit-scrollbar { width: 4px; height: 4px; }
*::-webkit-scrollbar-thumb { background: var(--border2); border-radius: 2px; }

/* ══════════════════════════════════════════════════════════════
   LAYOUT FIXES
   ══════════════════════════════════════════════════════════════ */

html, body { height: 100%; }

#app { min-height: 100vh; }

#app-body {
  display: flex;
  flex-direction: row;
  min-height: calc(100vh - 50px);
}

#side-nav {
  position: fixed !important;
  top: 0;
  left: 0;
  height: 100vh !important;
  width: 130px;
  z-index: 200;
  overflow-y: auto;
  overflow-x: hidden;
}

#top-header ~ #app-body #side-nav,
#app > #top-header + #app-body #side-nav {
  top: 50px;
  height: calc(100vh - 50px) !important;
}

#main-content {
  margin-left: 130px !important;
  height: 100vh;
  overflow-y: auto;
  overflow-x: hidden;
  background-image: var(--background-radial);
  background-attachment: fixed;
  background-repeat: no-repeat;
}

/* ══════════════════════════════════════════════════════════════
   PERSONALIZE MODE
   ══════════════════════════════════════════════════════════════ */

#personalize-btn:hover {
  border-color: var(--accent);
  color: var(--accent);
}

.dashboard-panel {
  transition: all 0.2s ease;
}

.dashboard-panel.personalize-active {
  position: relative;
  cursor: grab;
  border: 2px dashed transparent;
  border-radius: 12px;
  margin: 4px 0;
  padding: 4px;
}

.dashboard-panel.personalize-active::before {
  content: '';
  position: absolute;
  inset: 0;
  border: 2px dashed var(--accent);
  border-radius: 12px;
  pointer-events: none;
  opacity: 0.4;
  z-index: 10;
}

.dashboard-panel.personalize-active:hover::before {
  opacity: 0.8;
}

.dashboard-panel.dragging {
  opacity: 0.5;
  cursor: grabbing;
}

.dashboard-panel.dragging::before {
  border-style: solid;
  opacity: 1;
}

.dashboard-panel.drag-over::before {
  border-color: var(--accent);
  opacity: 1;
  background: rgba(90, 240, 196, 0.05);
}

/* ══════════════════════════════════════════════════════════════
   RESPONSIVE
   ══════════════════════════════════════════════════════════════ */

@media (max-width: 1024px) {
  .grid { grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); padding: 16px 20px 0; gap: 10px; }
  #intel-row { grid-template-columns: 1fr; padding: 0 20px; }
  #trump-assistant-row { grid-template-columns: 1fr; padding: 0 20px; }
  #calendar-row { grid-template-columns: 1fr !important; padding: 20px; }
  #cstrength-panel, #fj-panel, #trump-panel, #assistant-panel { height: 320px; min-height: 320px; max-height: 320px; }
}

@media (max-width: 768px) {
  #mobile-nav-toggle { display: flex; }
  .header-clocks { display: flex; }
  .time-display { display: none; }
  #side-nav { position: fixed; left: -200px; top: 0; width: 200px; min-width: 200px; height: 100vh; z-index: 250; transition: left 0.3s ease; box-shadow: 4px 0 20px rgba(0,0,0,0.5); background: #000; }
  #app:has(#top-header) #side-nav { top: 50px; height: calc(100vh - 50px); }
  #side-nav.mobile-open { left: 0; }
  /* Mobile nav item styling - horizontal layout with icon on left */
  #side-nav .nav-item { flex-direction: row; justify-content: flex-start; gap: 10px; padding: 12px 16px; text-align: left; border-left: none; }
  #side-nav .nav-item.active { border-left: none; background: rgba(0, 206, 174, 0.08); }
  #side-nav .nav-icon { width: 18px; height: 18px; }
  #side-nav .nav-icon svg { width: 16px; height: 16px; }
  #side-nav .nav-label { font-size: 0.58rem; text-align: left; }
  #side-nav .nav-item--bottom { font-size: 0.55rem; }
  /* AI Market Desk panel padding fix */
  .panel[style*="margin: 0 32px"] { margin: 0 16px 16px !important; padding: 16px !important; }
  #main-content { margin-left: 0 !important; width: 100%; }
  .welcome-section { padding: 14px 16px; }
  .welcome-title { font-size: 1.6rem; }
  .sessions-card { margin: 0 16px 16px; padding: 12px 16px; flex-direction: column; gap: 12px; }
  .sessions-bar { gap: 16px; flex-wrap: wrap; }
  .grid { grid-template-columns: 1fr; padding: 12px 16px 0 !important; gap: 10px; }
  .card { padding: 16px 18px; border-radius: 12px; }
  #intel-row, #trump-assistant-row { padding: 0 16px; gap: 10px; }
  footer { padding: 10px 16px; flex-direction: column; gap: 8px; text-align: center; margin-top: 20px; }
  #top-header { padding: 10px 16px; gap: 12px; }
  .top-header-logo-text { font-size: 0.85rem; }
  /* Personalize button responsive */
  #personalize-container { margin: 0 16px 12px !important; }
  #personalize-toolbar { flex-direction: column; gap: 10px; padding: 12px !important; }
  #personalize-toolbar > div:last-child { width: 100%; justify-content: center; }
}

@media (max-width: 480px) {
  .welcome-title { font-size: 1.3rem; }
  .pair-name { font-size: 1.15rem; }
  .price { font-size: 1.3rem; }
}

@media (hover: none) and (pointer: coarse) {
  .card:hover { transform: none; }
  .nav-item:hover { background: none; }
}

/* Tailwind utility classes kept from original */
.bg-background{background-color:var(--background)}.bg-foreground{background-color:var(--foreground)}.bg-card{background-color:var(--card)}.bg-muted{background-color:var(--muted)}.bg-accent{background-color:var(--accent)}.bg-sidebar{background-color:var(--sidebar)}.bg-popover{background-color:var(--popover)}.bg-secondary{background-color:var(--secondary)}.bg-input{background-color:var(--input)}.text-foreground{color:var(--foreground)}.text-card-foreground{color:var(--card-foreground)}.text-muted-foreground{color:var(--muted-foreground)}.text-accent-foreground{color:var(--accent-foreground)}.text-sidebar-foreground{color:var(--sidebar-foreground)}.text-popover-foreground{color:var(--popover-foreground)}.text-title{color:var(--title)}.border-border{border-color:var(--border)}.border-sidebar-border{border-color:var(--sidebar-border)}.border-input{border-color:var(--input)}.ring-ring{--tw-ring-color:var(--ring)}.badge-bullish{border-style:var(--tw-border-style);border-width:1px;border-color:#006b594d;border-radius:3.40282e38px;background-color:#006b5933;padding-inline:calc(var(--spacing) * 2);padding-block:calc(var(--spacing) * .5);font-size:var(--text-xs);line-height:var(--tw-leading,var(--text-xs--line-height));font-weight:500;color:var(--color-primary-400)}.badge-neutral{padding-inline:calc(var(--spacing) * 2);padding-block:calc(var(--spacing) * .5);font-size:var(--text-xs);line-height:var(--tw-leading,var(--text-xs--line-height));font-weight:500;background-color:var(--muted);color:var(--muted-foreground);border:1px solid var(--border);border-radius:3.40282e38px}.badge-bearish{border-style:var(--tw-border-style);border-width:1px;border-color:#82181a4d;border-radius:3.40282e38px;background-color:#82181a33;padding-inline:calc(var(--spacing) * 2);padding-block:calc(var(--spacing) * .5);font-size:var(--text-xs);line-height:var(--tw-leading,var(--text-xs--line-height));font-weight:500;color:var(--color-red-400)}.btn-primary{padding-inline:calc(var(--spacing) * 4);padding-block:calc(var(--spacing) * 2);font-weight:500;transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.2s;background-color:var(--primary-600);color:#fff;border-radius:var(--radius)}.btn-primary:hover{background-color:var(--primary-700)}.btn-ghost{padding-inline:calc(var(--spacing) * 4);padding-block:calc(var(--spacing) * 2);font-weight:500;transition-property:color,background-color,border-color;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.2s;border:1px solid var(--border);color:var(--foreground);border-radius:var(--radius);background-color:#0000}.btn-ghost:hover{background-color:var(--muted)}.input{padding-inline:calc(var(--spacing) * 3);padding-block:calc(var(--spacing) * 2);background-color:var(--input);border:1px solid var(--border);border-radius:var(--radius);color:var(--foreground)}.input::placeholder{color:var(--muted-foreground)}.progress-track{height:calc(var(--spacing) * 1.5);background-color:var(--muted);border-radius:3.40282e38px;width:100%}.progress-fill{background-color:var(--primary-500);border-radius:3.40282e38px;height:100%}

@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-outline-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-blur{syntax:"*";inherits:false}@property --tw-brightness{syntax:"*";inherits:false}@property --tw-contrast{syntax:"*";inherits:false}@property --tw-grayscale{syntax:"*";inherits:false}@property --tw-hue-rotate{syntax:"*";inherits:false}@property --tw-invert{syntax:"*";inherits:false}@property --tw-opacity{syntax:"*";inherits:false}@property --tw-saturate{syntax:"*";inherits:false}@property --tw-sepia{syntax:"*";inherits:false}@property --tw-drop-shadow{syntax:"*";inherits:false}@property --tw-drop-shadow-color{syntax:"*";inherits:false}@property --tw-drop-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-drop-shadow-size{syntax:"*";inherits:false}@property --tw-backdrop-blur{syntax:"*";inherits:false}@property --tw-backdrop-brightness{syntax:"*";inherits:false}@property --tw-backdrop-contrast{syntax:"*";inherits:false}@property --tw-backdrop-grayscale{syntax:"*";inherits:false}@property --tw-backdrop-hue-rotate{syntax:"*";inherits:false}@property --tw-backdrop-invert{syntax:"*";inherits:false}@property --tw-backdrop-opacity{syntax:"*";inherits:false}@property --tw-backdrop-saturate{syntax:"*";inherits:false}@property --tw-backdrop-sepia{syntax:"*";inherits:false}@property --tw-ease{syntax:"*";inherits:false}@property --tw-font-weight{syntax:"*";inherits:false}@property --tw-duration{syntax:"*";inherits:false}@property --tw-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-shadow-color{syntax:"*";inherits:false}@property --tw-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-inset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-shadow-color{syntax:"*";inherits:false}@property --tw-inset-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-ring-color{syntax:"*";inherits:false}@property --tw-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-ring-color{syntax:"*";inherits:false}@property --tw-inset-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-ring-inset{syntax:"*";inherits:false}@property --tw-ring-offset-width{syntax:"<length>";inherits:false;initial-value:0}@property --tw-ring-offset-color{syntax:"*";inherits:false;initial-value:#fff}@property --tw-ring-offset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-tracking{syntax:"*";inherits:false}@property --tw-leading{syntax:"*";inherits:false}
