/* ============================================================
   DXCELL · VFT — Claude Polish Layer
   Loads AFTER terminal-ui.css. Does not change DOM structure or
   element IDs — only refines typography, hierarchy, color, and
   micro-interactions to give the whole VFT deck a coherent,
   considered feel.

   Design principles:
   1. Information hierarchy: small label → big value → state → note
   2. Subtle bias signalling (left-edge accent + tint, not gaudy glow)
   3. Tabular monospaced numerals for every numeric readout
   4. Quiet motion: a single ambient pulse on the deck-live dot
   5. Honest empty states (em-dash treated as a placeholder, not data)
   ============================================================ */

/* ---------- Design tokens ---------- */
.dxVftDeck{
  /* Palette — refined, less neon, more financial-instrument */
  --vft-bull:        #5BD6A0;
  --vft-bull-soft:   rgba(91, 214, 160, .14);
  --vft-bull-edge:   rgba(91, 214, 160, .42);
  --vft-bear:        #FF7C92;
  --vft-bear-soft:   rgba(255, 124, 146, .14);
  --vft-bear-edge:   rgba(255, 124, 146, .42);
  --vft-flat:        #E8DEC8;          /* warm ivory */
  --vft-flat-soft:   rgba(232, 222, 200, .12);
  --vft-flat-edge:   rgba(232, 222, 200, .35);
  --vft-accent:      #7AC8FF;          /* steel-blue active */
  --vft-accent-soft: rgba(122, 200, 255, .14);
  --vft-accent-edge: rgba(122, 200, 255, .42);

  /* Text ramp */
  --vft-t1: rgba(245, 248, 252, .96);  /* primary — values */
  --vft-t2: rgba(232, 240, 252, .82);  /* secondary — state */
  --vft-t3: rgba(212, 225, 240, .60);  /* tertiary — notes */
  --vft-t4: rgba(196, 214, 232, .40);  /* quaternary — labels */
  --vft-t5: rgba(180, 200, 220, .26);  /* quietest — placeholders */

  /* Type system */
  --vft-mono: 'JetBrains Mono', 'SF Mono', 'Roboto Mono', 'IBM Plex Mono', ui-monospace, 'Courier New', monospace;
  --vft-sans: 'Inter', system-ui, -apple-system, BlinkMacSystemFont, sans-serif;

  /* Surfaces */
  --vft-card-bg: linear-gradient(180deg, rgba(255,255,255,.030), rgba(255,255,255,.008));
  --vft-card-bd: rgba(255,255,255,.07);
  --vft-card-bd-hover: rgba(255,255,255,.13);
}

/* ---------- Deck shell — refined ---------- */
.dxVftDeck{
  border-radius: 18px;
  background: linear-gradient(180deg, rgba(8,12,18,.90), rgba(6,9,14,.86));
  border: 1px solid rgba(255,255,255,.07);
  box-shadow:
    0 24px 70px rgba(0,0,0,.55),
    0 0 0 1px rgba(255,255,255,.025) inset;
  backdrop-filter: blur(14px) saturate(115%);
  -webkit-backdrop-filter: blur(14px) saturate(115%);
}

/* Bias glow — tighter, less neon */
.dxVftDeck.bias-bull{
  border-color: rgba(91, 214, 160, .22);
  background: linear-gradient(180deg, rgba(10,16,18,.90), rgba(6,11,14,.86));
  box-shadow:
    0 24px 70px rgba(0,0,0,.55),
    0 0 0 1px rgba(91, 214, 160, .07) inset,
    0 0 32px rgba(91, 214, 160, .10);
}
.dxVftDeck.bias-bear{
  border-color: rgba(255, 124, 146, .22);
  background: linear-gradient(180deg, rgba(16,11,14,.90), rgba(11,8,11,.86));
  box-shadow:
    0 24px 70px rgba(0,0,0,.55),
    0 0 0 1px rgba(255, 124, 146, .07) inset,
    0 0 32px rgba(255, 124, 146, .10);
}
.dxVftDeck.bias-neutral{
  border-color: rgba(232, 222, 200, .14);
  background: linear-gradient(180deg, rgba(11,12,14,.90), rgba(7,8,11,.86));
  box-shadow:
    0 24px 70px rgba(0,0,0,.55),
    0 0 0 1px rgba(232, 222, 200, .05) inset;
}

/* ---------- Header refinement ---------- */
.dxVftHead{
  padding: 11px 14px 10px;
  border-bottom: 1px solid rgba(255,255,255,.055);
}
.dxVftDeck.bias-bull  .dxVftHead{ border-bottom-color: rgba(91, 214, 160, .12); }
.dxVftDeck.bias-bear  .dxVftHead{ border-bottom-color: rgba(255, 124, 146, .12); }
.dxVftDeck.bias-neutral .dxVftHead{ border-bottom-color: rgba(232, 222, 200, .10); }

.dxVftTitle{
  font-family: var(--vft-sans);
  font-weight: 700;
  letter-spacing: .14em;
  font-size: 10px;
  text-transform: uppercase;
  color: var(--vft-t3);
  display: inline-flex;
  align-items: center;
  gap: 8px;
}
/* Live indicator dot — single ambient pulse on the whole deck */
.dxVftTitle::before{
  content: '';
  display: inline-block;
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--vft-accent);
  box-shadow: 0 0 8px rgba(122, 200, 255, .55);
  animation: vftLivePulse 2.6s ease-in-out infinite;
  flex: 0 0 6px;
}
.dxVftDeck.bias-bull  .dxVftTitle::before{ background: var(--vft-bull); box-shadow: 0 0 8px rgba(91, 214, 160, .55); }
.dxVftDeck.bias-bear  .dxVftTitle::before{ background: var(--vft-bear); box-shadow: 0 0 8px rgba(255, 124, 146, .55); }
.dxVftDeck.bias-neutral .dxVftTitle::before{ background: var(--vft-flat); box-shadow: 0 0 8px rgba(232, 222, 200, .35); }

