:root { color-scheme: dark; }
* { box-sizing: border-box; }
html, body { min-height: 100%; }
body {
  margin: 0;
  background:
    radial-gradient(circle at 16% 0%, rgba(243, 88, 0, .10), transparent 32%),
    linear-gradient(180deg, #050505 0%, #09090a 46%, #050505 100%);
  color: #f5f5f3;
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}
button, input { font: inherit; }
.energy-topbar {
  width: min(100%, 1240px);
  margin: 0 auto;
  padding: 9px 12px 2px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
}
.energy-brand {
  min-width: 0;
  display: inline-flex;
  align-items: center;
  gap: 9px;
  color: #f5f5f3;
  font-size: 12px;
  font-weight: 850;
  letter-spacing: 0;
  text-decoration: none;
  white-space: nowrap;
}
.energy-brand-mark {
  width: 26px;
  height: 26px;
  border: 1px solid rgba(243,88,0,.32);
  border-radius: 7px;
  background:
    linear-gradient(145deg, rgba(243,88,0,.22), rgba(35,199,104,.08)),
    rgba(255,255,255,.04);
  color: #fff3ea;
  display: inline-grid;
  place-items: center;
  font-size: 11px;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.08);
}
.energy-nav-links {
  min-width: 0;
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 18px;
  color: rgba(245,245,243,.56);
  font-size: 11px;
  font-weight: 760;
  overflow-x: auto;
  scrollbar-width: none;
}
.energy-nav-links::-webkit-scrollbar { display: none; }
.energy-nav-links a {
  flex: 0 0 auto;
  color: rgba(245,245,243,.70);
  text-decoration: none;
  transition: color .18s ease;
}
.energy-nav-links a:hover,
.energy-nav-links a:focus-visible { color: #ffd6bf; outline: none; }
.vet-page { width: 100%; padding: 8px 12px 12px; }
.vet-shell {
  width: min(100%, 1240px);
  margin: 0 auto;
  border: 1px solid rgba(255,255,255,.075);
  border-radius: 24px;
  background:
    radial-gradient(circle at 20% 0%, rgba(243,88,0,.08), transparent 34%),
    linear-gradient(180deg, rgba(255,255,255,.036), rgba(255,255,255,.012));
  box-shadow: 0 24px 80px rgba(0,0,0,.46);
  padding: 12px 14px 14px;
}
.vet-live-row { display: flex; flex-wrap: wrap; gap: 10px; align-items: center; color: rgba(245,245,243,.56); font-size: 11px; font-weight: 750; text-transform: uppercase; letter-spacing: .02em; }
.vet-live { color: rgba(245,245,243,.9); display: inline-flex; align-items: center; gap: 8px; }
.vet-live::before { content: ""; width: 7px; height: 7px; border-radius: 50%; background: #f35800; box-shadow: 0 0 18px rgba(243,88,0,.82); }
.vet-live-pill {
  height: 34px;
  display: inline-flex;
  align-items: center;
  flex: 0 0 auto;
  color: rgba(245,245,243,.9);
  font-size: 11px;
  font-weight: 820;
  letter-spacing: .04em;
  text-transform: uppercase;
}
.vet-sync { color: rgba(243,88,0,.9); }
.vet-top-signal { color: rgba(245,245,243,.64); }
.vet-top-signal strong { color: rgba(255,214,191,.92); font-weight: 820; }
.vet-title { margin: 8px 0 0; font-size: clamp(20px, 2.5vw, 30px); line-height: 1.05; letter-spacing: 0; font-weight: 760; }
.vet-subtitle { margin: 4px 0 0; color: rgba(245,245,243,.48); font-size: 13px; }
.vet-signal-wrap { position: relative; flex: 0 0 auto; }
.vet-signal-panel {
  width: min(390px, 38vw);
  flex: 0 0 auto;
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 14px;
  background: rgba(255,255,255,.035);
  padding: 9px 11px;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.035);
}
.vet-signal-kicker {
  display: block;
  color: rgba(245,245,243,.42);
  font-size: 10px;
  font-weight: 780;
  letter-spacing: .05em;
  text-transform: uppercase;
}
.vet-signal-panel strong {
  display: block;
  margin-top: 3px;
  font-size: 15px;
  line-height: 1.15;
  color: #f5f5f3;
}
.vet-signal-panel p {
  margin: 4px 0 0;
  color: rgba(245,245,243,.50);
  font-size: 11px;
  line-height: 1.25;
  font-weight: 650;
}
.vet-signal-chips { display: flex; flex-wrap: wrap; gap: 5px; margin-top: 6px; }
.vet-mini-chip {
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 999px;
  padding: 4px 7px;
  color: rgba(245,245,243,.58);
  background: rgba(255,255,255,.032);
  font-size: 10px;
  font-weight: 760;
  white-space: nowrap;
}
.vet-mini-chip.good { color: #8ef0b4; border-color: rgba(35,199,104,.18); background: rgba(35,199,104,.08); }
.vet-mini-chip.neutral { color: #d0d0ce; }
.vet-mini-chip.bad { color: #ffaaa2; border-color: rgba(240,82,69,.18); background: rgba(240,82,69,.08); }
.vet-signal-btn {
  width: 220px;
  height: 42px;
  border: 1px solid rgba(255,255,255,.10);
  border-radius: 13px;
  background: rgba(255,255,255,.045);
  color: rgba(245,245,243,.88);
  padding: 0 13px;
  display: inline-flex;
  align-items: center;
  justify-content: space-between;
  gap: 9px;
  cursor: pointer;
  font-size: 12px;
  font-weight: 720;
  transition: .18s ease;
}
.vet-signal-btn:hover { border-color: rgba(243,88,0,.35); background: rgba(243,88,0,.10); }
.vet-chevron { color: rgba(245,245,243,.38); transition: transform .18s ease; }
.vet-signal-wrap.is-open .vet-chevron { transform: rotate(180deg); }
.vet-menu {
  position: absolute;
  right: 0;
  top: 48px;
  width: 292px;
  z-index: 20;
  border: 1px solid rgba(255,255,255,.10);
  border-radius: 14px;
  background: rgba(10,10,11,.96);
  box-shadow: 0 20px 60px rgba(0,0,0,.5);
  padding: 6px;
  display: none;
}
.vet-signal-wrap.is-open .vet-menu { display: block; }
.vet-menu-item {
  width: 100%;
  border: 0;
  border-radius: 10px;
  background: transparent;
  color: #f5f5f3;
  display: flex;
  gap: 11px;
  align-items: flex-start;
  text-align: left;
  padding: 10px;
  cursor: pointer;
}
.vet-menu-item:hover, .vet-menu-item.is-active { background: rgba(255,255,255,.065); }
.vet-dot { width: 8px; height: 8px; margin-top: 6px; border-radius: 50%; background: #9ca3af; flex: 0 0 auto; }
.vet-dot.good { background: #23c768; }
.vet-dot.bad { background: #f05245; }
.vet-menu-title { display: block; font-size: 13px; font-weight: 740; }
.vet-menu-sub { display: block; margin-top: 3px; color: rgba(245,245,243,.42); font-size: 12px; line-height: 1.45; }
.vet-controls { padding-top: 0; display: grid; gap: 7px; }
.vet-search-row {
  display: flex;
  align-items: center;
  gap: 10px;
}
.vet-search {
  width: 100%;
  min-width: 0;
  height: 42px;
  border-radius: 13px;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.045);
  outline: none;
  color: #f5f5f3;
  padding: 0 14px;
  font-size: 14px;
}
.vet-search:focus { border-color: rgba(243,88,0,.45); background: rgba(255,255,255,.06); }
.vet-search::placeholder { color: rgba(245,245,243,.34); }
.vet-tabs { display: flex; gap: 8px; overflow-x: auto; scrollbar-width: none; }
.vet-tabs::-webkit-scrollbar { display: none; }
.vet-tab {
  height: 34px;
  flex: 0 0 auto;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.09);
  background: rgba(255,255,255,.04);
  color: rgba(245,245,243,.62);
  padding: 0 14px;
  font-size: 12px;
  font-weight: 700;
  cursor: pointer;
}
.vet-tab.is-active { border-color: rgba(243,88,0,.55); background: rgba(243,88,0,.15); color: #ffe7da; }
.vet-table-wrap {
  margin-top: 8px;
  overflow-x: auto;
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 18px;
  background: rgba(0,0,0,.22);
  scrollbar-color: rgba(255,255,255,.18) transparent;
}
.vet-table { width: 100%; min-width: 760px; border-collapse: collapse; text-align: left; font-size: 13px; }
.vet-col-rank { width: 42px; }
.vet-col-market { width: 230px; }
.vet-col-price { width: 140px; }
.vet-col-curve { width: 132px; }
.vet-col-momentum { width: 150px; }
.vet-col-valki { width: 140px; }
.vet-col-updated { width: 110px; }
.vet-table th { padding: 12px 12px; color: rgba(245,245,243,.42); font-size: 11px; font-weight: 760; border-bottom: 1px solid rgba(255,255,255,.07); }
.vet-table td { padding: 12px; border-bottom: 1px solid rgba(255,255,255,.055); vertical-align: middle; }
.vet-table tr:last-child td { border-bottom: 0; }
.vet-table tbody tr { transition: background .16s ease, box-shadow .16s ease; }
.market-row { cursor: pointer; }
.market-row:hover { background: rgba(243,88,0,.052); }
.market-row:focus-visible { outline: 1px solid rgba(243,88,0,.62); outline-offset: -1px; }
.market-row.is-selected {
  background: rgba(243,88,0,.09);
  box-shadow: inset 3px 0 0 #f35800;
}
.right { text-align: right; }
.rank { width: 42px; color: rgba(245,245,243,.42); font-weight: 650; }
.market-cell { min-width: 210px; }
.market-link { color: inherit; text-decoration: none; display: flex; align-items: center; gap: 11px; min-width: 0; }
.flag { width: 32px; height: 32px; flex: 0 0 32px; border-radius: 50%; overflow: hidden; display: inline-flex; align-items: center; justify-content: center; background: rgba(255,255,255,.06); border: 1px solid rgba(255,255,255,.14); color: rgba(245,245,243,.7); font-size: 10px; font-weight: 800; }
.flag img { width: 100%; height: 100%; object-fit: cover; object-position: center; display: block; }
.market-name { display: block; max-width: 145px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; font-weight: 760; color: #f5f5f3; }
.market-code { display: block; margin-top: 2px; color: rgba(245,245,243,.38); font-size: 11px; font-weight: 680; }
.price { font-variant-numeric: tabular-nums; color: #f5f5f3; font-weight: 800; white-space: nowrap; }
.status { display: block; margin-top: 4px; font-size: 11px; font-weight: 760; }
.status.good { color: #23c768; }
.status.neutral { color: #b8b8b5; }
.status.bad { color: #f05245; }
.momentum {
  display: inline-flex;
  min-height: 26px;
  align-items: center;
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 999px;
  padding: 0 10px;
  background: rgba(255,255,255,.035);
  font-size: 11px;
  font-weight: 800;
  white-space: nowrap;
}
.momentum.good { color: #8ef0b4; border-color: rgba(35,199,104,.20); background: rgba(35,199,104,.08); }
.momentum.neutral { color: #d0d0ce; }
.momentum.bad { color: #ffaaa2; border-color: rgba(240,82,69,.22); background: rgba(240,82,69,.08); }
.valki { color: rgba(255,214,191,.9); font-weight: 780; white-space: nowrap; font-variant-numeric: tabular-nums; }
.updated { color: rgba(245,245,243,.56); font-size: 12px; font-weight: 650; font-variant-numeric: tabular-nums; white-space: nowrap; }
.updated-wrap { display: inline-flex; flex-direction: column; align-items: flex-end; gap: 4px; }
.stale-chip {
  display: inline-flex;
  align-items: center;
  width: max-content;
  max-width: 128px;
  border: 1px solid rgba(243,88,0,.20);
  border-radius: 999px;
  padding: 2px 7px;
  color: rgba(255,214,191,.82);
  background: rgba(243,88,0,.08);
  font-size: 9px;
  font-weight: 780;
  line-height: 1.2;
  white-space: nowrap;
}
.spark { width: 104px; height: 36px; border-radius: 10px; border: 1px solid rgba(255,255,255,.07); background: rgba(255,255,255,.035); padding: 4px 6px; margin-left: auto; }
.spark svg { width: 100%; height: 100%; display: block; }
.spark.loading path { stroke: #737373; opacity: .6; animation: vetPulse 1.7s ease-in-out infinite; }
.spark.empty { display: inline-grid; place-items: center; color: rgba(245,245,243,.42); font-size: 13px; font-weight: 760; }
.spark.empty svg { display: none; }
.spark.empty::after { content: "—"; }
.summary-grid { margin-top: 12px; display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 12px; }
.summary-card { min-height: 90px; border: 1px solid rgba(255,255,255,.08); border-radius: 16px; background: rgba(255,255,255,.045); padding: 14px; box-shadow: 0 14px 40px rgba(0,0,0,.18); }
.summary-icon { width: 24px; height: 24px; border-radius: 50%; display: grid; place-items: center; font-size: 12px; font-weight: 900; margin-bottom: 10px; border: 1px solid rgba(156,163,175,.20); color: #d4d4d4; background: rgba(156,163,175,.10); }
.summary-icon.good { color: #23c768; border-color: rgba(35,199,104,.22); background: rgba(35,199,104,.11); }
.summary-icon.bad { color: #f05245; border-color: rgba(240,82,69,.22); background: rgba(240,82,69,.11); }
.summary-label { color: rgba(245,245,243,.48); font-size: 12px; font-weight: 650; }
.summary-value { margin-top: 4px; color: #f5f5f3; font-size: 16px; font-weight: 820; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.vet-footer { margin-top: 14px; display: flex; justify-content: space-between; gap: 12px; color: rgba(245,245,243,.36); font-size: 11px; font-weight: 650; }
.empty { text-align: center; padding: 42px 16px; color: rgba(245,245,243,.44); }
.detail-backdrop {
  position: fixed;
  inset: 0;
  z-index: 80;
  background: rgba(0,0,0,.24);
  backdrop-filter: blur(1.5px);
  animation: vetFadeIn .16s ease-out;
}
.detail-panel {
  position: fixed;
  top: 14px;
  right: 14px;
  bottom: 14px;
  z-index: 90;
  width: min(420px, calc(100vw - 28px));
  border: 1px solid rgba(255,255,255,.10);
  border-radius: 24px;
  background:
    radial-gradient(circle at 50% 0%, rgba(243,88,0,.12), transparent 38%),
    linear-gradient(180deg, rgba(18,18,19,.98), rgba(8,8,9,.98));
  box-shadow: 0 28px 90px rgba(0,0,0,.62);
  padding: 18px;
  overflow: auto;
  overflow-anchor: none;
  animation: vetDrawerIn .22s cubic-bezier(.2,.8,.2,1);
}
.detail-close {
  appearance: none;
  position: absolute;
  top: 14px;
  right: 14px;
  width: 34px;
  height: 34px;
  border-radius: 50%;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.045);
  color: rgba(245,245,243,.72);
  cursor: pointer;
  font-size: 22px;
  line-height: 1;
  margin: 0;
  padding: 0;
  text-decoration: none;
  display: grid;
  place-items: center;
}
.detail-close:hover { border-color: rgba(243,88,0,.34); color: #f5f5f3; }
.detail-head { display: flex; gap: 12px; align-items: center; padding-right: 44px; }
.detail-flag { width: 40px; height: 40px; flex-basis: 40px; }
.detail-head h2 { margin: 0; font-size: 24px; line-height: 1.1; letter-spacing: 0; }
.detail-head p { margin: 5px 0 0; color: rgba(245,245,243,.45); font-size: 12px; font-weight: 720; }
.detail-metrics, .detail-grid {
  margin-top: 18px;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
}
.detail-metric {
  border: 1px solid rgba(255,255,255,.075);
  border-radius: 14px;
  background: rgba(255,255,255,.035);
  padding: 11px;
}
.detail-metric span {
  display: block;
  color: rgba(245,245,243,.43);
  font-size: 11px;
  font-weight: 760;
}
.detail-metric strong {
  display: block;
  margin-top: 5px;
  color: #f5f5f3;
  font-size: 15px;
  line-height: 1.2;
  font-weight: 820;
  min-height: 18px;
}
.detail-chart {
  position: relative;
  margin-top: 18px;
  height: 240px;
  min-height: 240px;
  max-height: 240px;
  border: 1px solid rgba(255,255,255,.075);
  border-radius: 18px;
  background:
    linear-gradient(rgba(255,255,255,.045) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.035) 1px, transparent 1px),
    rgba(255,255,255,.025);
  background-size: 100% 33.333%, 25% 100%, auto;
  padding: 12px 12px 26px;
  touch-action: none;
  contain: layout paint;
}
.detail-chart::after {
  content: "";
  position: absolute;
  inset: 12px 12px 48px;
  border-radius: 14px;
  background: linear-gradient(90deg, transparent 0%, rgba(245,245,243,.07) 45%, transparent 78%);
  opacity: 0;
  pointer-events: none;
  transform: translateX(-55%);
}
.detail-chart.is-refreshing::after {
  opacity: .68;
  animation: vetChartRefresh 1.9s ease-in-out infinite;
}
.detail-chart.is-refreshing::before {
  content: "Marketpunten laden";
  position: absolute;
  left: 20px;
  bottom: 32px;
  z-index: 4;
  color: rgba(245,245,243,.45);
  font-size: 11px;
  font-weight: 760;
  letter-spacing: .01em;
  pointer-events: none;
}
.detail-chart svg { width: 100%; height: calc(100% - 22px); display: block; overflow: hidden; }
.detail-chart.loading path { opacity: .62; animation: vetPulse 1.7s ease-in-out infinite; }
.detail-area {
  opacity: .14;
  stroke: none;
}
.detail-area.good { fill: #23C768; }
.detail-area.neutral { fill: #9CA3AF; }
.detail-area.bad { fill: #F05245; }
.detail-history-glow {
  opacity: .20;
  filter: blur(.2px);
}
.detail-history-line {
  filter: drop-shadow(0 0 10px rgba(245,245,243,.18));
}
.detail-forecast-line {
  opacity: .78;
  stroke-dasharray: 4 7;
  filter: drop-shadow(0 0 8px rgba(243,88,0,.12));
}
.detail-now-timeline {
  stroke: rgba(245,245,243,.20);
  stroke-width: 1;
  stroke-dasharray: 1 7;
  vector-effect: non-scaling-stroke;
}
.detail-now-line {
  stroke: rgba(243,88,0,.42);
  stroke-width: 1;
  stroke-dasharray: 2 5;
  vector-effect: non-scaling-stroke;
  opacity: 1;
}
.detail-now-dot {
  fill: #f35800;
  stroke: rgba(255,231,218,.95);
  stroke-width: 2;
  filter: drop-shadow(0 0 10px rgba(243,88,0,.55));
  opacity: 1;
}
.detail-crosshair {
  stroke: rgba(243,88,0,.45);
  stroke-width: 1;
  stroke-dasharray: 2 5;
  opacity: 0;
  vector-effect: non-scaling-stroke;
}
.detail-hover-dot {
  fill: #f35800;
  stroke: rgba(255,231,218,.96);
  stroke-width: 2;
  opacity: 0;
  filter: drop-shadow(0 0 10px rgba(243,88,0,.55));
}
.detail-chart.is-hovering .detail-crosshair,
.detail-chart.is-hovering .detail-hover-dot {
  opacity: 1;
}
.detail-chart.is-hovering .detail-now-line,
.detail-chart.is-hovering .detail-now-dot { opacity: 0; }
.detail-tooltip {
  position: absolute;
  z-index: 3;
  left: 0;
  top: 0;
  width: 104px;
  min-width: 104px;
  max-width: 104px;
  transform: translate3d(-999px, -999px, 0);
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 10px;
  background: rgba(8,8,9,.92);
  box-shadow: 0 12px 34px rgba(0,0,0,.40);
  padding: 8px 9px;
  pointer-events: none;
  opacity: 0;
  will-change: transform;
  transform-origin: center center;
  contain: layout paint;
}
.detail-chart.is-hovering .detail-tooltip { opacity: 1; }
.detail-chart.is-hovering .detail-now-tooltip { opacity: 0; }
.detail-now-tooltip {
  position: absolute;
  z-index: 2;
  left: 0;
  top: 0;
  width: 112px;
  min-width: 112px;
  max-width: 112px;
  border: 1px solid rgba(243,88,0,.26);
  border-radius: 10px;
  background: rgba(15,10,8,.92);
  box-shadow: 0 12px 34px rgba(0,0,0,.34), 0 0 22px rgba(243,88,0,.10);
  padding: 8px 9px;
  pointer-events: none;
  transform-origin: center center;
  contain: layout paint;
}
.detail-now-tooltip.is-right { transform: translate3d(14px, -50%, 0); }
.detail-now-tooltip.is-left { transform: translate3d(calc(-100% - 14px), -50%, 0); }
.detail-now-tooltip strong,
.detail-now-tooltip span,
.detail-now-tooltip em { display: block; }
.detail-now-tooltip strong { color: #f5f5f3; font-size: 13px; line-height: 1.1; font-weight: 840; }
.detail-now-tooltip span { margin-top: 4px; color: #ffd6bf; font-size: 11px; font-weight: 820; }
.detail-now-tooltip em { margin-top: 3px; color: rgba(245,245,243,.55); font-size: 11px; font-style: normal; font-weight: 720; }
.detail-tooltip strong,
.detail-tooltip span,
.detail-tooltip em { display: block; }
.detail-tooltip strong { color: #f5f5f3; font-size: 13px; line-height: 1.1; font-weight: 840; }
.detail-tooltip span { margin-top: 4px; color: rgba(245,245,243,.55); font-size: 11px; font-weight: 720; }
.detail-tooltip em { margin-top: 3px; font-size: 11px; font-style: normal; font-weight: 800; }
.detail-tooltip em.good { color: #8ef0b4; }
.detail-tooltip em.neutral { color: #d0d0ce; }
.detail-tooltip em.bad { color: #ffaaa2; }
.detail-axis {
  position: absolute;
  left: 12px;
  right: 12px;
  bottom: 8px;
  color: rgba(245,245,243,.30);
  font-size: 10px;
  font-weight: 700;
  font-variant-numeric: tabular-nums;
  height: 12px;
}
.detail-axis span {
  position: absolute;
  top: 0;
  transform: translateX(-50%);
  white-space: nowrap;
  line-height: 1;
}
.detail-axis .is-start {
  transform: translateX(0);
  color: rgba(245,245,243,.28);
}
.detail-axis .is-end {
  transform: translateX(-100%);
  color: rgba(245,245,243,.28);
}
.detail-axis .is-now {
  z-index: 2;
  color: rgba(255,214,191,.94);
  font-weight: 820;
  text-shadow: 0 0 12px rgba(243,88,0,.28);
}
.detail-axis .is-now.is-shifted {
  color: rgba(255,214,191,.88);
}
.detail-intelligence {
  margin-top: 14px;
  border: 1px solid rgba(255,255,255,.075);
  border-radius: 16px;
  background: rgba(255,255,255,.03);
  padding: 12px;
  min-height: 126px;
}
.detail-section-label {
  display: block;
  margin-bottom: 8px;
  color: rgba(245,245,243,.42);
  font-size: 10px;
  font-weight: 780;
  letter-spacing: .05em;
  text-transform: uppercase;
}
.intel-item {
  position: relative;
  padding-left: 14px;
  color: rgba(245,245,243,.72);
  font-size: 12px;
  line-height: 1.45;
  font-weight: 680;
}
.intel-item + .intel-item { margin-top: 6px; }
.intel-item::before {
  content: "";
  position: absolute;
  left: 0;
  top: .62em;
  width: 5px;
  height: 5px;
  border-radius: 50%;
  background: rgba(243,88,0,.75);
  box-shadow: 0 0 12px rgba(243,88,0,.35);
}
.detail-source {
  margin-top: 14px;
  color: rgba(245,245,243,.42);
  font-size: 11px;
  font-weight: 700;
}
.detail-link {
  margin-top: 14px;
  height: 40px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0 16px;
  color: #ffe7da;
  background: rgba(243,88,0,.14);
  border: 1px solid rgba(243,88,0,.36);
  text-decoration: none;
  font-size: 12px;
  font-weight: 820;
}
.detail-link:hover { background: rgba(243,88,0,.20); }
@keyframes vetPulse { 0%,100% { opacity: .42; } 50% { opacity: .78; } }
@keyframes vetFadeIn { from { opacity: 0; } to { opacity: 1; } }
@keyframes vetChartRefresh {
  0% { transform: translateX(-55%); opacity: 0; }
  22% { opacity: .58; }
  78% { opacity: .42; }
  100% { transform: translateX(55%); opacity: 0; }
}
@keyframes vetDrawerIn {
  from { opacity: 0; transform: translateX(16px); }
  to { opacity: 1; transform: translateX(0); }
}
@media (max-width: 860px) {
  .energy-topbar { padding: 8px 8px 0; gap: 10px; }
  .energy-brand { font-size: 11px; gap: 7px; }
  .energy-brand-mark { width: 24px; height: 24px; border-radius: 7px; font-size: 10px; }
  .energy-nav-links { gap: 13px; font-size: 10px; justify-content: flex-start; }
  .vet-page { padding: 8px; }
  .vet-shell { border-radius: 20px; padding: 10px; }
  .vet-signal-panel { min-width: 0; width: 100%; }
  .vet-search-row { gap: 8px; }
  .vet-signal-wrap { align-self: stretch; width: auto; max-width: 42%; }
  .vet-signal-btn { width: clamp(128px, 34vw, 172px); padding: 0 10px; font-size: 11px; }
  .vet-signal-btn .status { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
  .vet-menu { left: 0; right: auto; width: min(292px, calc(100vw - 36px)); }
  .summary-grid { grid-template-columns: 1fr 1fr; }
  .vet-table { min-width: 680px; }
  .market-cell { min-width: 160px; }
  .market-name { max-width: 92px; }
  .detail-panel {
    top: auto;
    left: 0;
    right: 0;
    bottom: 0;
    width: 100%;
    max-height: 88vh;
    border-radius: 24px 24px 0 0;
    padding: 18px 14px 20px;
    animation-name: vetSheetIn;
  }
  .detail-chart {
    height: 210px;
    min-height: 210px;
    max-height: 210px;
  }
  .detail-backdrop { background: rgba(0,0,0,.32); backdrop-filter: blur(1px); }
}
@keyframes vetSheetIn {
  from { opacity: 0; transform: translateY(18px); }
  to { opacity: 1; transform: translateY(0); }
}
@media (max-width: 520px) {
  .summary-grid { grid-template-columns: 1fr; }
  .vet-table { min-width: 720px; }
  .vet-col-rank { width: 32px; }
  .vet-col-market { width: 124px; }
  .vet-col-price { width: 88px; }
  .vet-col-curve { width: 96px; }
  .vet-col-momentum { width: 130px; }
  .vet-col-valki { width: 150px; }
  .vet-col-updated { width: 100px; }
  .vet-table th, .vet-table td { padding-left: 8px; padding-right: 8px; }
  .rank { width: 34px; }
  .market-cell { min-width: 126px; }
  .market-name { max-width: 76px; }
  .spark { width: 90px; }
  .detail-metrics, .detail-grid { grid-template-columns: 1fr; }
}
