/* ============================================================
   TANK'S TRADING DESK — home.css
   Option-D homepage sections (KPI ticker · system pipeline ·
   premarket plan hero + price scale · TV charting · email capture ·
   reconciled-proof reframe · Trade-with-Tank).
   Built on the bound design-system tokens (var(--accent), --carbon, …).
   ============================================================ */

/* ---------- KPI BAR — "current performance", fixed three KPIs ---------- */
.kpi-fixed {
  background: linear-gradient(160deg, #1E222D 0%, #15191F 55%, #0E1116 100%);
  border-radius: 12px;
  margin: 14px var(--page-gutter, 16px) 0;
  padding: 16px 16px 15px;
  border: 1px solid var(--border-dk, #2A2E39);
  box-shadow: 0 5px 20px rgba(0,0,0,0.18);
}
.kpi-fixed-head {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 14px;
  letter-spacing: -0.01em;
  color: var(--cream-1, #F2F4F6);
  line-height: 1.2;
  margin-bottom: 11px;
}
.kpi-fixed-tiles {
  display: grid;
  grid-template-columns: 1fr;
  gap: 8px;
}
.kpi-fixed-tile {
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(242,244,246,0.10);
  border-radius: 9px;
  padding: 13px 14px 12px;
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.kft-l {
  font-family: var(--font-sans);
  font-size: 10px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--mustard, #D6A24A);
  font-weight: 700;
}
.kft-v {
  font-family: var(--font-display);
  font-size: 26px;
  font-weight: 800;
  letter-spacing: -0.02em;
  color: var(--cream-1, #F2F4F6);
  line-height: 1.0;
  font-variant-numeric: tabular-nums;
}
.kft-v.accent { color: var(--mustard, #D6A24A); }
.kft-s {
  font-family: var(--font-sans);
  font-size: 11px;
  color: rgba(242,244,246,0.62);
  line-height: 1.5;
}
.kpi-fixed-cta {
  text-decoration: none;
  background: linear-gradient(140deg, rgba(129,151,206,0.30), rgba(129,151,206,0.15));
  border-color: rgba(129,151,206,0.55);
  cursor: pointer;
  flex-direction: row;
  align-items: center;
  justify-content: center;
  gap: 9px;
  transition: background 160ms var(--ease, ease), border-color 160ms var(--ease, ease);
}
.kpi-fixed-cta:hover {
  background: linear-gradient(140deg, rgba(129,151,206,0.46), rgba(129,151,206,0.26));
  border-color: rgba(129,151,206,0.85);
}
.kft-cta-label {
  font-family: var(--font-display);
  font-size: 15px;
  font-weight: 800;
  letter-spacing: -0.01em;
  color: var(--cream-1, #F2F4F6);
  line-height: 1.15;
}
.kft-cta-arrow {
  color: #E7EBF3;
  font-size: 19px;
  font-weight: 700;
  line-height: 1;
  transition: transform 180ms var(--ease, ease);
}
.kpi-fixed-cta:hover .kft-cta-arrow { transform: translateX(5px); }
@media (min-width: 760px) {
  .kpi-fixed-tiles { grid-template-columns: repeat(4, 1fr); gap: 10px; }
  .kpi-fixed-head { font-size: 15px; }
  .kft-v { font-size: 29px; }
}
@media (min-width: 1024px) {
  .kpi-fixed { padding: 20px 20px 19px; }
  .kft-v { font-size: 32px; }
}

/* ---------- SYSTEM PIPELINE — compact interactive process-flow nav ---------- */
.pad:has(> .sys-pipe) { padding-left: 16px; padding-right: 16px; }
.sys-pipe { margin-top: 20px; }
.sys-headrow { display: flex; align-items: baseline; justify-content: space-between; gap: 20px; flex-wrap: wrap; margin-bottom: 18px; }
.sys-headline {
  font-family: var(--font-display); font-weight: 700; font-size: clamp(22px, 2.8vw, 30px);
  letter-spacing: -0.015em; color: var(--ink-deep, #111827); margin: 0; line-height: 1.12;
}
.sys-headline-live { text-align: right; color: var(--gain, #3F7A4F); font-size: clamp(15px, 1.6vw, 19px); font-weight: 700; align-self: flex-end; }
.sys-headline-date { color: var(--accent, #4B5E8E); }
.sys-headline-tag { display: block; font-family: var(--font-sans); font-size: 14.5px; font-weight: 600; color: var(--soft, #6B7280); margin-top: 5px; letter-spacing: 0; }
.sys-pipe-eb {
  font-family: var(--font-sans); font-size: 11px; letter-spacing: 0.18em;
  text-transform: uppercase; color: var(--soft, #6B7280); font-weight: 700; margin-bottom: 12px;
}
.sys-pipe-row { display: flex; align-items: stretch; gap: 10px; }

/* phase header — frames the journey for first-time users:
   "Premarket planning" timeline → node → "Live session" */
.sys-phase { margin-bottom: 9px; }
.phase-labels { display: flex; align-items: flex-end; }
.phase-label {
  font-family: var(--font-sans); font-weight: 700; font-size: 13.5px;
  color: var(--ink, #1F2937); letter-spacing: -0.01em; line-height: 1;
}
.phase-label-sub { font-weight: 600; font-size: 11px; color: var(--soft, #6B7280); letter-spacing: 0; }
.phase-label.planning { flex: 3; text-align: left; }
.phase-label.live { flex: 1; text-align: center; color: var(--accent-deep, #3C4D78); }
.phase-gap { width: 30px; flex: none; }
.phase-track { display: flex; align-items: center; margin-top: 5px; }
.phase-line { position: relative; height: 5px; border-radius: 4px; }
.phase-line.planning { flex: 4.6; background: linear-gradient(90deg, rgba(75,94,142,0.22) 0%, var(--accent, #4B5E8E) 100%); }
.phase-line.live { flex: 1; background: linear-gradient(90deg, rgba(63,122,79,0.25) 0%, var(--gain-dk, #69B083) 45%, var(--gain, #3F7A4F) 100%); }
.phase-head {
  position: absolute; right: -1px; top: 50%; width: 8px; height: 8px;
  border-top: 2px solid var(--accent, #4B5E8E); border-right: 2px solid var(--accent, #4B5E8E);
  transform: translateY(-50%) rotate(45deg);
}
.phase-node { width: 30px; flex: none; display: flex; align-items: center; justify-content: center; }
.phase-node::before {
  content: ''; width: 14px; height: 14px; border-radius: 50%;
  background: var(--accent, #4B5E8E); box-shadow: 0 0 0 4px rgba(75,94,142,0.16);
}
@media (max-width: 760px) { .sys-phase { display: none; } }
.sys-pipe-row { display: flex; align-items: stretch; gap: 7px; }
.sp-stage {
  flex: 1; display: flex; flex-direction: column; align-items: center; justify-content: center;
  text-align: center; gap: 2px;
  border: 1px solid var(--border, #E3E6EA); background: var(--surface, #FBFBFC);
  padding: 7px 16px; min-height: 36px;
  font-family: var(--font-sans); font-weight: 700; font-size: 12.5px; color: var(--ink, #1F2937);
  position: relative; text-decoration: none; cursor: pointer; overflow: hidden;
  clip-path: polygon(0 0, calc(100% - 15px) 0, 100% 50%, calc(100% - 15px) 100%, 0 100%, 15px 50%);
  transition: transform 160ms var(--ease, ease), border-color 160ms var(--ease, ease), background 160ms var(--ease, ease), color 160ms var(--ease, ease);
}
/* first chevron: flat left edge */
.sys-pipe-row > .sp-stage:first-child { clip-path: polygon(0 0, calc(100% - 15px) 0, 100% 50%, calc(100% - 15px) 100%, 0 100%); padding-left: 18px; }
.sp-stage:not(.dual):hover { transform: translateY(-3px); border-color: var(--accent, #4B5E8E); color: var(--accent-deep, #3C4D78); }
.sp-stage.active:hover { color: #fff; }
.sp-stage.active:hover .sp-sub { color: rgba(255,255,255,0.82); }
.sp-stage:not(.dual):active { transform: translateY(-1px); }
.sp-stage .sp-sub { font-size: 8.5px; font-weight: 600; letter-spacing: 0.08em; text-transform: uppercase; color: var(--soft, #6B7280); }
/* dual chevron holds the two sub-tabs — wider, with room to clear the notch */
.sp-stage.dual { flex: 1.7; flex-direction: row; gap: 6px; padding: 6px 24px 6px 30px; cursor: default; }
.sp-stage.dual:hover { transform: none; }
.sp-stage.dual .sp-dual-item {
  border: 1px solid var(--border, #E3E6EA); border-radius: var(--r-sm, 8px);
  padding: 6px 10px; font-size: 11.5px; font-weight: 700; background: var(--paper, #F2F4F6);
  color: var(--ink, #1F2937); font-family: var(--font-sans); cursor: pointer; text-align: center; white-space: nowrap;
  transition: transform 140ms var(--ease, ease), background 160ms var(--ease, ease), color 160ms, border-color 160ms;
}
.sp-stage.dual .sp-dual-item:hover { border-color: var(--accent, #4B5E8E); transform: translateY(-2px); }
.sp-stage.dual .sp-dual-item.on { background: var(--accent, #4B5E8E); border-color: var(--accent, #4B5E8E); color: #fff; }
.sp-stage.dual.active-dual { border-color: var(--accent, #4B5E8E); }
/* active stage: animated slate gradient sheen (the B signature) */
.sp-stage.active { color: #fff; border-color: transparent;
  background: linear-gradient(110deg, var(--accent-deep, #3C4D78), var(--accent, #4B5E8E) 45%, var(--accent-lite, #8197CE));
  background-size: 200% 100%; animation: sp-sheen 1.6s ease-out 1;
}
.sp-stage.active .sp-sub { color: rgba(255,255,255,0.82); }
@keyframes sp-sheen { to { background-position: -200% 0; } }
@media (prefers-reduced-motion: reduce) { .sp-stage.active { animation: none; } .sp-arrow::after { animation: none; } }
.sp-stage.cta {
  background: rgba(63,122,79,0.12); border-color: var(--gain, #3F7A4F); color: #2E5E3B;
}
.sp-stage.cta:hover { background: rgba(63,122,79,0.20); transform: translateY(-3px); }
.sp-stage.cta .sp-sub { color: var(--gain, #3F7A4F); }
/* flow connector — slate dot travels left → right between chevrons */
.sp-arrow {
  flex: 0 0 20px; align-self: center; position: relative; height: 2px; border-radius: 2px;
  background: var(--border, #E3E6EA); overflow: hidden; font-size: 0; color: transparent;
}
.sp-arrow::after {
  content: ''; position: absolute; top: -2px; left: 0; width: 9px; height: 6px; border-radius: 3px;
  background: var(--accent, #4B5E8E); animation: sp-flow 1.9s linear 1 forwards;
}
@keyframes sp-flow { from { left: -12px; } to { left: 130%; } }

/* ---------- PREMARKET PLAN — full-bleed dark band (matches Structural Bias / Market Sensor) ---------- */
.plan-hero {
  background: radial-gradient(125% 90% at 80% 12%, #1E222D 0%, #131722 46%, #0E1116 100%);
  padding: 40px 0 84px;
  margin-top: 0;
}
.plan-hero-wrap { max-width: none; margin: 0 auto; padding: 0 16px; }
.plan-hero-head { margin-bottom: 26px; }
.plan-hero-eb {
  font-family: var(--font-sans); font-size: 11px; letter-spacing: 0.2em; text-transform: uppercase;
  color: var(--accent-lite, #8197CE); font-weight: 700; margin: 0 0 10px;
}
.plan-hero-h {
  font-family: var(--font-display); font-weight: 700; font-size: clamp(28px, 3.4vw, 38px);
  letter-spacing: -0.01em; color: #F2F4F6; margin: 0; line-height: 1.04;
}
.plan-hero-h em { font-style: normal; color: var(--accent-lite, #8197CE); }
.plan-hero-sub { font-family: var(--font-sans); font-size: 14.5px; color: #9CA3AE; margin: 12px 0 0; line-height: 1.55; max-width: 680px; }
.plan-hero-meta { display: flex; gap: 24px; margin-top: 18px; flex-wrap: wrap; }
.plan-hero-meta .phm { display: flex; flex-direction: column; gap: 3px; }
.plan-hero-meta .phm .k { font-family: var(--font-sans); font-size: 9.5px; letter-spacing: 0.12em; text-transform: uppercase; color: #7E8893; }
.plan-hero-meta .phm .v { font-family: var(--font-sans); font-size: 13.5px; font-weight: 700; color: #E6EAF0; font-variant-numeric: tabular-nums; }
.plan-hero-meta .phm .v.phm-risk { color: var(--loss-dk, #CC7A6C); }
@media (max-width: 760px) { .plan-hero { padding: 32px 0 40px; } .plan-hero-wrap { padding: 0 14px; } }

.plan-panel {
  margin-top: 0;
  background: transparent;
  border: none;
  border-radius: 0;
  padding: 0;
  box-shadow: none;
}
.plan-panel-top { display: flex; align-items: center; gap: 12px; margin-bottom: 18px; flex-wrap: wrap; }
.plan-panel-day {
  font-family: var(--font-sans); font-size: 11px; letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--accent-lite, #8197CE); font-weight: 700;
}
.plan-panel-verdict {
  font-family: var(--font-display); font-weight: 700; font-size: 18px; color: #fff; margin-left: 2px;
}
.plan-panel-riskmode { margin-left: auto; }
.plan-grid { display: grid; grid-template-columns: 1.15fr 0.85fr; gap: 20px; }

/* allowed / not-allowed columns */
.allow-stack { display: flex; flex-direction: column; gap: 12px; }
.allow-box { background: #1B2837; border: 1px solid #2A3845; border-left: 3px solid transparent; border-radius: var(--r, 10px); padding: 14px 18px; }
.allow-box.allowed { border-left: 3px solid var(--gain-dk, #69B083); }
.allow-box.blocked { border-left: 3px solid var(--loss-dk, #CC7A6C); }
.allow-box-h {
  display: flex; align-items: center; gap: 7px; font-family: var(--font-sans);
  font-size: 10px; letter-spacing: 0.12em; text-transform: uppercase; font-weight: 700; margin-bottom: 9px;
}
.allow-box.allowed .allow-box-h { color: #A6C7B1; }
.allow-box.blocked .allow-box-h { color: #D9ABA4; }
.allow-box-h .dot { width: 7px; height: 7px; border-radius: 50%; }
.allow-box.allowed .allow-box-h .dot { background: var(--gain-dk, #69B083); }
.allow-box.blocked .allow-box-h .dot { background: var(--loss-dk, #CC7A6C); }
.allow-item { display: flex; gap: 8px; font-family: var(--font-sans); font-size: 12.5px; color: #C7D2DA; line-height: 1.4; margin-top: 8px; }
.allow-item:first-of-type { margin-top: 0; }
.allow-item .gl { flex-shrink: 0; font-weight: 700; }
.allow-box.allowed .allow-item .gl { color: var(--gain-dk, #69B083); }
.allow-box.blocked .allow-item .gl { color: var(--loss-dk, #CC7A6C); }

/* ---------- PRICE SCALE ---------- */
.price-scale-wrap { background: #18222E; border: 1px solid #2A3845; border-radius: var(--r, 10px); padding: 14px 16px; }
.price-scale-h {
  font-family: var(--font-sans); font-size: 10px; letter-spacing: 0.12em; text-transform: uppercase;
  color: #8FA0AE; font-weight: 700; margin-bottom: 6px; display: flex; justify-content: space-between;
}
.price-scale { position: relative; }
.ps-axis { position: absolute; width: 2px; background: linear-gradient(180deg, rgba(224,138,79,0.25) 0%, #E08A4F 100%); }
.ps-cap { position: absolute; width: 8px; height: 8px; border-right: 2px solid #E08A4F; border-top: 2px solid #E08A4F; }
.ps-tick-label { position: absolute; text-align: right; white-space: nowrap; transform: translateY(-50%); }
.ps-tick-price { font-family: var(--font-sans); font-weight: 700; font-variant-numeric: tabular-nums; color: #C7D2DA; }
.ps-tick-role { font-family: var(--font-sans); font-size: 8px; letter-spacing: 0.02em; margin-top: 1px; }
.ps-tick-dot { position: absolute; border-radius: 50%; transform: translate(-50%, -50%); }
.ps-em-band { position: absolute; left: 0; right: 0; background: rgba(129,151,206,0.08); border-top: 1px dashed rgba(129,151,206,0.25); border-bottom: 1px dashed rgba(129,151,206,0.25); }
.ps-leader { position: absolute; background: linear-gradient(90deg, rgba(224,138,79,0.35), #E08A4F); }
.ps-leader-head { position: absolute; width: 7px; height: 7px; border-right: 2px solid #E08A4F; border-top: 2px solid #E08A4F; transform: rotate(45deg); }
.ps-tier-card { position: absolute; background: #243340; border-radius: var(--r-sm, 8px); padding: 8px 12px; }
.ps-tier-card.active { border: 1.5px solid var(--loss-dk, #CC7A6C); }
.ps-tier-card.armed { border: 1.5px dashed #5A6B79; opacity: 0.92; }
.ps-tier-name { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; font-family: var(--font-sans); font-weight: 700; font-size: 13px; color: #fff; }
.ps-tier-label { white-space: nowrap; }
.ps-tier-state { font-family: var(--font-sans); font-size: 8.5px; letter-spacing: 0.1em; text-transform: uppercase; padding: 2px 6px; border-radius: 4px; font-weight: 700; }
.ps-tier-state.active { background: rgba(204,122,108,0.2); color: var(--loss-dk, #CC7A6C); }
.ps-tier-state.armed { background: rgba(255,255,255,0.07); color: #9AA7B2; }
.ps-tier-legs { display: flex; gap: 14px; margin-top: 6px; }
.ps-tier-leg-l { font-family: var(--font-sans); font-size: 8px; letter-spacing: 0.08em; text-transform: uppercase; color: #8FA0AE; }
.ps-tier-leg-v { font-family: var(--font-sans); font-size: 11px; font-weight: 700; color: #E6ECF1; font-variant-numeric: tabular-nums; }
.ps-tier-invalid { margin-top: 8px; padding-top: 8px; border-top: 1px solid rgba(255,255,255,0.08); font-family: var(--font-sans); font-size: 11.5px; line-height: 1.4; color: #C7D2DA; }
.ps-tier-invalid-l { display: block; font-size: 8px; letter-spacing: 0.08em; text-transform: uppercase; color: #8FA0AE; margin-bottom: 2px; }
.plan-hero .ps-tier-invalid { color: var(--ink, #1F2937); border-top-color: var(--border, #E3E6EA); }
.plan-hero .ps-tier-invalid-l { color: var(--soft, #6B7280); }

/* ---------- TIER PLAYBOOK — full swing-tier breakdown ---------- */
.tier-pb { margin-top: 16px; }
.tier-pb-head { font-family: var(--font-sans); font-size: 13px; font-weight: 800; letter-spacing: 0.04em; text-transform: uppercase; color: var(--ink, #1F2937); margin-bottom: 12px; }
.tier-pb-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.tier-pb-card { background: #FFFFFF; border: 1px solid var(--border, #E3E6EA); border-radius: var(--r, 10px); padding: 16px 18px; border-top: 3px solid var(--accent, #4B5E8E); }
.tier-pb-card.active { border-top-color: var(--loss-dk, #CC7A6C); }
.tier-pb-card.armed { border-top-color: #9AA7B2; }
.tier-pb-top { display: flex; align-items: center; gap: 10px; }
.tier-pb-name { font-family: var(--font-sans); font-size: 16px; font-weight: 800; color: var(--ink, #1F2937); }
.tier-pb-state { font-family: var(--font-sans); font-size: 9px; letter-spacing: 0.1em; text-transform: uppercase; padding: 3px 8px; border-radius: 4px; font-weight: 700; }
.tier-pb-state.active { background: rgba(204,122,108,0.16); color: #B0524A; }
.tier-pb-state.armed { background: rgba(107,114,128,0.14); color: #5A6473; }
.tier-pb-setup { font-family: var(--font-sans); font-size: 13.5px; font-weight: 700; color: var(--accent-deep, #3C4D78); margin: 9px 0 12px; line-height: 1.35; }
.tier-pb-dl { margin: 0; display: flex; flex-direction: column; gap: 9px; }
.tier-pb-row { display: grid; grid-template-columns: 132px 1fr; gap: 12px; align-items: baseline; }
.tier-pb-row dt { font-family: var(--font-sans); font-size: 9.5px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--soft, #6B7280); font-weight: 700; }
.tier-pb-row dd { margin: 0; font-family: var(--font-sans); font-size: 13px; line-height: 1.45; color: var(--ink, #1F2937); }
@media (max-width: 760px) {
  .tier-pb-grid { grid-template-columns: 1fr; }
  .tier-pb-row { grid-template-columns: 112px 1fr; gap: 10px; }
}

/* ---------- 1C · ALLOWED / NOT ALLOWED — two-panel split (TradingView-flat) ---------- */
.allow-2col { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; margin-bottom: 22px; }
.allow-2col .a2-rule { display: none; }
.a2-col { background: #FFFFFF; border: 1px solid var(--border, #E3E6EA); border-radius: var(--r, 10px); padding: 16px 18px; }
.a2-h { font-family: var(--font-sans); font-size: 24px; font-weight: 800; letter-spacing: 0.02em; text-transform: uppercase; margin: 0 0 16px; }
.a2-col.ok .a2-h { color: var(--gain-dk, #69B083); }
.a2-col.no .a2-h { color: var(--loss-dk, #CC7A6C); }
.a2-row { display: flex; gap: 9px; padding: 8px 0; font-family: var(--font-sans); font-size: 14px; line-height: 1.4; color: #C7D2DA; }
.a2-col.ok .a2-row { font-weight: 400; }
.a2-m { flex: none; font-weight: 800; font-size: 12px; }
.a2-col.ok .a2-m { color: var(--gain-dk, #69B083); }
.a2-col.no .a2-m { color: var(--loss-dk, #CC7A6C); }
@media (max-width: 700px) { .allow-2col { grid-template-columns: 1fr; gap: 0; } .allow-2col .a2-rule { display: none; } .a2-col.no { margin-top: 16px; padding-top: 16px; border-top: 1px solid #232C38; } }

/* ---------- 2B · MARKET DATA — screener table (always-on, dense) ---------- */
.md-scr { width: 100%; border-collapse: collapse; font-family: var(--font-sans); font-size: 12.5px; }
.md-scr th { font-family: var(--font-mono); font-size: 8.5px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--soft, #6B7280); font-weight: 700; text-align: left; padding: 9px 8px; border-bottom: 1px solid var(--border, #E3E6EA); }x solid #2A2E39; }
.md-scr th.c, .md-scr td.c { text-align: center; }
.md-scr td { padding: 10px 8px; border-bottom: 1px solid var(--border-soft, #ECEEF1); vertical-align: top; }
.md-scr tr.md-scr-mod td { background: rgba(75,94,142,0.06); font-weight: 700; color: var(--ink-deep, #111827); font-size: 12.5px; letter-spacing: 0.01em; border-bottom: 1px solid var(--border, #E3E6EA); border-top: 1px solid var(--border, #E3E6EA); cursor: pointer; }
.md-scr tr.md-scr-mod:hover td { background: rgba(75,94,142,0.10); }
.md-scr-caret { display: inline-block; width: 14px; font-size: 9px; color: var(--soft, #6B7280); }E39; }
.md-scr .md-scr-mc { font-family: var(--font-mono); font-weight: 700; font-size: 11px; }
.md-scr .md-scr-mc.bull { color: var(--gain, #3F7A4F); }
.md-scr .md-scr-mc.bear { color: var(--loss, #A14A47); }
.md-scr .md-scr-mc.neut { color: var(--accent, #4B5E8E); }
.md-scr .md-scr-ind { color: var(--ink, #1F2937); font-weight: 600; }
.md-scr .md-scr-read { color: var(--soft, #5A6473); font-family: var(--font-mono); font-size: 11.5px; }
.md-scr .md-scr-stat { font-family: var(--font-mono); font-weight: 800; font-size: 10px; }
.md-scr .md-scr-stat.bull { color: var(--gain, #3F7A4F); }
.md-scr .md-scr-stat.bear { color: var(--loss, #A14A47); }
.md-scr .md-scr-stat.neut { color: var(--accent, #4B5E8E); }
.md-scr .md-scr-stat.none { color: var(--soft, #6B7280); }
.md-scr .md-scr-conf { font-family: var(--font-mono); color: var(--soft, #6B7280); font-weight: 700; font-size: 10px; }

.md-scr-bar { display: flex; justify-content: flex-start; margin-bottom: 4px; }
.md-scr-toggle { background: transparent; border: 1px solid var(--border, #E3E6EA); border-radius: 999px; padding: 6px 14px; font-family: var(--font-sans); font-size: 11px; font-weight: 700; letter-spacing: 0.04em; color: var(--accent, #4B5E8E); cursor: pointer; transition: background 150ms var(--ease, ease), border-color 150ms; }
.md-scr-toggle:hover { background: var(--accent-soft, #E7EBF3); border-color: var(--accent, #4B5E8E); }
.md-scr tr.md-scr-ir { transition: background 130ms var(--ease, ease); }
.md-scr tr.md-scr-ir:hover td { background: rgba(75,94,142,0.07); }
.md-scr tr.md-scr-ir:hover .md-scr-ind { color: var(--accent-deep, #3C4D78); }
.md-scr tr.md-scr-ir td:first-child { box-shadow: inset 0 0 0 rgba(75,94,142,0); transition: box-shadow 130ms var(--ease, ease); }
.md-scr tr.md-scr-ir:hover td:first-child { box-shadow: inset 3px 0 0 var(--accent, #4B5E8E); }

/* ---------- PLAN CANDIDATES — today's plan + carry-forwards table ---------- */
.plan-cand { margin-top: 16px; background: #16202B; border: 1px solid #2A3D4D; border-radius: var(--r, 10px); padding: 16px; }
.pc-table { display: flex; flex-direction: column; }
.pc-row { display: grid; grid-template-columns: 1.3fr 0.7fr 1.05fr 1.5fr 0.8fr 0.85fr; gap: 12px; align-items: center; padding: 10px 6px; border-bottom: 1px solid #232C38; }
.pc-row:last-child { border-bottom: none; }
.pc-row .r { text-align: right; }
.pc-head span { font-family: var(--font-mono, monospace); font-size: 8.5px; font-weight: 700; letter-spacing: 0.12em; text-transform: uppercase; color: #7E8893; }
.pc-name { font-family: var(--font-sans, sans-serif); font-size: 13px; font-weight: 700; color: #EAEFF4; display: flex; flex-direction: column; gap: 2px; }
.pc-name .pc-when { font-style: normal; font-size: 9px; letter-spacing: 0.08em; text-transform: uppercase; color: #7E8893; font-weight: 600; }
.pc-dir { font-family: var(--font-mono, monospace); font-size: 10px; font-weight: 800; letter-spacing: 0.04em; }
.pc-dir.short { color: var(--loss-dk, #CC7A6C); }
.pc-dir.long { color: var(--gain-dk, #69B083); }
.pc-trig { font-family: var(--font-mono, monospace); font-size: 12px; color: #C7D2DA; font-variant-numeric: tabular-nums; }
.pc-cond { font-family: var(--font-sans, sans-serif); font-size: 12px; color: #AEB6C2; line-height: 1.35; }
.pc-dist { font-family: var(--font-mono, monospace); font-size: 13px; font-weight: 800; color: #EAEFF4; font-variant-numeric: tabular-nums; }
.pc-state { font-family: var(--font-mono, monospace); font-size: 9px; font-weight: 800; letter-spacing: 0.04em; padding: 3px 8px; border-radius: 5px; text-transform: uppercase; }
.pc-state.allowed { background: rgba(105,176,131,0.18); color: var(--gain-dk, #69B083); }
.pc-state.armed { background: rgba(129,151,206,0.20); color: var(--accent-lite, #8197CE); }
.pc-state.carried, .pc-state.no-trigger, .pc-state.touched-no-trigger { background: rgba(255,255,255,0.06); color: #9CA3AE; }
.pc-empty { padding: 14px 6px; font-family: var(--font-sans, sans-serif); font-size: 13px; color: #9CA3AE; }
.pc-foot { font-family: var(--font-sans, sans-serif); font-size: 11px; color: #7E8893; margin-top: 10px; }
@media (max-width: 700px) {
  .pc-row { grid-template-columns: 1.4fr 0.9fr 1fr; }
  .pc-row .pc-trig, .pc-row .pc-cond, .pc-head span:nth-child(3), .pc-head span:nth-child(4) { display: none; }
}

/* ---------- OPEN POSITIONS — inside the plan ---------- */
.open-pos { margin-top: 16px; background: #16202B; border: 1px solid #2A3D4D; border-radius: var(--r, 10px); padding: 16px; }
.open-pos-head { display: flex; align-items: baseline; gap: 10px; flex-wrap: wrap; margin-bottom: 12px; }
.open-pos-eb { font-family: var(--font-mono, monospace); font-size: 10.5px; font-weight: 700; letter-spacing: 0.16em; text-transform: uppercase; color: var(--accent-lite, #8197CE); }
.open-pos-note { font-family: var(--font-sans, sans-serif); font-size: 11px; color: #7E8893; }
.open-pos-empty { display: flex; align-items: center; gap: 9px; font-family: var(--font-sans, sans-serif); font-size: 13px; color: #9CA3AE; padding: 6px 2px; }
.open-pos-empty .dot { width: 7px; height: 7px; border-radius: 50%; background: var(--gain-dk, #69B083); flex-shrink: 0; }
.open-pos-list { display: flex; flex-direction: column; gap: 10px; }
.open-pos-row { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; background: rgba(255,255,255,0.03); border: 1px solid #2A3845; border-radius: 10px; padding: 13px 15px; }
.opr-top { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; }
.opr-dir { font-family: var(--font-mono, monospace); font-size: 10px; font-weight: 800; letter-spacing: 0.06em; text-transform: uppercase; padding: 3px 8px; border-radius: 5px; }
.opr-dir.long { background: rgba(105,176,131,0.18); color: var(--gain-dk, #69B083); }
.opr-dir.short { background: rgba(204,122,108,0.18); color: var(--loss-dk, #CC7A6C); }
.opr-label { font-family: var(--font-sans, sans-serif); font-weight: 700; font-size: 14px; color: #EAEFF4; }
.opr-size { font-family: var(--font-mono, monospace); font-size: 11px; color: #9CA3AE; }
.opr-pnl { margin-left: auto; font-family: var(--font-mono, monospace); font-weight: 800; font-size: 13px; font-variant-numeric: tabular-nums; }
.opr-pnl.up { color: var(--gain-dk, #69B083); }
.opr-pnl.down { color: var(--loss-dk, #CC7A6C); }
.opr-legs { display: flex; gap: 16px; margin-top: 9px; flex-wrap: wrap; }
.opr-legs span { font-family: var(--font-mono, monospace); font-size: 11.5px; color: #C7D2DA; font-variant-numeric: tabular-nums; }
.opr-legs span i { font-style: normal; color: #7E8893; font-size: 8.5px; letter-spacing: 0.1em; text-transform: uppercase; margin-right: 4px; }
.opr-action { border-left: 2px solid var(--accent-lite, #8197CE); padding-left: 13px; display: flex; flex-direction: column; justify-content: center; gap: 4px; }
.opr-action-eb { font-family: var(--font-mono, monospace); font-size: 8.5px; font-weight: 700; letter-spacing: 0.14em; text-transform: uppercase; color: var(--accent-lite, #8197CE); }
.opr-action-t { font-family: var(--font-sans, sans-serif); font-size: 13px; font-weight: 600; color: #DDE3EA; line-height: 1.45; }
@media (max-width: 700px) { .open-pos-row { grid-template-columns: 1fr; gap: 10px; } .opr-action { border-left: none; border-top: 1px solid #2A3845; padding-left: 0; padding-top: 10px; } }

/* ---------- TV CHARTING — inside the plan ---------- */
.tv-charting { margin-top: 16px; background: #FFFFFF; border: 1px solid var(--border, #E3E6EA); border-radius: var(--r, 10px); padding: 14px; }
.tv-indicator-link { display: flex; align-items: center; justify-content: space-between; gap: 12px; text-decoration: none; background: var(--cream-1, #F2F4F6); border: 1px solid var(--border, #E3E6EA); border-radius: var(--r-sm, 8px); padding: 16px 18px; font-family: var(--font-sans); font-size: 14px; color: var(--ink, #1F2937); transition: border-color 150ms var(--ease, ease), background 150ms; }
.tv-indicator-link:hover { border-color: var(--accent, #4B5E8E); background: var(--accent-soft, #E7EBF3); }
.tv-indicator-link b { color: var(--accent-deep, #3C4D78); }
.tv-il-arr { font-weight: 700; font-size: 16px; color: var(--accent, #4B5E8E); }
.tv-charting-head { display: flex; align-items: center; gap: 10px; margin-bottom: 10px; flex-wrap: wrap; }
.tv-charting-eb { font-family: var(--font-sans); font-size: 10px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--accent, #4B5E8E); font-weight: 700; }
.tv-deeplink {
  display: inline-flex; align-items: center; gap: 7px;
  background: #243340; border: 1px solid #3A4D5E; border-radius: 999px; padding: 7px 14px;
  font-family: var(--font-sans); font-size: 11px; font-weight: 700; color: #C7D2DA;
  text-decoration: none; transition: border-color 200ms var(--ease, ease), color 200ms;
}
.tv-deeplink:hover { border-color: var(--accent-lite, #8197CE); color: #fff; }
.tv-widget-host { height: 440px; border-radius: var(--r-sm, 8px); overflow: hidden; border: 1px solid #2A3D4D; background: #0E1116; }
.tv-widget-host .tradingview-widget-container,
.tv-widget-host .tradingview-widget-container__widget { height: 100%; width: 100%; }
.tv-charting-foot { font-family: var(--font-sans); font-size: 9px; color: #7E8893; margin-top: 7px; }

/* TV published-script screenshot frame (mirrors the indicator page) */
.tv-shot { position: relative; display: block; border-radius: var(--r-sm, 8px); overflow: hidden; border: 1px solid var(--border, #E3E6EA); background: #FBFBFC; text-decoration: none; }
.tv-shot-img { display: block; width: 100%; height: auto; }
.tv-shot-fallback { display: none; padding: 28px 16px; text-align: center; font-family: var(--font-sans); font-size: 13px; color: var(--soft, #6B7280); }
.tv-shot-fallback b { color: var(--accent-deep, #3C4D78); }
.tv-shot-img[data-failed] { display: none; }
.tv-shot-img[data-failed] + .tv-shot-fallback { display: block; }
.tv-shot-cap { font-family: var(--font-sans); font-size: 11.5px; line-height: 1.5; color: var(--soft, #6B7280); margin: 9px 2px 0; }
.tv-shot-cap a { color: var(--accent, #4B5E8E); text-decoration: none; font-weight: 600; }
.tv-shot-cap a:hover { text-decoration: underline; }

.plan-audit { margin-top: 16px; }

/* ---------- EMAIL CAPTURE — free, before the open ---------- */
.email-cap {
  margin-top: 18px; background: var(--accent-soft, #E7EBF3); border: 1px solid var(--accent, #4B5E8E);
  border-radius: var(--r-lg, 18px); padding: 20px 22px;
  display: flex; align-items: center; justify-content: space-between; gap: 22px; flex-wrap: wrap;
}
.email-cap-copy { min-width: 240px; flex: 1; }
.email-cap-eb { font-family: var(--font-sans); font-size: 10.5px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--accent, #4B5E8E); font-weight: 700; }
.email-cap-h { font-family: var(--font-display); font-weight: 700; font-size: 19px; color: var(--ink-deep, #111827); margin: 5px 0 0; letter-spacing: -0.01em; }
.email-cap-sub { font-family: var(--font-sans); font-size: 12.5px; color: var(--soft, #6B7280); margin: 4px 0 0; }
.email-cap-form { display: flex; gap: 9px; align-items: center; flex: 0 0 auto; }
.email-cap-input {
  border: 1px solid var(--border, #E3E6EA); background: var(--surface, #FBFBFC); border-radius: 999px;
  padding: 11px 16px; font-family: var(--font-sans); font-size: 13px; color: var(--ink, #1F2937); min-width: 220px;
}
.email-cap-input:focus-visible { outline: 2px solid var(--accent, #4B5E8E); outline-offset: 2px; }
.email-cap-btn {
  background: var(--accent, #4B5E8E); color: #fff; border: 1px solid var(--accent, #4B5E8E);
  border-radius: 999px; padding: 11px 20px; font-family: var(--font-sans); font-size: 13px; font-weight: 700;
  cursor: pointer; white-space: nowrap; transition: background 200ms var(--ease, ease);
}
.email-cap-btn:hover { background: var(--accent-deep, #3C4D78); }
.email-cap.done { justify-content: flex-start; }
.email-cap-done { font-family: var(--font-sans); font-size: 14px; color: var(--accent-deep, #3C4D78); font-weight: 600; display: flex; align-items: center; gap: 9px; }
.email-cap-done .dot { width: 8px; height: 8px; border-radius: 50%; background: var(--gain, #3F7A4F); }

/* ---------- RECONCILED PROOF — section intro reframe ---------- */
.recon-head { margin-top: 8px; border-top: 1px solid var(--border, #E3E6EA); padding-top: 26px; }
.recon-eb { font-family: var(--font-sans); font-size: 11px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--soft, #6B7280); font-weight: 700; }
.recon-h { font-family: var(--font-display); font-weight: 700; font-size: clamp(20px, 2.6vw, 26px); letter-spacing: -0.02em; color: var(--ink-deep, #111827); margin: 6px 0 0; }
.recon-h em { font-style: normal; color: var(--accent, #4B5E8E); }
.recon-sub { font-family: var(--font-sans); font-size: 14px; color: var(--soft, #6B7280); margin: 8px 0 0; max-width: 62ch; line-height: 1.5; }

/* section intro shared (the eyes) */
.eyes-head { padding: 0 var(--page-gutter, 16px); margin-top: 30px; }
.eyes-eb { font-family: var(--font-sans); font-size: 11px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--soft, #6B7280); font-weight: 700; }
.eyes-h { font-family: var(--font-display); font-weight: 700; font-size: clamp(20px, 2.6vw, 26px); letter-spacing: -0.02em; color: var(--ink-deep, #111827); margin: 6px 0 0; }
.eyes-h em { font-style: normal; color: var(--accent, #4B5E8E); }

/* stage note — intro line above an expanded pipeline stage */
.stage-note { margin-top: 14px; font-family: var(--font-sans); font-size: 13px; color: var(--soft, #6B7280); }
.stage-note-eb { font-weight: 700; letter-spacing: 0.1em; text-transform: uppercase; font-size: 10.5px; color: var(--accent, #4B5E8E); margin-right: 8px; }

/* ---------- responsive ---------- */
@media (max-width: 860px) {
  .plan-grid { grid-template-columns: 1fr; gap: 16px; }
  .sys-pipe-row { flex-wrap: wrap; gap: 8px; }
  .sp-arrow { display: none; }
  /* drop the chevron notch on mobile so nothing clips; plain rounded boxes */
  .sp-stage { flex: 1 1 42%; clip-path: none !important; border-radius: var(--r, 10px); padding: 12px 14px; }
  .sp-stage.dual { flex: 1 1 100%; padding: 6px; }
  .sp-stage.dual .sp-dual-item { flex: 1; }
  .email-cap-form { width: 100%; }
  .email-cap-input { flex: 1; min-width: 0; }
}

/* ---------- mobile Option-D wrapper (dark page) ---------- */
.m-od-wrap { padding: 0 14px; }
.m-od-wrap .plan-panel { padding: 16px; }
.m-od-wrap .plan-hero-h { font-size: 22px; }
.m-od-wrap .sp-stage { background: #1B2128; border-color: #2A2E39; color: #E6EAF0; }
.m-od-wrap .sp-stage .sp-sub { color: #8FA0AE; }
.m-od-wrap .sp-stage.dual .sp-dual-item { background: #131722 !important; border-color: #2A2E39; color: #E6EAF0 !important; }
.m-od-wrap .sp-stage.active { background: var(--accent, #4B5E8E); border-color: var(--accent, #4B5E8E); color: #fff; }
.m-od-wrap .sp-stage.cta { background: rgba(129,151,206,0.14); border-color: var(--accent-lite, #8197CE); color: var(--accent-lite, #8197CE); }
.m-od-wrap .sp-stage.cta .sp-sub { color: var(--accent-lite, #8197CE); }
.m-od-wrap .sys-pipe-eb, .m-od-wrap .plan-hero-sub { color: #9CA3AE; }
.m-od-wrap .plan-hero-h { color: #fff; }
.m-od-wrap .plan-hero-eb { color: var(--accent-lite, #8197CE); }
.m-od-wrap .email-cap { background: #1B2837; border-color: #2A3D4D; }
.m-od-wrap .email-cap-h { color: #fff; }
.m-od-wrap .email-cap-sub { color: #AEB4BE; }
.m-od-wrap .email-cap-eb { color: var(--accent-lite, #8197CE); }
.m-od-wrap .email-cap-input { background: #0E1116; border-color: #2A3D4D; color: #E6EAF0; }
.m-od-wrap .email-cap-done { color: #C7D2DA; }
.m-od-eyes { padding: 26px 14px 0; }
.m-od-eyes .eyes-eb { color: #8FA0AE; }
.m-od-eyes .eyes-h { color: #fff; }

/* mobile slim brand header */
.m-headerbar {
  display: flex; align-items: center; justify-content: space-between; gap: 12px;
  padding: 12px 14px; position: sticky; top: 0; z-index: 30;
  background: rgba(14,17,22,0.92); backdrop-filter: blur(8px);
  border-bottom: 1px solid var(--border-dk, #2A2E39);
}
.m-hb-logo { display: inline-flex; align-items: center; font-family: var(--font-sans, sans-serif); font-size: 16px; font-weight: 700; letter-spacing: -0.01em; color: #fff; text-decoration: none; }
.m-hb-light { font-weight: 400; }
.m-hb-dot { width: 5px; height: 5px; border-radius: 50%; background: var(--accent-lite, #8197CE); margin: 0 5px; }
.m-hb-cta { background: var(--accent, #4B5E8E); color: #fff; border: none; border-radius: 999px; padding: 9px 16px; font-family: var(--font-sans, sans-serif); font-size: 13px; font-weight: 700; cursor: pointer; }
.m-hb-menu { display: inline-flex; flex-direction: column; gap: 4px; background: none; border: none; cursor: pointer; padding: 6px; margin-left: -6px; }
.m-hb-menu span { display: block; width: 20px; height: 2px; border-radius: 2px; background: #E6EAF0; }
.m-hb-scrim { position: fixed; inset: 0; background: rgba(10,14,20,0.5); z-index: 39; }
.m-hb-menu-panel {
  position: absolute; top: calc(100% + 6px); left: 12px; z-index: 40;
  background: #1B2128; border: 1px solid var(--border-dk, #2A2E39); border-radius: 12px;
  padding: 8px; min-width: 220px; display: flex; flex-direction: column;
  box-shadow: 0 18px 50px rgba(10,14,20,0.5);
}
.m-hb-menu-item {
  display: block; padding: 11px 14px; border-radius: 8px; text-decoration: none;
  font-family: var(--font-sans, sans-serif); font-size: 14px; font-weight: 600; color: #E6EAF0;
}
.m-hb-menu-item:active { background: rgba(129,151,206,0.16); }

/* ============================================================
   MARKET DATA SHEET — self-contained raw indicator verification.
   Scoped under .md-sheet-sec so it renders identically on desktop
   (styles.css) and mobile (m-styles.css) without colliding.
   ============================================================ */
.md-sheet-sec {
  background: var(--cream-1, #F2F4F6);
  padding: 40px 0 84px; margin-top: 0;
}
.md-sheet-wrap { max-width: none; margin: 0 auto; padding: 0 16px; }
.md-sheet-head { margin-bottom: 26px; }
.md-sheet-h {
  font-family: var(--font-display); font-weight: 700; font-size: clamp(28px, 3.4vw, 38px);
  letter-spacing: -0.01em; color: var(--ink-deep, #111827); margin: 0; line-height: 1.04;
}
.md-sheet-meta { display: flex; gap: 24px; margin-top: 18px; flex-wrap: wrap; }
.md-sheet-meta .mm { display: flex; flex-direction: column; gap: 3px; }
.md-sheet-meta .mm .k { font-family: var(--font-sans); font-size: 9.5px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--soft, #6B7280); }
.md-sheet-meta .mm .v { font-family: var(--font-sans); font-size: 13.5px; font-weight: 700; color: var(--ink, #1F2937); }
@media (max-width: 760px) { .md-sheet-sec { padding: 32px 0 40px; } .md-sheet-wrap { padding: 0 14px; } }
.md-sheet-sec .md-panel { max-width: none; margin: 0; animation: none; transform: none; }
.md-sheet-sec .md-grid { display: block; }
.md-sheet-sec .md-card {
  background: transparent;
  border: none;
  border-radius: 0; padding: 0;
  box-shadow: none;
}
.md-sheet-sec .md-h { display: flex; flex-direction: column; gap: 5px; margin-bottom: 16px; }
.md-sheet-sec .md-eb {
  font-family: var(--font-mono, monospace); font-size: 10.5px; font-weight: 700;
  letter-spacing: 0.16em; text-transform: uppercase; color: var(--accent-lite, #8197CE);
}
.md-sheet-sec .md-t { font-family: var(--font-sans, sans-serif); font-size: 13px; color: #9CA3AE; line-height: 1.5; max-width: 62ch; }
.md-sheet-sec .mdv-list { display: flex; flex-direction: column; gap: 0; }
.md-sheet-sec .mdv-group {
  border: none; border-bottom: 1px solid #232C38; border-radius: 0; overflow: visible;
  background: transparent;
}
.md-sheet-sec .mdv-group:last-child { border-bottom: none; }
.md-sheet-sec .mdv-group.open { border-color: #232C38; background: transparent; }
.md-sheet-sec .mdv-head {
  appearance: none; width: 100%; border: none; background: transparent; cursor: pointer;
  display: flex; align-items: center; justify-content: space-between; gap: 10px;
  padding: 13px 16px; text-align: left;
  transition: background 160ms var(--ease, ease);
}
.md-sheet-sec .mdv-head { padding: 14px 4px; }
.md-sheet-sec .mdv-head:hover { background: transparent; }
.md-sheet-sec .mdv-head:hover .mdv-name { color: var(--accent-lite, #8197CE); }
.md-sheet-sec .mdv-name { font-family: var(--font-display, sans-serif); font-weight: 700; font-size: 14px; color: #EAEFF4; letter-spacing: -0.005em; line-height: 1.25; }
.md-sheet-sec .mdv-head-r { display: inline-flex; align-items: center; gap: 10px; flex-shrink: 0; }
.md-sheet-sec .mdv-badge {
  font-family: var(--font-mono, monospace); font-size: 10px; font-weight: 700;
  padding: 3px 8px; border-radius: 5px; white-space: nowrap; letter-spacing: 0.03em;
}
.md-sheet-sec .mdv-badge.bull { background: rgba(105,176,131,0.18); color: var(--gain-dk, #69B083); }
.md-sheet-sec .mdv-badge.bear { background: rgba(204,122,108,0.18); color: var(--loss-dk, #CC7A6C); }
.md-sheet-sec .mdv-badge.neut { background: rgba(129,151,206,0.20); color: var(--accent-lite, #8197CE); }
.md-sheet-sec .mdv-caret { font-size: 9px; color: #8FA0AE; }
.md-sheet-sec .mdv-detail { border-top: none; padding: 0 4px 14px; background: transparent; }
.md-sheet-sec .mdf-row {
  display: grid; grid-template-columns: 1.3fr 1.6fr 64px 50px; gap: 8px;
  padding: 9px 8px; align-items: start; border-bottom: 1px dashed rgba(255,255,255,0.06);
  border-radius: 6px; transition: background 150ms var(--ease, ease), transform 150ms var(--ease, ease);
}
.md-sheet-sec .mdf-row:last-child { border-bottom: none; }
.md-sheet-sec .mdf-row:not(.mdf-head-row):hover {
  background: rgba(129,151,206,0.12); transform: translateX(5px);
  box-shadow: inset 3px 0 0 var(--accent-lite, #8197CE);
}
.md-sheet-sec .mdf-head-row { border-bottom: none; padding-bottom: 2px; }
.md-sheet-sec .mdf-head-row:hover { background: transparent; transform: none; box-shadow: none; }
.md-sheet-sec .mdf-head-row span {
  font-family: var(--font-mono, monospace); font-size: 8.5px; letter-spacing: 0.12em;
  text-transform: uppercase; color: #7E8893; font-weight: 700;
}
.md-sheet-sec .mdf-head-row span.c { text-align: center; }
.md-sheet-sec .mdf-ind { font-family: var(--font-sans, sans-serif); font-size: 12px; font-weight: 600; color: #EDF1F6 !important; line-height: 1.35; }
.md-sheet-sec .mdf-read { font-family: var(--font-mono, monospace); font-size: 10.5px; color: #B4BCC8 !important; line-height: 1.45; }
.md-sheet-sec .mdf-stat {
  text-align: center; font-family: var(--font-mono, monospace); font-size: 9px; font-weight: 800;
  letter-spacing: 0.04em; padding: 2px 4px; border-radius: 4px; height: fit-content;
}
.md-sheet-sec .mdf-stat.bull { background: rgba(105,176,131,0.18); color: var(--gain-dk, #69B083); }
.md-sheet-sec .mdf-stat.bear { background: rgba(204,122,108,0.18); color: var(--loss-dk, #CC7A6C); }
.md-sheet-sec .mdf-stat.neut { background: rgba(129,151,206,0.20); color: var(--accent-lite, #8197CE); }
.md-sheet-sec .mdf-stat.none { background: transparent; color: #8FA0AE; }
.md-sheet-sec .mdf-conf { text-align: center; font-family: var(--font-mono, monospace); font-size: 9.5px; font-weight: 800; }
.md-sheet-sec .mdf-conf.high { color: var(--gain-dk, #69B083); }
.md-sheet-sec .mdf-conf.med { color: var(--accent-lite, #8197CE); }
.md-sheet-sec .mdf-conf.low { color: var(--loss-dk, #CC7A6C); }
.md-sheet-sec .mdf-src { font-family: var(--font-mono, monospace); font-size: 9.5px; color: #7E8893; letter-spacing: 0.04em; margin-top: 10px; }

/* mobile: give the light sheet breathing room on the dark page */
.m-od-mdsheet { padding: 0 14px 8px; }
.m-od-mdsheet .md-sheet-sec { padding: 0; }
@media (max-width: 760px) {
  .md-sheet-sec .mdf-row { grid-template-columns: 1fr 1fr 56px 44px; }
}

/* ============================================================
   LIGHT THEME — Premarket Plan band (matches Market Data).
   ============================================================ */
.plan-hero { background: var(--cream-1, #F2F4F6); }
.plan-hero .plan-hero-h { color: var(--ink-deep, #111827); }
.plan-hero .plan-hero-meta .phm .k { color: var(--soft, #6B7280); }
.plan-hero .plan-hero-meta .phm .v { color: var(--ink, #1F2937); }
.plan-hero .a2-row { color: var(--ink, #1F2937); }
.plan-hero .allow-2col .a2-rule { background: var(--border, #E3E6EA); }
@media (max-width: 700px) { .plan-hero .allow-2col .a2-col.no { border-top-color: var(--border, #E3E6EA); } }
/* price scale */
.plan-hero .price-scale-wrap { background: #FFFFFF; border: 1px solid var(--border, #E3E6EA); }
.plan-hero .price-scale-h { color: var(--soft, #6B7280); }
.plan-hero .price-scale-h span { color: var(--soft, #6B7280) !important; }
.plan-hero .ps-tick-price { color: var(--ink, #1F2937) !important; }
.plan-hero .ps-tier-card { background: #F4F6F8; }
.plan-hero .ps-tier-name { color: var(--ink-deep, #111827); }
.plan-hero .ps-tier-leg-l { color: var(--soft, #6B7280); }
.plan-hero .ps-tier-leg-v { color: var(--ink, #1F2937); }
.plan-hero .ps-em-band { background: rgba(75,94,142,0.06); }
/* plan candidates */
.plan-hero .plan-cand { background: #FFFFFF; border: 1px solid var(--border, #E3E6EA); }
.plan-hero .plan-cand .open-pos-note, .plan-hero .pc-head span, .plan-hero .pc-when { color: var(--soft, #6B7280); }
.plan-hero .pc-row { border-bottom-color: var(--border-soft, #ECEEF1); }
.plan-hero .pc-name { color: var(--ink-deep, #111827); }
.plan-hero .pc-trig { color: var(--ink, #1F2937); }
.plan-hero .pc-dist { color: var(--ink, #1F2937); }
.plan-hero .pc-cond { color: var(--soft, #5A6473); }
.plan-hero .pc-state.carried, .plan-hero .pc-state.no-trigger, .plan-hero .pc-state.touched-no-trigger { background: rgba(31,41,55,0.06); color: var(--soft, #5A6473); }
/* open positions */
.plan-hero .open-pos { background: #FFFFFF; border: 1px solid var(--border, #E3E6EA); }
.plan-hero .open-pos-note { color: var(--soft, #6B7280); }
.plan-hero .open-pos-empty { color: var(--soft, #5A6473); }
.plan-hero .open-pos-row { background: #F4F6F8; border: 1px solid var(--border, #E3E6EA); }
.plan-hero .opr-label { color: var(--ink-deep, #111827); }
.plan-hero .opr-size, .plan-hero .opr-legs span { color: var(--ink, #1F2937); }
.plan-hero .opr-legs span i { color: var(--soft, #6B7280); }
.plan-hero .opr-action-t { color: var(--ink, #1F2937); }
/* tv charting */
.plan-hero .tv-charting { background: #FFFFFF; border: 1px solid var(--border, #E3E6EA); }
.plan-hero .tv-charting-foot { color: var(--soft, #6B7280); }