@keyframes vftLivePulse{
  0%, 100%{ opacity: 1; transform: scale(1); }
  50%     { opacity: .50; transform: scale(.78); }
}
@media (prefers-reduced-motion: reduce){
  .dxVftTitle::before{ animation: none; }
}

/* ---------- Pills refinement ---------- */
.dxVftPills{ gap: 5px; }
.dxVftPill{
  font-family: var(--vft-sans);
  font-weight: 700;
  font-size: 10.5px;
  letter-spacing: .08em;
  padding: 5px 9px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.08);
  background: rgba(255,255,255,.025);
  color: var(--vft-t3);
  cursor: pointer;
  transition: color .15s ease, border-color .15s ease, background .15s ease, box-shadow .15s ease;
  white-space: nowrap;
}
.dxVftPill:hover{
  border-color: rgba(255,255,255,.18);
  color: var(--vft-t2);
  background: rgba(255,255,255,.05);
}
.dxVftPill.is-active{
  border-color: var(--vft-accent-edge);
  background: var(--vft-accent-soft);
  color: var(--vft-t1);
  box-shadow: 0 0 0 1px rgba(122, 200, 255, .14), 0 0 18px rgba(122, 200, 255, .14);
}
.dxVftDeck.bias-bull .dxVftPill.is-active{
  border-color: var(--vft-bull-edge);
  background: var(--vft-bull-soft);
  box-shadow: 0 0 0 1px rgba(91, 214, 160, .14), 0 0 18px rgba(91, 214, 160, .14);
}
.dxVftDeck.bias-bear .dxVftPill.is-active{
  border-color: var(--vft-bear-edge);
  background: var(--vft-bear-soft);
  box-shadow: 0 0 0 1px rgba(255, 124, 146, .14), 0 0 18px rgba(255, 124, 146, .14);
}
.dxVftDeck.bias-neutral .dxVftPill.is-active{
  border-color: var(--vft-flat-edge);
  background: var(--vft-flat-soft);
  box-shadow: 0 0 0 1px rgba(232, 222, 200, .12), 0 0 18px rgba(232, 222, 200, .10);
}

/* ---------- Header buttons ---------- */
.dxVftBtns{ gap: 5px; }
.dxVftBtn{
  width: 30px;
  height: 28px;
  border-radius: 9px;
  border: 1px solid rgba(255,255,255,.08);
  background: rgba(255,255,255,.025);
  color: var(--vft-t3);
  font-family: var(--vft-sans);
  font-weight: 800;
  font-size: 11px;
  letter-spacing: .04em;
  cursor: pointer;
  transition: all .15s ease;
}
.dxVftBtn:hover{
  border-color: rgba(255,255,255,.20);
  background: rgba(255,255,255,.05);
  color: var(--vft-t1);
}
.dxVftBtn.is-on,
html.dx-pro .dxVftBtn[id="dxVftConfig"]{
  border-color: var(--vft-bull-edge) !important;
  background: var(--vft-bull-soft) !important;
  color: rgba(91, 214, 160, .96);
  box-shadow: 0 0 0 1px rgba(91, 214, 160, .12);
}

/* ---------- Body + grid ---------- */
.dxVftBody{ padding: 10px 12px 12px; gap: 10px; }
.dxVftGrid{
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
}
/* Some VFTs use a "trend" grid — same idea but slightly wider gutter */
.dxVftGrid--trend{
  grid-template-columns: 1fr 1fr;
  gap: 10px;
}

/* ---------- Card refinement ---------- */
.dxVftCard{
  position: relative;
  padding: 12px 12px 11px 14px;       /* extra left padding for accent strip */
  border-radius: 12px;
  border: 1px solid var(--vft-card-bd);
  background: var(--vft-card-bg);
  display: flex;
  flex-direction: column;
  gap: 4px;
  overflow: hidden;
  transition: border-color .25s ease, background .25s ease;
}
.dxVftCard:hover{ border-color: var(--vft-card-bd-hover); }

/* Subtle inner highlight — makes the card feel premium without glow */
.dxVftCard::after{
  content:'';
  position:absolute;
  inset: 0;
  border-radius: 12px;
  pointer-events:none;
  background: radial-gradient(120% 60% at 50% -10%, rgba(255,255,255,.03), transparent 60%);
}

/* Left-edge accent strip — the signature bias signal */
.dxVftCard::before{
  content: '';
  position: absolute;
  left: 0; top: 12px; bottom: 12px;
  width: 2px;
  border-radius: 2px;
  background: linear-gradient(180deg, transparent, rgba(255,255,255,.08), transparent);
  transition: background .25s ease, box-shadow .25s ease;
  pointer-events: none;
}
.dxVftDeck.bias-bull .dxVftCard::before{
  background: linear-gradient(180deg, transparent 6%, var(--vft-bull) 32%, var(--vft-bull) 68%, transparent 94%);
  box-shadow: 0 0 8px rgba(91, 214, 160, .55);
}
.dxVftDeck.bias-bear .dxVftCard::before{
  background: linear-gradient(180deg, transparent 6%, var(--vft-bear) 32%, var(--vft-bear) 68%, transparent 94%);
  box-shadow: 0 0 8px rgba(255, 124, 146, .55);
}
.dxVftDeck.bias-neutral .dxVftCard::before{
  background: linear-gradient(180deg, transparent 6%, rgba(232, 222, 200, .55) 32%, rgba(232, 222, 200, .55) 68%, transparent 94%);
}

/* --- Content order inside cards: label always first --- */
/* Existing markup orders the dxVftLabel last; flex order flips it visually
   without touching the JS. */
.dxVftCard{
  /* default order anchors */
}
.dxVftCard > .dxVftLabel       { order: -2; margin-top: 0; margin-bottom: 2px; }
.dxVftCard > .dxVftBig         { order: -1; }
.dxVftCard > .dxVftBig--fit    { order: -1; }
.dxVftCard > .dxVftSub         { order: 0; }
.dxVftCard > .dxVftState       { order: 1; }
.dxVftCard > .dxVftNote        { order: 2; }
.dxVftCard > .dxVftLevels      { order: 3; }
.dxVftCard > .dxVftMeter       { order: 4; }
.dxVftCard > .dxFlowRow        { order: 5; }
.dxVftCard > .dxVftMiniRow     { order: 5; }

/* When card has a "label only" arrangement (e.g. small Tag fields after big number),
   keep the label visible by reusing same hierarchy */
.dxVftCard > .dxVftLabel + .dxVftLabel{ order: 6; opacity: .68; }

/* External (deck-footer) labels — outside any grid, used as
   a small signature for VFTs whose cards don't carry a label */
.dxVftBody > .dxVftLabel{
  order: 99;
  text-align: center;
  margin: 4px 2px 0;
  padding: 7px 6px 2px;
  font-family: var(--vft-sans);
  font-weight: 800;
  font-size: 9px;
  letter-spacing: .20em;
  text-transform: uppercase;
  color: var(--vft-t4);
  border-top: 1px dashed rgba(255,255,255,.06);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

/* ---------- Typography ---------- */
.dxVftBig,
.dxVftBig--fit{
  font-family: var(--vft-mono);
  font-weight: 600;
  font-size: clamp(26px, 3.4vw, 36px);
  letter-spacing: -.015em;
  line-height: 1.04;
  color: var(--vft-t1);
  font-variant-numeric: tabular-nums;
  font-feature-settings: "tnum", "ss01";
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
/* When the "big" slot contains a non-numeric word (BULLISH / BEARISH / etc),
   fall back to sans for better legibility */
.dxVftBig:not(:has(.numeric)){ /* progressive: harmless if :has() unsupported */ }

.dxVftSub{
  font-family: var(--vft-sans);
  font-weight: 600;
  font-size: 11.5px;
  letter-spacing: .01em;
  color: var(--vft-t3);
  margin-top: 3px;
  font-variant-numeric: tabular-nums;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.dxVftLabel{
  font-family: var(--vft-sans);
  font-weight: 800;
  font-size: 9.5px;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--vft-t4);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.dxVftState{
  font-family: var(--vft-sans);
  font-weight: 700;
  font-size: 12.5px;
  letter-spacing: .015em;
  color: var(--vft-t2);
  line-height: 1.25;
  font-variant-numeric: tabular-nums;
}
.dxVftState.is-bull   { color: var(--vft-bull); }
.dxVftState.is-bear   { color: var(--vft-bear); }
.dxVftState.is-neutral{ color: var(--vft-flat); }

.dxVftNote{
  font-family: var(--vft-sans);
  font-weight: 500;
  font-size: 11.5px;
  line-height: 1.42;
  color: var(--vft-t3);
  font-feature-settings: "tnum";
}

.dxVftLevels{
  font-family: var(--vft-mono);
  font-weight: 500;
  font-size: 10.5px;
  line-height: 1.5;
  color: var(--vft-t3);
  font-variant-numeric: tabular-nums;
  letter-spacing: .005em;
}

/* Em-dash placeholder treatment — make the live readout feel honest.
   When a value is just '—', render it dimmer + slightly smaller so it
   reads as awaiting-data, not as data. */
.dxVftBig:where(:not([data-loaded])){ /* hook for future, no-op today */ }

/* ---------- Meter refinement ---------- */
.dxVftMeter{
  margin-top: 9px;
  height: 5px;
  border-radius: 999px;
  background: rgba(255,255,255,.05);
  overflow: hidden;
  position: relative;
}
/* tick marks at 25/50/75 */
.dxVftMeter::after{
  content: '';
  position: absolute;
  inset: 0;
  pointer-events: none;
  background-image:
    linear-gradient(90deg, transparent calc(50% - .5px), rgba(255,255,255,.10) 50%, transparent calc(50% + .5px)),
    linear-gradient(90deg, transparent calc(25% - .5px), rgba(255,255,255,.06) 25%, transparent calc(25% + .5px)),
    linear-gradient(90deg, transparent calc(75% - .5px), rgba(255,255,255,.06) 75%, transparent calc(75% + .5px));
}
.dxVftMeterFill{
  height: 100%;
  background: linear-gradient(90deg, rgba(122, 200, 255, .50), rgba(122, 200, 255, .92));
  box-shadow: 0 0 14px rgba(122, 200, 255, .30);
  transition: width .35s cubic-bezier(.2,.9,.25,1);
}
.dxVftMeterFill.is-bull{
  background: linear-gradient(90deg, rgba(91, 214, 160, .45), rgba(91, 214, 160, .96));
  box-shadow: 0 0 14px rgba(91, 214, 160, .32);
}
.dxVftMeterFill.is-bear{
  background: linear-gradient(90deg, rgba(255, 124, 146, .45), rgba(255, 124, 146, .96));
  box-shadow: 0 0 14px rgba(255, 124, 146, .30);
}
.dxVftMeterFill.is-neutral{
  background: linear-gradient(90deg, rgba(232, 222, 200, .35), rgba(232, 222, 200, .8));
  box-shadow: 0 0 14px rgba(232, 222, 200, .22);
}

/* ---------- MACD / MA mini-row triplet ---------- */
.dxMacdTrip{ margin-top: 10px; gap: 6px; }
.dxMacdTrip .dxMacdItem{
  padding: 7px 9px 6px;
  border-radius: 10px;
  border: 1px solid rgba(255,255,255,.07);
  background: linear-gradient(180deg, rgba(255,255,255,.025), rgba(0,0,0,.16));
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 8px;
}
.dxMacdTrip .dxMacdItem span{
  font-family: var(--vft-sans);
  font-weight: 800;
  font-size: 9.5px;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--vft-t4);
}
.dxMacdTrip .dxMacdItem b{
  font-family: var(--vft-mono);
  font-weight: 600;
  font-size: 11.5px;
  letter-spacing: .005em;
  color: var(--vft-t1);
  font-variant-numeric: tabular-nums;
  max-width: 92px;
  text-align: right;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

/* ---------- Flow chips ---------- */
.dxFlowRow{
  margin-top: 10px;
  gap: 8px;
}
.dxFlowChip{
  padding: 7px 10px;
  border-radius: 999px;
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.08);
  transition: border-color .18s ease, background .18s ease;
  gap: 8px;
}
.dxFlowChip img{ width: 24px; height: 24px; }
.dxFlowChip span{
  font-family: var(--vft-sans);
  font-weight: 700;
  font-size: 11px;
  letter-spacing: .015em;
  color: var(--vft-t2);
}
.dxFlowChip.dxFlowChip--up{
  border-color: rgba(91, 214, 160, .22);
  background: linear-gradient(180deg, rgba(91, 214, 160, .06), rgba(91, 214, 160, .02));
}
.dxFlowChip.dxFlowChip--dn{
  border-color: rgba(255, 124, 146, .22);
  background: linear-gradient(180deg, rgba(255, 124, 146, .06), rgba(255, 124, 146, .02));
}

/* ---------- Pred buttons row ---------- */
.dxVftCfg{
  margin-top: 8px;
  padding: 9px 10px;
  border-radius: 12px;
  border: 1px solid rgba(255,255,255,.07);
  background: rgba(255,255,255,.02);
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.dxVftCfgRow{
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}
.dxVftCfgRow + .dxVftCfgRow{ margin-top: 0; }
.dxVftCfgRow label{
  font-family: var(--vft-sans);
  font-weight: 700;
  font-size: 10px;
  letter-spacing: .10em;
  text-transform: uppercase;
  color: var(--vft-t4);
}
.dxVftCfgRow input[type="color"]{
  width: 32px; height: 26px;
  border: 1px solid rgba(255,255,255,.10);
  border-radius: 8px;
  background: rgba(0,0,0,.25);
  padding: 0;
}
.dxVftCfgRow input[type="range"]{
  flex: 1; min-width: 100px;
  height: 4px;
  -webkit-appearance: none; appearance: none;
  background: rgba(255,255,255,.08);
  border-radius: 999px;
  outline: none;
}
.dxVftCfgRow input[type="range"]::-webkit-slider-thumb{
  -webkit-appearance: none; appearance: none;
  width: 14px; height: 14px;
  border-radius: 50%;
  background: var(--vft-t1);
  border: 1px solid rgba(0,0,0,.30);
  cursor: pointer;
  box-shadow: 0 0 0 3px rgba(122, 200, 255, .14);
}
.dxVftCfgRow input[type="range"]::-moz-range-thumb{
  width: 14px; height: 14px;
  border-radius: 50%;
  background: var(--vft-t1);
  border: 1px solid rgba(0,0,0,.30);
  cursor: pointer;
}
.dxVftCfgRow select{
  height: 28px;
  padding: 0 8px;
  border-radius: 9px;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(0,0,0,.30);
  color: var(--vft-t2);
  font-family: var(--vft-sans);
  font-weight: 700;
  font-size: 11px;
  letter-spacing: .02em;
}
.dxVftCfgRow span{
  font-family: var(--vft-mono);
  font-weight: 600;
  font-size: 11px;
  color: var(--vft-t2);
  font-variant-numeric: tabular-nums;
  min-width: 32px;
  text-align: right;
}
.dxVftCfgHint{
  font-family: var(--vft-sans);
  font-weight: 500;
  font-size: 10.5px;
  line-height: 1.4;
  color: var(--vft-t4);
  margin-top: 4px;
  padding-top: 8px;
  border-top: 1px dashed rgba(255,255,255,.06);
}

/* Pred-deck primary button */
.dxVftBtn--primary{
  background: linear-gradient(180deg, rgba(122, 200, 255, .18), rgba(122, 200, 255, .08)) !important;
  border-color: rgba(122, 200, 255, .42) !important;
  color: rgba(245, 252, 255, .98) !important;
  box-shadow: 0 0 0 1px rgba(122, 200, 255, .14), 0 6px 18px rgba(0,0,0,.35);
}

/* ---------- U-Trend (U) — already a different shape, just refine ---------- */
.dxUHead{ padding: 0 2px 8px; }
.dxUTitle{
  font-family: var(--vft-sans);
  font-weight: 800;
  font-size: 10px;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--vft-t3);
}
.dxUSub{
  font-family: var(--vft-sans);
  font-weight: 500;
  font-size: 10.5px;
  color: var(--vft-t4);
}
.dxURow{
  padding: 9px 11px;
  border-radius: 12px;
  background: linear-gradient(180deg, rgba(255,255,255,.025), rgba(255,255,255,.005));
  border: 1px solid rgba(255,255,255,.07);
  box-shadow: 0 0 0 1px rgba(0,0,0,.18) inset;
  position: relative;
  overflow: hidden;
}
.dxURow::before{
  content:'';
  position:absolute;
  left:0; top: 10px; bottom: 10px;
  width: 2px;
  border-radius: 2px;
  background: rgba(255,255,255,.10);
  transition: background .25s ease;
}
.dxURow.bull{ border-color: rgba(91, 214, 160, .22); }
.dxURow.bull::before{ background: var(--vft-bull); box-shadow: 0 0 8px rgba(91, 214, 160, .55); }
.dxURow.bear{ border-color: rgba(255, 124, 146, .22); }
.dxURow.bear::before{ background: var(--vft-bear); box-shadow: 0 0 8px rgba(255, 124, 146, .55); }
.dxURow.neutral{ border-color: rgba(232, 222, 200, .14); }
.dxURow.neutral::before{ background: rgba(232, 222, 200, .55); }

.dxUAvatar{
  border-radius: 12px;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(0,0,0,.30);
}
.dxUTf{
  font-family: var(--vft-sans);
  font-weight: 800;
  font-size: 11.5px;
  letter-spacing: .04em;
  color: var(--vft-t1);
}
.dxUTag{
  font-family: var(--vft-sans);
  font-weight: 700;
  font-size: 10.5px;
  color: var(--vft-t2);
}
.dxURow.bull  .dxUTag{ color: var(--vft-bull); }
.dxURow.bear  .dxUTag{ color: var(--vft-bear); }
.dxURow.neutral .dxUTag{ color: var(--vft-flat); }
.dxUHint{
  font-family: var(--vft-sans);
  font-weight: 500;
  font-size: 10.5px;
  line-height: 1.35;
  color: var(--vft-t3);
}
.dxUExtra{
  font-family: var(--vft-mono);
  font-weight: 500;
  font-size: 9.5px;
  color: var(--vft-t4);
  font-variant-numeric: tabular-nums;
  letter-spacing: .005em;
}

/* ---------- RSI Pro toolbar inside VFT ---------- */
.xOscProTools{
  display: flex;
  flex-wrap: wrap;
  gap: 5px;
  margin-top: 8px;
}
.xOscProToolBtn{
  appearance: none;
  font-family: var(--vft-sans);
  font-weight: 700;
  font-size: 10px;
  letter-spacing: .08em;
  padding: 5px 8px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.08);
  background: rgba(255,255,255,.025);
  color: var(--vft-t3);
  cursor: pointer;
  transition: all .15s ease;
}
.xOscProToolBtn:hover{
  border-color: rgba(255,255,255,.20);
  color: var(--vft-t1);
  background: rgba(255,255,255,.05);
}
.xOscProToolBtn.is-on,
.xOscProToolBtn.is-active{
  border-color: var(--vft-bull-edge);
  background: var(--vft-bull-soft);
  color: rgba(91, 214, 160, .96);
  box-shadow: 0 0 0 1px rgba(91, 214, 160, .12);
}

/* ---------- xOsc panel inside VFT (DX-RSI) ---------- */
#dxVftDeck .xOscPanel{ padding: 10px; border-radius: 12px; border: 1px solid var(--vft-card-bd); background: var(--vft-card-bg); }
#dxVftDeck .xOscBtn{
  height: 28px;
  padding: 0 10px;
  border-radius: 9px;
  border: 1px solid rgba(255,255,255,.08);
  background: rgba(255,255,255,.025);
  color: var(--vft-t3);
  font-family: var(--vft-sans);
  font-weight: 700;
  font-size: 10.5px;
  letter-spacing: .04em;
  cursor: pointer;
  transition: all .15s ease;
}
#dxVftDeck .xOscBtn:hover{ border-color: rgba(255,255,255,.20); color: var(--vft-t1); background: rgba(255,255,255,.05); }
#dxVftDeck .xOscBtn.is-active{
  border-color: var(--vft-bull-edge);
  background: var(--vft-bull-soft);
  color: rgba(91, 214, 160, .96);
  box-shadow: 0 0 0 1px rgba(91, 214, 160, .12);
}

/* ---------- Pro mode: tighten everything by ~1px ---------- */
#dxVftDeck.dxVft--pro .dxVftCard{
  border-color: rgba(91, 214, 160, .14);
}
#dxVftDeck.dxVft--pro .dxVftBig{ letter-spacing: -.005em; }

/* ---------- Sniper tools (S1-S9) — make state-led layout pleasant ---------- */
[id^="dxVftSlotS"] .dxVftCard:first-child .dxVftState{
  font-size: 14px;
  font-weight: 800;
  letter-spacing: .02em;
}

/* ---------- Stoch / CCI / OBV / ADX / Vol — when state appears in 2nd card,
              treat it as the "verdict" and give it a tiny extra weight  ---------- */
.dxVftGrid > .dxVftCard:nth-child(2) > .dxVftState{
  font-size: 13px;
  font-weight: 800;
}

/* ---------- T/B (Top / Bottom) ---------- */
#dxVftSlotTB .dxVftBig{ font-size: clamp(22px, 3.0vw, 30px); }

/* ---------- Vol VFT — make the rVol stand out ---------- */
#dxVftSlotVol #dxVolRvol{
  font-family: var(--vft-mono);
  font-weight: 700;
  font-variant-numeric: tabular-nums;
}

/* ---------- FVG/Liq/Triangle — state-only big text ---------- */
#dxVftSlotFvg .dxVftBig,
#dxVftSlotLiq .dxVftBig,
#dxVftSlotTri .dxVftBig,
#dxVftSlotMS .dxVftBig,
#dxVftSlotTrend .dxVftBig,
#dxVftSlotPred .dxVftBig,
#dxVftSlotKill .dxVftBig{
  /* These hold words like "ABOVE", "INSIDE", "BULL" — sans is more readable */
  font-family: var(--vft-sans);
  font-weight: 800;
  letter-spacing: .005em;
  font-size: clamp(20px, 2.7vw, 28px);
  text-transform: uppercase;
}

/* ---------- HUDs / S-tools state pop ---------- */
#dxVftSlotKill .dxVftCard:first-child{
  /* Flow card with chips needs a touch more vertical space */
  min-height: 122px;
}

/* ---------- Mobile / narrow widths ---------- */
@media (max-width: 1080px){
  .dxVftBig, .dxVftBig--fit{ font-size: clamp(22px, 3.6vw, 30px); }
  .dxVftCard{ padding: 11px 11px 10px 13px; }
  .dxVftBody{ padding: 9px 10px 10px; gap: 9px; }
}
@media (max-width: 720px){
  .dxVftGrid{ grid-template-columns: 1fr; }
  .dxVftBig, .dxVftBig--fit{ font-size: 26px; }
  .dxVftCard{ padding: 11px 11px 10px 13px; }
  .dxFlowRow{ gap: 6px; }
  .dxFlowChip span{ font-size: 10.5px; }
}

/* ---------- White theme parity ---------- */
body.dx-theme-white .dxVftDeck{
  background: linear-gradient(180deg, rgba(252,254,255,.96), rgba(244,248,252,.92));
  border-color: rgba(16,32,51,.10);
  box-shadow:
    0 24px 70px rgba(16,24,40,.12),
    0 0 0 1px rgba(16,32,51,.04) inset;
}
body.dx-theme-white .dxVftDeck.bias-bull{ border-color: rgba(20,140,90,.22); }
body.dx-theme-white .dxVftDeck.bias-bear{ border-color: rgba(200,60,80,.22); }
body.dx-theme-white .dxVftDeck.bias-neutral{ border-color: rgba(150,130,90,.22); }

body.dx-theme-white .dxVftDeck{
  --vft-t1: rgba(16, 32, 51, .96);
  --vft-t2: rgba(28, 44, 64, .82);
  --vft-t3: rgba(40, 58, 80, .60);
  --vft-t4: rgba(60, 78, 100, .42);
  --vft-card-bg: linear-gradient(180deg, rgba(255,255,255,.86), rgba(248,251,254,.78));
  --vft-card-bd: rgba(16,32,51,.08);
  --vft-card-bd-hover: rgba(16,32,51,.18);
  --vft-bull:        #1FA876;
  --vft-bear:        #C8455A;
  --vft-flat:        #8A7A52;
  --vft-accent:      #2F7FBF;
}
body.dx-theme-white .dxVftMeter{ background: rgba(16,32,51,.07); }
body.dx-theme-white .dxVftMeter::after{
  background-image:
    linear-gradient(90deg, transparent calc(50% - .5px), rgba(16,32,51,.16) 50%, transparent calc(50% + .5px)),
    linear-gradient(90deg, transparent calc(25% - .5px), rgba(16,32,51,.10) 25%, transparent calc(25% + .5px)),
    linear-gradient(90deg, transparent calc(75% - .5px), rgba(16,32,51,.10) 75%, transparent calc(75% + .5px));
}
body.dx-theme-white .dxMacdTrip .dxMacdItem{
  background: linear-gradient(180deg, rgba(255,255,255,.65), rgba(244,248,252,.55));
  border-color: rgba(16,32,51,.08);
}
body.dx-theme-white .dxFlowChip{ background: rgba(255,255,255,.45); border-color: rgba(16,32,51,.10); }
body.dx-theme-white .dxVftCfg{ background: rgba(255,255,255,.55); border-color: rgba(16,32,51,.08); }
body.dx-theme-white .xOscPanel{ background: rgba(255,255,255,.55); border-color: rgba(16,32,51,.08); }

/* ---------- Side rail integration ---------- */
.dxSideVft .dxVftDeck{
  width: 100%;
  margin: 0;
  align-self: stretch;
  border-radius: 14px;
}
.dxSideVft .dxVftBody{ padding: 10px 11px 12px; }

/* When in the side rail and tight, allow vertical scroll within the deck */
.dxSideVft{
  display: flex;
  flex-direction: column;
  min-height: 0;
}
.dxSideVft .dxVftDeck{
  flex: 1 1 auto;
  min-height: 0;
  display: flex;
  flex-direction: column;
}
.dxSideVft .dxVftDeck .dxVftBody{
  flex: 1 1 auto;
  min-height: 0;
  overflow-y: auto;
  overscroll-behavior: contain;
  scrollbar-width: thin;
  scrollbar-color: rgba(255,255,255,.18) transparent;
}
.dxSideVft .dxVftDeck .dxVftBody::-webkit-scrollbar{ width: 7px; }
.dxSideVft .dxVftDeck .dxVftBody::-webkit-scrollbar-thumb{
  background: rgba(255,255,255,.16);
  border-radius: 999px;
}
.dxSideVft .dxVftDeck .dxVftBody::-webkit-scrollbar-track{ background: transparent; }

/* ---------- Sidebar minimised states ---------- */
.dxSideBar.is-vft-min .dxVftHead{
  padding: 9px 12px;
  border-bottom-color: transparent;
}

/* ---------- Focus ring for keyboard nav (a11y) ---------- */
.dxVftPill:focus-visible,
.dxVftBtn:focus-visible,
.xOscProToolBtn:focus-visible,
#dxVftDeck .xOscBtn:focus-visible{
  outline: 2px solid var(--vft-accent);
  outline-offset: 2px;
}

/* ---------- One-shot: hide stray duplicate dxVftLabel at very end inside body
              (some VFTs have it both inside and outside the grid) ---------- */
.dxVftBody > .dxVftLabel + .dxVftLabel{ display: none; }


/* ============================================================
   ───────  CLAUDE OSCILLATOR + CHART OVERLAY POLISH  ────────
   These rules touch the SVG-based RSI sparkline (#xOscSvg /
   #xOscPath / etc.) and the surrounding xOsc panel chrome.
   They do NOT reach the canvas-rendered candlestick chart —
   that is recoloured at runtime by vft-claude-chart-theme.js.
   ============================================================ */

/* ----- xOsc panel shell (RSI / oscillator container) ----- */
.xOscPanel{
  background: linear-gradient(180deg, rgba(8,12,18,.72), rgba(6,9,14,.62));
  border: 1px solid rgba(255,255,255,.07);
  border-radius: 14px;
  padding: 11px 12px 10px;
  box-shadow: 0 0 0 1px rgba(255,255,255,.02) inset;
}

/* In white theme */
body.dx-theme-white .xOscPanel{
  background: linear-gradient(180deg, rgba(252,254,255,.82), rgba(244,248,252,.72));
  border-color: rgba(16,32,51,.08);
  box-shadow: 0 0 0 1px rgba(16,32,51,.02) inset;
}

/* ----- xOsc header refinements ----- */
.xOscHeader{ margin-bottom: 8px; }
.xOscMeta{
  font-family: 'JetBrains Mono', 'SF Mono', 'Roboto Mono', ui-monospace, 'Courier New', monospace;
  font-weight: 600;
  font-size: 11.5px;
  letter-spacing: .01em;
  color: rgba(232,240,252,.82);
  font-variant-numeric: tabular-nums;
}
body.dx-theme-white .xOscMeta{ color: rgba(28,44,64,.86); }

/* ----- xOsc number block ----- */
.xOscBig{
  border: 1px solid rgba(255,255,255,.07);
  border-radius: 12px;
  padding: 11px 13px;
  background: linear-gradient(180deg, rgba(255,255,255,.025), rgba(255,255,255,.005));
}
.xOscValue{
  font-family: 'JetBrains Mono', 'SF Mono', 'Roboto Mono', ui-monospace, 'Courier New', monospace;
  font-weight: 600;
  letter-spacing: -.012em;
  font-variant-numeric: tabular-nums;
  font-size: clamp(26px, 3vw, 34px);
  color: rgba(245,248,252,.96);
}
body.dx-theme-white .xOscBig{
  background: linear-gradient(180deg, rgba(255,255,255,.65), rgba(244,248,252,.55));
  border-color: rgba(16,32,51,.08);
}
body.dx-theme-white .xOscValue{ color: rgba(16,32,51,.96); }

.xOscState{
  margin-top: 6px;
  font-family: 'Inter', system-ui, sans-serif;
  font-weight: 700;
  font-size: 11.5px;
  letter-spacing: .015em;
  color: rgba(232,240,252,.82);
}
body.dx-theme-white .xOscState{ color: rgba(28,44,64,.82); }

/* ----- xOsc banner / sub ----- */
.xOscBannerWrap{
  border: 1px solid rgba(255,255,255,.07);
  border-radius: 12px;
  padding: 11px 13px;
  background: linear-gradient(180deg, rgba(255,255,255,.020), rgba(255,255,255,.004));
}
.xOscBanner{
  font-family: 'Inter', system-ui, sans-serif;
  font-weight: 700;
  font-size: 13px;
  letter-spacing: .005em;
  color: rgba(245,248,252,.94);
}
.xOscSub{
  font-family: 'Inter', system-ui, sans-serif;
  font-weight: 500;
  font-size: 11px;
  color: rgba(212,225,240,.62);
  margin-top: 4px;
  line-height: 1.4;
}
body.dx-theme-white .xOscBannerWrap{
  background: linear-gradient(180deg, rgba(255,255,255,.55), rgba(244,248,252,.45));
  border-color: rgba(16,32,51,.08);
}
body.dx-theme-white .xOscBanner{ color: rgba(16,32,51,.96); }
body.dx-theme-white .xOscSub{ color: rgba(40,58,80,.66); }

/* ----- xOsc stats grid ----- */
.xOscStats{ gap: 5px 12px; margin-top: 9px; }
.xOscStat{
  font-family: 'Inter', system-ui, sans-serif;
  font-weight: 500;
  font-size: 10.5px;
  color: rgba(212,225,240,.60);
}
.xOscStat b{
  font-family: 'JetBrains Mono', 'SF Mono', 'Roboto Mono', ui-monospace, 'Courier New', monospace;
  font-weight: 600;
  color: rgba(245,248,252,.92);
  font-variant-numeric: tabular-nums;
  letter-spacing: .005em;
}
body.dx-theme-white .xOscStat{ color: rgba(40,58,80,.62); }
body.dx-theme-white .xOscStat b{ color: rgba(16,32,51,.92); }

/* ----- xOsc note ----- */
.xOscNote{
  font-family: 'Inter', system-ui, sans-serif;
  font-weight: 500;
  font-size: 11px;
  line-height: 1.42;
  color: rgba(212,225,240,.62);
  margin-top: 7px;
}
body.dx-theme-white .xOscNote{ color: rgba(40,58,80,.62); }

/* ----- xOsc warn box (settings) ----- */
.xOscWarn{
  border: 1px solid rgba(232,180,80,.28);
  background: linear-gradient(180deg, rgba(232,180,80,.06), rgba(232,180,80,.02));
  border-radius: 11px;
  padding: 9px 11px;
  font-family: 'Inter', system-ui, sans-serif;
  font-weight: 500;
  font-size: 11px;
  line-height: 1.4;
  color: rgba(245,232,205,.82);
  margin-top: 8px;
}

/* ============================================================
   SVG SPARKLINE — refined OB/OS bands + line strokes
   The xOscSvg is an inline SVG that draws RSI history. Its
   background bands are pure CSS layered gradients; we
   replace those plus the path stroke colors below.
   ============================================================ */

#xOscSvg{
  height: 32px;
  border-radius: 9px;
  background:
    /* Refined OB/OS bands (top = bear caution, bottom = bull caution
       — matches the new emerald/salmon palette) */
    linear-gradient(to bottom,
      rgba(255,124,146,.18) 0%,
      rgba(255,124,146,.10) var(--dx-ob, 30%),
      rgba(0,0,0,0)         var(--dx-ob, 30%),
      rgba(0,0,0,0)         var(--dx-os, 70%),
      rgba(91,214,160,.10)  var(--dx-os, 70%),
      rgba(91,214,160,.18)  100%
    ),
    /* OB line (top, bear) */
    linear-gradient(to bottom,
      rgba(0,0,0,0) calc(var(--dx-ob, 30%) - .8%),
      rgba(255,124,146,.55) var(--dx-ob, 30%),
      rgba(0,0,0,0) calc(var(--dx-ob, 30%) + .8%)
    ),
    /* MID line (50) */
    linear-gradient(to bottom,
      rgba(0,0,0,0) calc(var(--dx-mid, 50%) - .8%),
      rgba(232,240,252,.20) var(--dx-mid, 50%),
      rgba(0,0,0,0) calc(var(--dx-mid, 50%) + .8%)
    ),
    /* OS line (bottom, bull) */
    linear-gradient(to bottom,
      rgba(0,0,0,0) calc(var(--dx-os, 70%) - .8%),
      rgba(91,214,160,.55) var(--dx-os, 70%),
      rgba(0,0,0,0) calc(var(--dx-os, 70%) + .8%)
    );
}
body.dx-theme-white #xOscSvg{
  background:
    linear-gradient(to bottom,
      rgba(200,69,90,.16) 0%,
      rgba(200,69,90,.08) var(--dx-ob, 30%),
      rgba(0,0,0,0)        var(--dx-ob, 30%),
      rgba(0,0,0,0)        var(--dx-os, 70%),
      rgba(31,168,118,.08) var(--dx-os, 70%),
      rgba(31,168,118,.16) 100%
    ),
    linear-gradient(to bottom,
      rgba(0,0,0,0) calc(var(--dx-ob, 30%) - .8%),
      rgba(200,69,90,.55) var(--dx-ob, 30%),
      rgba(0,0,0,0) calc(var(--dx-ob, 30%) + .8%)
    ),
    linear-gradient(to bottom,
      rgba(0,0,0,0) calc(var(--dx-mid, 50%) - .8%),
      rgba(16,32,51,.20) var(--dx-mid, 50%),
      rgba(0,0,0,0) calc(var(--dx-mid, 50%) + .8%)
    ),
    linear-gradient(to bottom,
      rgba(0,0,0,0) calc(var(--dx-os, 70%) - .8%),
      rgba(31,168,118,.55) var(--dx-os, 70%),
      rgba(0,0,0,0) calc(var(--dx-os, 70%) + .8%)
    );
}

/* RSI primary path (the live line) */
#xOscPath{
  stroke: rgba(91,214,160,.92);
  stroke-width: 2;
  stroke-linecap: round;
  stroke-linejoin: round;
  fill: none;
}

/* RSI secondary / tertiary paths (for the RSI Stack) */
#xOscPath2,
#xOscPath3{
  stroke: rgba(232,240,252,.36);
  stroke-width: 1.6;
  fill: none;
}

/* When the RSI is in a bearish state we recolour the active path */
.xOscPathBear{ stroke: rgba(255,124,146,.92) !important; }

/* Subtle glow for the active path in PRO mode (replaces neon halo) */
.xOscPanel.is-pro #xOscPath.is-active,
.xOscPanel.is-pro #xOscPath2.is-active,
.xOscPanel.is-pro #xOscPath3.is-active{
  filter: drop-shadow(0 0 6px rgba(91,214,160,.32));
}
.xOscPanel.is-pro .xOscPathBear.is-active{
  filter: drop-shadow(0 0 6px rgba(255,124,146,.32));
}

/* ----- xOsc top buttons (PRO toggle, Settings) ----- */
.xOscBtn{
  font-family: 'Inter', system-ui, sans-serif;
  font-weight: 700;
  font-size: 10.5px;
  letter-spacing: .04em;
  height: 28px;
  padding: 0 11px;
  border-radius: 9px;
  border: 1px solid rgba(255,255,255,.08);
  background: rgba(255,255,255,.025);
  color: rgba(212,225,240,.78);
  transition: color .15s ease, border-color .15s ease, background .15s ease;
}
.xOscBtn:hover{
  border-color: rgba(255,255,255,.20);
  color: rgba(245,248,252,.96);
  background: rgba(255,255,255,.05);
}
.xOscBtn.is-active{
  border-color: rgba(91,214,160,.42);
  background: rgba(91,214,160,.10);
  color: rgba(91,214,160,.96);
  box-shadow: 0 0 0 1px rgba(91,214,160,.14);
}
body.dx-theme-white .xOscBtn{
  border-color: rgba(16,32,51,.10);
  background: rgba(255,255,255,.55);
  color: rgba(40,58,80,.78);
}
body.dx-theme-white .xOscBtn:hover{
  border-color: rgba(16,32,51,.22);
  color: rgba(16,32,51,.96);
}
body.dx-theme-white .xOscBtn.is-active{
  border-color: rgba(31,168,118,.42);
  background: rgba(31,168,118,.10);
  color: rgba(31,168,118,.96);
}

/* ----- VST select pill ----- */
.dxVstSelect{
  font-family: 'Inter', system-ui, sans-serif;
  font-weight: 700;
  font-size: 10.5px;
  letter-spacing: .04em;
  height: 28px;
  padding: 0 10px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.08);
  background: rgba(0,0,0,.30);
  color: rgba(232,240,252,.86);
}
.dxVstSelect:focus{
  outline: none;
  box-shadow: 0 0 0 2px rgba(122,200,255,.22);
  border-color: rgba(122,200,255,.42);
}
body.dx-theme-white .dxVstSelect{
  background: rgba(255,255,255,.62);
  border-color: rgba(16,32,51,.10);
  color: rgba(28,44,64,.86);
}

/* ============================================================
   ───────  ECHARTS TOOLTIP / AXIS / CROSSHAIR REFINEMENT  ────
   ECharts tooltips render as DOM divs (not on the canvas), so
   CSS reaches them. We refine typography + backdrop here to
   match the rest of the deck. Selectors target both default
   and DXCELL-styled tooltips.
   ============================================================ */

div[role="tooltip"][style*="border"],
.echarts-tooltip,
div[class*="echarts-tooltip"]{
  font-family: 'Inter', system-ui, sans-serif !important;
  font-feature-settings: "tnum" !important;
  font-variant-numeric: tabular-nums !important;
  border-radius: 12px !important;
  backdrop-filter: blur(10px) saturate(110%) !important;
  -webkit-backdrop-filter: blur(10px) saturate(110%) !important;
}

/* The Claude monospace stack on the numeric portions of tooltips
   (ECharts emits values inside <b> by default in custom formatters) */
div[role="tooltip"] b,
.echarts-tooltip b{
  font-family: 'JetBrains Mono', 'SF Mono', 'Roboto Mono', ui-monospace, monospace !important;
  font-weight: 600 !important;
  letter-spacing: .005em !important;
}

/* ============================================================
   ───────  END OSCILLATOR + OVERLAY POLISH  ──────────────────
   ============================================================ */
