/* ============================================================
   EvvyTools — Trackers Shared Stylesheet
   Loaded on every /trackers/[slug]/ page via tracker-shell-top.
   Class prefix: .ett- (EvvyTools Tracker)

   Each tracker page can override accent colors by setting
   --ett-accent / --ett-accent-soft inline. Default falls back
   to the page's --cluster-dark.
   ============================================================ */

:root {
  --ett-accent:      var(--cluster-dark, #1D3354);
  --ett-accent-soft: color-mix(in srgb, var(--ett-accent) 18%, transparent);
  --ett-up:          #B12A38;
  --ett-up-soft:     rgba(177, 42, 56, 0.10);
  --ett-down:        #2A6A47;
  --ett-down-soft:   rgba(42, 106, 71, 0.12);
  /* Lightning-bolt blue from the EvvyTools logo — accent on dark navy heros */
  --ett-bolt:        #4FC3F7;
  --ett-bolt-soft:   rgba(79, 195, 247, 0.18);
  --ett-bolt-mid:    #29B6F6;
}
[data-bs-theme="dark"] {
  --ett-up:          #fca5a5;
  --ett-up-soft:     rgba(252, 165, 165, 0.16);
  --ett-down:        #86efac;
  --ett-down-soft:   rgba(134, 239, 172, 0.16);
}

/* ============================================================
   KEYFRAMES
   ============================================================ */
@keyframes ettTickerScroll { 0% { transform: translateX(0); } 100% { transform: translateX(-50%); } }
@keyframes ettHeroOrbPulse { 0% { opacity: 0.55; } 100% { opacity: 1; } }
@keyframes ettSweepShine   { 0% { transform: translateX(-120%) skewX(-14deg); } 100% { transform: translateX(220%) skewX(-14deg); } }
@keyframes ettFlickerLow   { 0%, 100% { opacity: 0.7; } 50% { opacity: 1; } }
@keyframes ettLivePulse {
  0%   { box-shadow: 0 0 0 0   rgba(94, 206, 124, 0.55); }
  70%  { box-shadow: 0 0 0 9px rgba(94, 206, 124, 0); }
  100% { box-shadow: 0 0 0 0   rgba(94, 206, 124, 0); }
}

/* ============================================================
   PAGE LAYOUT CONSTRAINTS
   (Mirrors evvy-tools.css so tracker pages share the same
   1200px container as tool pages without needing that file.)
   ============================================================ */
.evvy-tool-layout {
  display: block;
  max-width: 1200px;
  margin: 0 auto;
  padding: 1.5rem 1rem 0;
}
.evvy-tool-main {
  min-width: 0;
  max-width: 100%;
  padding-bottom: 5rem;
}
.evvy-page-container {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 1rem;
}
.evvy-breadcrumb {
  padding: 0;
  font-size: 0.8125rem;
}
.evvy-breadcrumb a {
  color: var(--evvy-text-secondary);
  text-decoration: none;
}
.evvy-breadcrumb a:hover {
  color: var(--ett-accent);
  text-decoration: underline;
}
.evvy-breadcrumb .separator {
  margin: 0 0.375rem;
  color: var(--evvy-text-secondary);
}
.evvy-breadcrumb .current {
  color: var(--evvy-text-primary);
  font-weight: 500;
}
@media (max-width: 767.98px) {
  .evvy-tool-main { padding-bottom: 3.5rem; }
}

/* ============================================================
   LIVE TICKER (top — atmospheric scrolling rate strip)
   ============================================================ */
.ett-ticker {
  background: linear-gradient(90deg, #0a0f1c 0%, #0e1730 50%, #0a0f1c 100%);
  color: #e6edf5;
  overflow: hidden;
  position: relative;
  border-bottom: 1px solid rgba(70, 130, 180, 0.25);
  box-shadow: 0 2px 14px rgba(0, 0, 0, 0.25);
}
.ett-ticker::before {
  content: ''; position: absolute; inset: 0;
  background: linear-gradient(90deg, #0a0f1c 0%, transparent 6%, transparent 94%, #0a0f1c 100%);
  pointer-events: none; z-index: 2;
}
.ett-ticker-track {
  display: inline-flex; align-items: center; gap: 2.2rem;
  padding: 0.65rem 2rem; white-space: nowrap;
  animation: ettTickerScroll 65s linear infinite;
  will-change: transform;
  font-family: var(--evvy-font-mono);
  font-size: 0.82rem;
}
.ett-ticker:hover .ett-ticker-track { animation-play-state: paused; }
.ett-ticker-item {
  display: inline-flex; align-items: center; gap: 0.45rem;
  text-decoration: none; color: inherit;
}
.ett-ticker-item:hover { color: #fff; }
.ett-ticker-item > i { color: rgba(176, 196, 222, 0.75); }
.ett-ticker-label { color: rgba(230, 237, 245, 0.75); letter-spacing: 0.04em; }
.ett-ticker-price { color: #fff; font-weight: 700; font-variant-numeric: tabular-nums; }
.ett-ticker-chg {
  display: inline-flex; align-items: center; gap: 0.15rem;
  font-weight: 600; padding: 0.1rem 0.42rem;
  border-radius: 50rem; font-size: 0.74rem;
  font-variant-numeric: tabular-nums;
}
.ett-up   { color: #fca5a5; }
.ett-down { color: #86efac; }
.ett-flat { color: #94a3b8; }
.ett-ticker-chg.ett-up   { background: rgba(248, 113, 113, 0.14); }
.ett-ticker-chg.ett-down { background: rgba(74, 222, 128, 0.16); }
.ett-ticker-chg.ett-flat { background: rgba(148, 163, 184, 0.12); }
@media (max-width: 600px) {
  .ett-ticker-track { gap: 1.4rem; padding: 0.55rem 1rem; font-size: 0.76rem; }
}

/* ============================================================
   BREADCRUMB STRIP (between ticker and hero)
   ============================================================ */
.ett-crumb-strip {
  background: var(--bs-body-bg);
  border-bottom: 1px solid var(--evvy-border-color);
  padding: 0.65rem 0;
}
.ett-crumb-strip .evvy-breadcrumb { padding: 0; font-size: 0.82rem; }

/* ============================================================
   HERO — big rate display
   ============================================================ */
.ett-hero {
  position: relative; overflow: hidden;
  border-radius: 18px;
  margin: 1.75rem 0 2rem;
  background: linear-gradient(160deg, #0a1529 0%, #0d1e3f 50%, var(--ett-accent, #1d3354) 100%);
  color: #fff;
  box-shadow: 0 14px 44px rgba(0, 12, 40, 0.32);
}
.ett-hero-bg {
  position: absolute; inset: 0;
  background:
    radial-gradient(ellipse 70% 60% at 82% 30%, rgba(79, 195, 247, 0.22) 0%, transparent 60%),
    radial-gradient(ellipse 45% 50% at 12% 90%, rgba(255, 132, 0, 0.12) 0%, transparent 60%),
    url("data:image/svg+xml,%3Csvg width='24' height='24' viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Ccircle cx='1' cy='1' r='1' fill='rgba(176,196,222,0.07)'/%3E%3C/svg%3E");
  animation: ettHeroOrbPulse 6s ease-in-out infinite alternate;
  pointer-events: none;
}
.ett-hero-inner {
  position: relative; z-index: 1;
  display: grid; grid-template-columns: 1.1fr 1fr;
  gap: 2rem; padding: 2.4rem 2.2rem; align-items: center;
}
@media (max-width: 880px) {
  .ett-hero-inner { grid-template-columns: 1fr; padding: 1.85rem 1.4rem; gap: 1.75rem; }
}

/* Eyebrow row */
.ett-eyebrow-row {
  display: flex; flex-direction: column; gap: 0.45rem;
  margin-bottom: 1rem;
}
.ett-eyebrow {
  display: inline-flex; align-items: center; gap: 0.5rem;
  font-family: var(--evvy-font-mono);
  font-size: 0.72rem; letter-spacing: 0.16em; text-transform: uppercase;
  color: rgba(176, 196, 222, 0.72);
}
.ett-eyebrow.ett-light-sub { color: rgba(176, 196, 222, 0.72); }
.ett-live-dot {
  display: inline-block; width: 8px; height: 8px;
  border-radius: 50%; background: #5ECE7C;
  animation: ettLivePulse 2.2s cubic-bezier(.4,0,.2,1) infinite;
}
.ett-hero-title {
  font-family: var(--evvy-font-display);
  font-size: clamp(1.4rem, 2.5vw, 2rem); font-weight: 700;
  line-height: 1.1; letter-spacing: -0.01em; color: #fff; margin: 0;
}

/* Big number with gradient text */
.ett-price-display {
  display: flex; align-items: flex-start; gap: 0.15rem;
  font-family: var(--evvy-font-display); font-weight: 700;
  color: #fff; line-height: 1;
  margin: 0.4rem 0 0.9rem;
}
.ett-price-prefix {
  font-size: clamp(2rem, 4vw, 3rem);
  color: rgba(176, 196, 222, 0.85);
  margin-top: 0.55rem;
  font-weight: 600;
}
.ett-price-number {
  font-size: clamp(4rem, 10vw, 7.5rem);
  letter-spacing: -0.025em;
  font-variant-numeric: tabular-nums;
  background: linear-gradient(180deg, #ffffff 0%, #b0c4de 100%);
  -webkit-background-clip: text; background-clip: text;
  -webkit-text-fill-color: transparent;
}
.ett-price-number.ett-price-number-sm {
  font-size: clamp(3rem, 7vw, 5.5rem);
}
.ett-price-unit {
  font-size: clamp(2rem, 4vw, 3rem);
  font-weight: 600;
  color: rgba(176, 196, 222, 0.85);
  margin-top: 0.55rem;
}

/* Change pill */
.ett-hero-change {
  display: inline-flex; align-items: center; gap: 0.4rem;
  font-size: 1.02rem; font-weight: 600;
  padding: 0.45rem 0.9rem; border-radius: 50rem;
  margin-bottom: 1rem;
  background: rgba(255, 255, 255, 0.06);
  color: rgba(255, 255, 255, 0.95);
  font-variant-numeric: tabular-nums;
}
.ett-hero-change.ett-up   { background: rgba(248, 113, 113, 0.14); color: #fca5a5; }
.ett-hero-change.ett-down { background: rgba(74, 222, 128, 0.16);  color: #86efac; }
.ett-hero-change.ett-flat { background: rgba(148, 163, 184, 0.14); color: #cbd5e1; }
.ett-hero-change i { font-size: 1.2rem; }
.ett-hero-change-label {
  opacity: 0.7; font-size: 0.85rem; font-weight: 400; margin-left: 0.25rem;
}

/* Meta line */
.ett-hero-meta {
  display: flex; flex-wrap: wrap; gap: 1.25rem;
  color: rgba(176, 196, 222, 0.7); font-size: 0.82rem;
}
.ett-hero-meta i { margin-right: 0.3rem; opacity: 0.75; }
.ett-hero-meta a { color: rgba(176, 196, 222, 0.85); text-decoration: underline; text-decoration-thickness: 1px; }
.ett-hero-meta a:hover { color: #fff; }

/* Right column */
.ett-hero-right {
  display: flex; flex-direction: column; gap: 1.1rem;
}
.ett-sparkline-wrap {
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 12px;
  padding: 0.85rem 1rem;
  position: relative; overflow: hidden;
}
.ett-sparkline-wrap::after {
  content: ''; position: absolute; top: 0; left: 0; bottom: 0;
  width: 80px;
  background: linear-gradient(90deg, rgba(255,255,255,0.12), transparent);
  animation: ettSweepShine 6s ease-in-out infinite;
  pointer-events: none;
}
.ett-sparkline-label {
  display: flex; align-items: center; justify-content: space-between; gap: 0.5rem;
  margin-bottom: 0.6rem;
  font-family: var(--evvy-font-mono);
  font-size: 0.7rem; letter-spacing: 0.1em; text-transform: uppercase;
  color: rgba(176, 196, 222, 0.65);
}
.ett-sparkline-range {
  padding: 0.2rem 0.6rem;
  background: rgba(255, 255, 255, 0.06);
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: 50rem;
  color: rgba(255, 255, 255, 0.9);
  font-weight: 600; letter-spacing: 0.04em;
}
.ett-sparkline-canvas-box {
  position: relative; height: 130px; width: 100%;
}
.ett-sparkline-canvas-box > canvas {
  position: absolute !important; inset: 0;
  width: 100% !important; height: 100% !important;
  display: block;
}

/* Hero context strip */
.ett-hero-context {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 0.5rem;
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 12px;
  padding: 0.95rem;
}
.ett-hero-context-item {
  display: flex; flex-direction: column; gap: 0.25rem;
  padding: 0.25rem 0.55rem;
  border-right: 1px solid rgba(255, 255, 255, 0.06);
}
.ett-hero-context-item:last-child { border-right: 0; }
.ett-hero-context-label {
  font-family: var(--evvy-font-mono);
  font-size: 0.65rem; text-transform: uppercase; letter-spacing: 0.1em;
  color: rgba(176, 196, 222, 0.6);
}
.ett-hero-context-value {
  font-family: var(--evvy-font-display); font-weight: 700;
  color: #fff; font-size: 1.1rem; font-variant-numeric: tabular-nums;
}
.ett-hero-context-value.ett-up   { color: #fca5a5; }
.ett-hero-context-value.ett-down { color: #86efac; }

/* Floating action chip cluster */
.ett-hero-actions {
  position: absolute;
  top: 1rem; right: 1rem;
  display: flex; gap: 0.4rem; z-index: 3; flex-wrap: wrap;
}
.ett-action-btn {
  display: inline-flex; align-items: center; gap: 0.35rem;
  padding: 0.4rem 0.75rem;
  background: rgba(255, 255, 255, 0.08);
  border: 1px solid rgba(255, 255, 255, 0.15);
  color: rgba(255, 255, 255, 0.85);
  font-size: 0.78rem; font-weight: 600;
  border-radius: 50rem; cursor: pointer;
  transition: all 0.2s ease;
  font-family: var(--evvy-font-ui);
}
.ett-action-btn:hover {
  background: rgba(255, 255, 255, 0.14); color: #fff;
  border-color: rgba(255, 255, 255, 0.35);
}
.ett-action-btn i { font-size: 0.85rem; }
@media (max-width: 600px) {
  .ett-hero-actions { position: static; margin-top: 1rem; width: 100%; }
}

/* ============================================================
   EDITORIAL pull-quote
   ============================================================ */
.ett-pullquote {
  position: relative;
  margin: 2.25rem 0 1.5rem;
  padding: 1.25rem 1.5rem 1.25rem 4rem;
  background: var(--cluster-surface, #EEF3F8);
  border-radius: 14px;
  border-left: 4px solid var(--ett-accent);
}
.ett-pullquote-mark {
  position: absolute; top: 1rem; left: 1rem;
  width: 36px; height: 36px;
  display: flex; align-items: center; justify-content: center;
  border-radius: 50%; background: var(--ett-accent);
  color: #fff; font-size: 1.4rem;
}
.ett-pullquote p {
  margin: 0;
  font-family: var(--evvy-font-display);
  font-size: 1.1rem; line-height: 1.55;
  color: var(--evvy-text-primary);
  font-weight: 500; letter-spacing: -0.005em;
}
.ett-pullquote strong { color: var(--ett-accent); font-weight: 700; }
[data-bs-theme="dark"] .ett-pullquote-mark { color: #1a1a2e; }
@media (max-width: 575.98px) {
  .ett-pullquote { padding: 1rem 1.25rem; }
  .ett-pullquote-mark { position: relative; top: 0; left: 0; margin-bottom: 0.7rem; }
}

/* ============================================================
   SECTIONS — generic + dark variant
   ============================================================ */
.ett-section { margin: 2.5rem 0; padding: 0; }
.ett-section-dark {
  background: linear-gradient(160deg, #0a1529 0%, var(--ett-accent, #1d3354) 100%);
  color: #fff; border-radius: 18px;
  padding: 2.2rem 1.75rem 2.5rem;
  position: relative; overflow: hidden;
}
.ett-section-dark::before {
  content: ''; position: absolute; inset: 0;
  background-image: url("data:image/svg+xml,%3Csvg width='24' height='24' viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Ccircle cx='1' cy='1' r='1' fill='rgba(176,196,222,0.06)'/%3E%3C/svg%3E");
  pointer-events: none;
}
.ett-section-head {
  display: flex; align-items: flex-end; justify-content: space-between;
  flex-wrap: wrap; gap: 1rem;
  margin-bottom: 1.25rem;
  position: relative; z-index: 1;
}
.ett-section-title {
  font-family: var(--evvy-font-display);
  font-size: 1.6rem; font-weight: 700;
  margin: 0 0 0.2rem; line-height: 1.2;
  letter-spacing: -0.01em;
  color: var(--evvy-text-heading);
}
.ett-section-title.ett-light { color: #fff; }
.ett-section-sub {
  color: var(--evvy-text-secondary);
  margin: 0; font-size: 0.95rem;
}
.ett-section-sub.ett-light-sub { color: rgba(176, 196, 222, 0.72); }

/* Range pills */
.ett-range-pills {
  display: inline-flex;
  background: var(--evvy-gray-50);
  padding: 0.22rem; border-radius: 50rem;
  border: 1px solid var(--evvy-border-color);
}
.ett-range-pill {
  background: transparent; border: 0;
  padding: 0.32rem 0.95rem;
  font-family: var(--evvy-font-mono);
  font-size: 0.78rem; font-weight: 700;
  color: var(--evvy-text-secondary);
  border-radius: 50rem; cursor: pointer;
  transition: all 0.2s ease;
  letter-spacing: 0.04em;
}
.ett-range-pill:hover { color: var(--evvy-navy); }
.ett-range-pill-active {
  background: var(--ett-accent);
  color: #fff;
  box-shadow: 0 2px 6px color-mix(in srgb, var(--ett-accent) 30%, transparent);
}
[data-bs-theme="dark"] .ett-range-pill-active { color: #1a1a2e; }
.ett-section-dark .ett-range-pills {
  background: rgba(255, 255, 255, 0.06);
  border-color: rgba(255, 255, 255, 0.1);
}
.ett-section-dark .ett-range-pill { color: rgba(255, 255, 255, 0.7); }
.ett-section-dark .ett-range-pill:hover { color: #fff; }
.ett-section-dark .ett-range-pill-active { background: rgba(255, 255, 255, 0.95); color: var(--evvy-navy); }

/* Chart wrappers */
.ett-chart-wrap {
  position: relative;
  background: #fff;
  border: 1px solid var(--evvy-border-color);
  border-radius: 14px;
  padding: 1.25rem 1rem 1rem;
  height: 380px;
}
[data-bs-theme="dark"] .ett-chart-wrap {
  background: #021123;
  border-color: rgba(255, 255, 255, 0.1);
}
.ett-chart-wrap-dark {
  background: rgba(255, 255, 255, 0.04);
  border-color: rgba(255, 255, 255, 0.08);
  height: 400px;
}
.ett-chart-wrap canvas { width: 100% !important; height: 100% !important; }
.ett-chart-footnote {
  margin: 0.7rem 0 0;
  font-size: 0.78rem;
  color: var(--evvy-text-secondary);
  font-style: italic;
}
.ett-chart-footnote a {
  color: var(--ett-accent);
  text-decoration: underline; text-decoration-thickness: 1px;
}

/* Long view summary pills */
.ett-longview-pills {
  display: flex; flex-wrap: wrap; gap: 0.5rem;
  margin-top: 1rem;
  position: relative; z-index: 1;
}
.ett-longview-pill {
  display: inline-flex; align-items: center;
  padding: 0.4rem 0.85rem; border-radius: 50rem;
  background: rgba(255, 255, 255, 0.06);
  border: 1px solid rgba(255, 255, 255, 0.1);
  color: rgba(255, 255, 255, 0.85);
  font-size: 0.82rem;
  font-variant-numeric: tabular-nums;
}
.ett-longview-pill strong {
  color: #fff; margin-right: 0.4rem;
  font-weight: 700; letter-spacing: 0.03em;
  text-transform: uppercase; font-size: 0.7rem;
}
.ett-longview-pill-up   { border-color: rgba(248, 113, 113, 0.4); }
.ett-longview-pill-up   strong { color: #fca5a5; }
.ett-longview-pill-down { border-color: rgba(74, 222, 128, 0.4); }
.ett-longview-pill-down strong { color: #86efac; }

/* ============================================================
   CONTEXT GRID — comparison stat cards
   ============================================================ */
.ett-context-grid {
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 1rem;
}
@media (max-width: 991.98px) { .ett-context-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 575.98px) { .ett-context-grid { grid-template-columns: 1fr; } }

.ett-context-card {
  position: relative;
  padding: 1.4rem 1.3rem;
  background: #fff;
  border: 1px solid var(--evvy-border-color);
  border-radius: 14px;
  box-shadow: var(--evvy-shadow-sm);
  transition: transform 0.25s cubic-bezier(.4,0,.2,1),
              box-shadow 0.25s cubic-bezier(.4,0,.2,1),
              border-color 0.25s;
  overflow: hidden;
}
.ett-context-card::before {
  content: ''; position: absolute; top: 0; left: 0; right: 0;
  height: 3px; background: var(--ett-accent);
  transform: scaleX(0); transform-origin: left;
  transition: transform 0.35s cubic-bezier(.4,0,.2,1);
}
.ett-context-card:hover {
  transform: translateY(-3px);
  box-shadow: var(--evvy-shadow-md);
  border-color: color-mix(in srgb, var(--ett-accent) 35%, var(--evvy-border-color));
}
.ett-context-card:hover::before { transform: scaleX(1); }
[data-bs-theme="dark"] .ett-context-card {
  background: var(--evvy-gray-100);
  border-color: var(--evvy-border-color);
}
.ett-context-up::before    { background: var(--ett-up); }
.ett-context-down::before  { background: var(--ett-down); }
.ett-context-today::before { background: linear-gradient(90deg, #fca5a5, #86efac); }

.ett-context-label {
  font-family: var(--evvy-font-mono);
  font-size: 0.68rem; text-transform: uppercase; letter-spacing: 0.1em;
  color: var(--evvy-text-secondary);
  margin-bottom: 0.45rem; font-weight: 700;
}
.ett-context-value {
  font-family: var(--evvy-font-display);
  font-size: 2.1rem; font-weight: 700; line-height: 1;
  color: var(--evvy-text-heading);
  font-variant-numeric: tabular-nums;
  letter-spacing: -0.015em;
}
.ett-context-up   .ett-context-value { color: var(--ett-up); }
.ett-context-down .ett-context-value { color: var(--ett-down); }
.ett-context-sub {
  margin-top: 0.6rem;
  font-size: 0.85rem; line-height: 1.5;
  color: var(--evvy-text-secondary);
}

/* ============================================================
   GENERIC CALC WRAPPER (optional, per-tracker)
   ============================================================ */
.ett-calc-wrap {
  background: #fff;
  border: 1px solid var(--evvy-border-color);
  border-radius: 14px; padding: 1.75rem;
}
[data-bs-theme="dark"] .ett-calc-wrap { background: var(--evvy-gray-100); }
.ett-calc-inputs {
  display: grid; grid-template-columns: repeat(4, 1fr);
  gap: 1rem; margin-bottom: 1.5rem;
}
@media (max-width: 880px) { .ett-calc-inputs { grid-template-columns: 1fr 1fr; } }
@media (max-width: 480px) { .ett-calc-inputs { grid-template-columns: 1fr; } }

.ett-input-group { display: flex; flex-direction: column; gap: 0.4rem; }
.ett-input-group label {
  font-family: var(--evvy-font-mono);
  font-size: 0.7rem; text-transform: uppercase; letter-spacing: 0.1em;
  color: var(--evvy-text-secondary); font-weight: 700;
}
.ett-input-group input {
  padding: 0.7rem 0.9rem;
  border: 1.5px solid var(--evvy-border-color);
  border-radius: 10px;
  font-size: 1.05rem; font-weight: 600;
  font-variant-numeric: tabular-nums;
  background: var(--bs-body-bg);
  color: var(--evvy-text-primary);
  transition: border-color 0.2s ease, box-shadow 0.2s ease;
}
.ett-input-group input:focus {
  outline: none;
  border-color: var(--ett-accent);
  box-shadow: 0 0 0 3px var(--ett-accent-soft);
}
.ett-input-static {
  display: flex; align-items: center; gap: 0.5rem;
  padding: 0.7rem 0.9rem;
  background: var(--evvy-gray-50);
  border-radius: 10px;
  font-size: 1.05rem; font-weight: 700;
  color: var(--ett-accent);
  font-variant-numeric: tabular-nums;
  border: 1.5px solid transparent;
}
.ett-input-static-tag {
  font-family: var(--evvy-font-mono);
  font-size: 0.62rem; font-weight: 700;
  letter-spacing: 0.12em; text-transform: uppercase;
  padding: 0.1rem 0.45rem;
  background: var(--ett-accent); color: #fff; border-radius: 4px;
}
.ett-calc-results {
  display: grid; grid-template-columns: 1.4fr 1fr 1fr 1fr;
  gap: 0.75rem; margin-bottom: 1rem;
}
@media (max-width: 880px) { .ett-calc-results { grid-template-columns: 1fr 1fr; } }
@media (max-width: 480px) { .ett-calc-results { grid-template-columns: 1fr; } }
.ett-calc-stat {
  background: var(--evvy-gray-50);
  border-radius: 12px; padding: 1rem 1.1rem;
  border: 1px solid var(--evvy-border-color);
}
.ett-calc-stat-hero {
  background: linear-gradient(135deg, var(--ett-accent) 0%, color-mix(in srgb, var(--ett-accent) 70%, #4682B4) 100%);
  border-color: var(--ett-accent);
}
.ett-calc-stat-hero .ett-calc-stat-label,
.ett-calc-stat-hero .ett-calc-stat-sub { color: rgba(255, 255, 255, 0.78); }
.ett-calc-stat-hero .ett-calc-stat-value { color: #fff; font-size: 2rem; }
.ett-calc-stat-label {
  font-family: var(--evvy-font-mono);
  font-size: 0.7rem; text-transform: uppercase; letter-spacing: 0.1em;
  color: var(--evvy-text-secondary);
  margin-bottom: 0.4rem; font-weight: 700;
}
.ett-calc-stat-value {
  font-family: var(--evvy-font-display);
  font-size: 1.55rem; font-weight: 700;
  color: var(--evvy-text-primary);
  font-variant-numeric: tabular-nums;
  line-height: 1.1; letter-spacing: -0.01em;
}
.ett-calc-stat-sub {
  font-size: 0.72rem; color: var(--evvy-text-secondary); margin-top: 0.3rem;
}
.ett-calc-share { display: flex; justify-content: flex-end; padding-top: 0.6rem; }
.ett-share-btn {
  display: inline-flex; align-items: center; gap: 0.5rem;
  padding: 0.65rem 1.4rem;
  background: var(--ett-accent); color: #fff;
  border: 0; border-radius: 50rem;
  font-weight: 600; font-size: 0.92rem;
  cursor: pointer; text-decoration: none;
  transition: transform 0.2s ease, box-shadow 0.2s ease;
  box-shadow: 0 4px 14px color-mix(in srgb, var(--ett-accent) 35%, transparent);
}
.ett-share-btn:hover {
  transform: translateY(-1px); color: #fff; text-decoration: none;
  box-shadow: 0 6px 20px color-mix(in srgb, var(--ett-accent) 45%, transparent);
}

/* ============================================================
   CTA CARDS (dark band) — "Use this rate"
   ============================================================ */
.ett-cta-grid {
  display: grid; grid-template-columns: repeat(3, 1fr);
  gap: 1.1rem;
  position: relative; z-index: 1;
}
@media (max-width: 880px) { .ett-cta-grid { grid-template-columns: 1fr; } }

.ett-cta-card {
  position: relative; display: flex; flex-direction: column;
  padding: 1.6rem 1.5rem 1.4rem;
  background: rgba(255, 255, 255, 0.05);
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: 14px;
  text-decoration: none; color: #fff;
  transition: transform 0.3s cubic-bezier(.4,0,.2,1),
              background 0.3s, border-color 0.3s;
  overflow: hidden; backdrop-filter: blur(4px);
}
.ett-cta-card::before {
  content: ''; position: absolute; inset: 0;
  background: linear-gradient(135deg, rgba(79, 195, 247, 0.22), transparent 65%);
  opacity: 0; transition: opacity 0.3s;
}
.ett-cta-card:hover {
  transform: translateY(-4px);
  background: rgba(255, 255, 255, 0.09);
  border-color: rgba(79, 195, 247, 0.60);
  color: #fff; text-decoration: none;
}
.ett-cta-card:hover::before { opacity: 1; }

.ett-cta-icon {
  position: relative;
  width: 44px; height: 44px;
  display: inline-flex; align-items: center; justify-content: center;
  border-radius: 11px;
  background: rgba(79, 195, 247, 0.18);
  color: var(--ett-bolt);
  font-size: 1.35rem;
  margin-bottom: 1rem;
}
.ett-cta-card h3 {
  position: relative;
  font-family: var(--evvy-font-display);
  font-size: 1.25rem; color: #fff;
  margin: 0 0 0.5rem;
}
.ett-cta-card p {
  position: relative;
  color: rgba(255, 255, 255, 0.72);
  font-size: 0.9rem; line-height: 1.55;
  margin: 0; flex: 1;
}
.ett-cta-arrow {
  position: relative;
  display: inline-flex; align-items: center; gap: 0.3rem;
  margin-top: 1.1rem;
  font-family: var(--evvy-font-mono);
  font-size: 0.74rem; font-weight: 700;
  letter-spacing: 0.1em; text-transform: uppercase;
  color: var(--ett-bolt);
}
.ett-cta-arrow i {
  font-size: 1.05rem;
  transition: transform 0.25s cubic-bezier(.4,0,.2,1);
}
.ett-cta-card:hover .ett-cta-arrow i { transform: translateX(4px); }

/* ============================================================
   RELATED TRACKERS
   ============================================================ */
.ett-related-grid {
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 0.9rem;
}
@media (max-width: 991.98px) { .ett-related-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 480px)    { .ett-related-grid { grid-template-columns: 1fr; } }
.ett-rel-card {
  display: block;
  padding: 1.1rem 1.1rem 0.9rem;
  background: #fff;
  border: 1px solid var(--evvy-border-color);
  border-radius: 14px;
  text-decoration: none; color: var(--evvy-text-primary);
  transition: transform 0.25s cubic-bezier(.4,0,.2,1),
              border-color 0.25s, box-shadow 0.25s;
}
[data-bs-theme="dark"] .ett-rel-card { background: var(--evvy-gray-100); }
.ett-rel-card:hover {
  transform: translateY(-3px);
  border-color: color-mix(in srgb, var(--ett-accent) 45%, var(--evvy-border-color));
  box-shadow: var(--evvy-shadow-md);
  text-decoration: none; color: var(--evvy-text-primary);
}
.ett-rel-source {
  font-family: var(--evvy-font-mono);
  font-size: 0.62rem; font-weight: 700;
  letter-spacing: 0.1em; text-transform: uppercase;
  color: var(--evvy-text-secondary);
  margin-bottom: 0.35rem;
}
.ett-rel-name {
  font-family: var(--evvy-font-display);
  font-weight: 700; font-size: 1.05rem; line-height: 1.2;
  margin-bottom: 0.6rem;
  color: var(--evvy-text-heading);
}
.ett-rel-row {
  display: flex; align-items: baseline; justify-content: space-between;
  gap: 0.5rem; margin-bottom: 0.5rem;
}
.ett-rel-val {
  font-family: var(--evvy-font-display);
  font-weight: 700; font-size: 1.7rem; line-height: 1;
  color: var(--ett-accent);
  font-variant-numeric: tabular-nums;
  letter-spacing: -0.015em;
}
.ett-rel-val span {
  font-size: 0.9rem;
  color: var(--evvy-text-secondary);
  font-weight: 600; margin-left: 0.1rem;
}
.ett-rel-delta {
  display: inline-flex; align-items: center; gap: 0.18rem;
  font-family: var(--evvy-font-mono);
  font-size: 0.74rem; font-weight: 700;
  padding: 0.18rem 0.55rem; border-radius: 50rem;
  font-variant-numeric: tabular-nums;
}
.ett-rel-delta.ett-up   { background: var(--ett-up-soft); color: var(--ett-up); }
.ett-rel-delta.ett-down { background: var(--ett-down-soft); color: var(--ett-down); }
.ett-rel-spark { position: relative; height: 32px; margin-top: 0.2rem; }
.ett-rel-spark canvas { width: 100% !important; height: 32px !important; }

/* ============================================================
   CARD EMBED / OUTLINE BUTTONS
   ============================================================ */
.ett-card-embed-btn {
  display: inline-flex; align-items: center; gap: 0.35rem;
  padding: 0.4rem 0.85rem;
  background: var(--evvy-gray-50);
  border: 1px solid var(--evvy-border-color);
  color: var(--evvy-text-secondary);
  font-size: 0.78rem; font-weight: 600;
  border-radius: 50rem; cursor: pointer;
  text-decoration: none;
  transition: all 0.2s ease;
}
.ett-card-embed-btn:hover {
  background: #fff; color: var(--ett-accent);
  border-color: var(--ett-accent);
  text-decoration: none;
}
.ett-section-dark .ett-card-embed-btn {
  background: rgba(255, 255, 255, 0.08);
  border-color: rgba(255, 255, 255, 0.15);
  color: rgba(255, 255, 255, 0.85);
}
.ett-section-dark .ett-card-embed-btn:hover {
  background: rgba(255, 255, 255, 0.14); color: #fff;
  border-color: rgba(79, 195, 247, 0.6);
}

/* ============================================================
   DATA LIST PROMO
   ============================================================ */
.ett-datalist-promo {
  display: flex; align-items: center; gap: 1.25rem;
  margin: 2.5rem 0;
  padding: 1.25rem 1.5rem;
  border-radius: 14px;
  background: linear-gradient(135deg, var(--evvy-gray-50) 0%, var(--evvy-gray-100) 100%);
  border: 1px solid var(--evvy-border-color);
  position: relative; overflow: hidden;
}
.ett-datalist-promo::before {
  content: ''; position: absolute; top: 0; bottom: 0; left: 0; width: 4px;
  background: linear-gradient(180deg, var(--ett-accent) 0%, var(--evvy-accent) 100%);
}
.ett-dlp-icon {
  flex-shrink: 0;
  width: 54px; height: 54px;
  border-radius: 12px;
  background: linear-gradient(135deg, var(--ett-accent) 0%, var(--evvy-accent) 100%);
  color: #fff;
  display: flex; align-items: center; justify-content: center;
  font-size: 1.4rem;
  box-shadow: 0 4px 14px rgba(0, 32, 64, 0.25);
}
.ett-dlp-body { flex: 1; min-width: 0; }
.ett-dlp-eyebrow {
  font-family: var(--evvy-font-mono);
  font-size: 0.68rem; letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--ett-accent); font-weight: 700;
  margin-bottom: 0.2rem;
}
.ett-dlp-title {
  font-family: var(--evvy-font-display);
  font-weight: 700; font-size: 1.15rem;
  color: var(--evvy-text-heading);
  margin-bottom: 0.2rem;
}
.ett-dlp-sub {
  color: var(--evvy-text-secondary);
  font-size: 0.9rem; margin: 0; line-height: 1.5;
}
.ett-dlp-cta {
  flex-shrink: 0;
  display: inline-flex; align-items: center; gap: 0.4rem;
  padding: 0.6rem 1.25rem;
  background: var(--evvy-navy);
  color: #fff !important;
  font-weight: 600; font-size: 0.9rem;
  border-radius: 50rem;
  text-decoration: none !important;
  transition: transform 0.2s ease, box-shadow 0.2s ease;
}
.ett-dlp-cta:hover {
  transform: translateY(-1px);
  box-shadow: 0 4px 14px rgba(0, 32, 64, 0.3);
}
@media (max-width: 640px) {
  .ett-datalist-promo { flex-direction: column; align-items: flex-start; }
  .ett-dlp-cta { width: 100%; justify-content: center; }
}

/* ============================================================
   EDITORIAL BLOCK (the long-form SEO body copy)
   ============================================================ */
.ett-editorial {
  margin: 2rem 0;
  padding: 1.5rem;
  background: var(--bs-body-bg);
  border: 1px solid var(--evvy-border-color);
  border-radius: 14px;
}
.ett-editorial h2,
.ett-editorial h3 {
  font-family: var(--evvy-font-display);
  color: var(--evvy-text-heading);
  margin-top: 1.5rem;
  margin-bottom: 0.6rem;
}
.ett-editorial h2 { font-size: 1.4rem; }
.ett-editorial h2:first-child { margin-top: 0; }
.ett-editorial h3 { font-size: 1.15rem; }
.ett-editorial p {
  color: var(--evvy-text-primary);
  font-size: 0.97rem;
  line-height: 1.65;
  margin: 0 0 0.85rem;
}
.ett-editorial strong { color: var(--ett-accent); font-weight: 700; }
.ett-editorial ul, .ett-editorial ol {
  padding-left: 1.4rem; margin: 0 0 1rem;
  color: var(--evvy-text-primary);
  line-height: 1.65;
}
.ett-editorial li { margin: 0.3rem 0; }
.ett-editorial .ett-ed-meta {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
  gap: 0.55rem 1.4rem;
  padding-top: 1rem;
  margin-top: 1.25rem;
  border-top: 1px dashed color-mix(in srgb, var(--ett-accent) 35%, transparent);
  font-size: 0.82rem;
}
.ett-editorial .ett-ed-meta > div {
  display: flex; flex-direction: column;
}
.ett-editorial .ett-ed-meta span {
  font-family: var(--evvy-font-mono);
  font-size: 0.62rem; letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--evvy-text-secondary);
  opacity: 0.75; margin-bottom: 0.15rem;
}

/* ============================================================
   FAQ
   ============================================================ */
.ett-faq { max-width: 920px; }
.ett-faq .accordion-item {
  background: var(--bs-body-bg);
  border: 1px solid var(--evvy-border-color);
  border-radius: 12px !important;
  margin-bottom: 0.6rem;
  overflow: hidden;
}
.ett-faq .accordion-button {
  background: var(--bs-body-bg);
  color: var(--evvy-text-heading);
  font-family: var(--evvy-font-display);
  font-weight: 700; font-size: 1.05rem;
  padding: 1rem 1.25rem;
  box-shadow: none;
  border-radius: 12px !important;
}
.ett-faq .accordion-button:not(.collapsed) {
  background: color-mix(in srgb, var(--ett-accent) 6%, var(--bs-body-bg));
  color: var(--ett-accent);
}
.ett-faq .accordion-button:focus {
  box-shadow: 0 0 0 3px var(--ett-accent-soft);
}
.ett-faq .accordion-body {
  color: var(--evvy-text-primary);
  line-height: 1.65;
  padding: 0 1.25rem 1.25rem;
}

/* ============================================================
   METHODOLOGY
   ============================================================ */
.ett-meth {
  margin: 2.5rem 0 4.5rem;
  padding-top: 2rem;
  border-top: 1px solid var(--evvy-border-color);
}
.ett-meth-grid {
  display: grid; grid-template-columns: 1fr 1fr 1fr;
  gap: 2.25rem; margin-top: 1rem;
}
@media (max-width: 767.98px) {
  .ett-meth-grid { grid-template-columns: 1fr; gap: 1.5rem; }
}
.ett-meth h4 {
  display: flex; align-items: center; gap: 0.5rem;
  font-family: var(--evvy-font-mono);
  font-size: 0.74rem; font-weight: 700;
  letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--evvy-text-secondary);
  padding-bottom: 0.6rem; margin-bottom: 0.85rem;
  border-bottom: 1px solid var(--evvy-border-color);
}
.ett-meth h4 i { color: var(--ett-accent); font-size: 1rem; }
.ett-meth p {
  font-size: 0.92rem; line-height: 1.65;
  color: var(--evvy-text-primary); margin: 0;
}
.ett-meth a {
  color: var(--ett-accent); font-weight: 600;
  text-decoration: underline; text-decoration-thickness: 1px;
  text-underline-offset: 2px;
}

/* ============================================================
   /trackers/ INDEX PAGE — card extensions
   The cards reuse .et-tool-card-shared / .et-tcs-* from evvy-layout.css
   (same as /tools/ and /lists/). Here we just add the tracker-specific
   bits: a small "LIVE" chip and the value + delta footer styling.
   ============================================================ */
.tracker-card-wrap .et-tcs-header {
  align-items: center;
  gap: 0.5rem;
}
.tracker-card-wrap .et-tcs-cluster {
  flex: 1;
  min-width: 0;
}
.et-tcs-live {
  display: inline-flex;
  align-items: center;
  gap: 0.25rem;
  font-family: var(--evvy-font-mono);
  font-size: 0.58rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: #2A6A47;
  padding: 0.15rem 0.45rem;
  border-radius: 50rem;
  background: rgba(42, 106, 71, 0.10);
}
[data-bs-theme="dark"] .et-tcs-live { color: #86efac; background: rgba(134, 239, 172, 0.16); }
.et-tcs-live-dot {
  width: 6px; height: 6px;
  border-radius: 50%;
  background: #5ECE7C;
  animation: ettLivePulse 2.2s cubic-bezier(.4,0,.2,1) infinite;
}

/* Footer: value + delta on the left, arrow on the right */
.tracker-card-wrap .et-tcs-footer {
  align-items: center;
}
.tracker-card-wrap .et-tcs-meta {
  display: inline-flex;
  align-items: baseline;
  gap: 0.6rem;
}
.et-tcs-value {
  font-family: var(--evvy-font-display);
  font-size: 1.25rem;
  font-weight: 700;
  color: var(--evvy-text-heading);
  font-variant-numeric: tabular-nums;
  letter-spacing: -0.01em;
  line-height: 1;
}
.et-tcs-delta {
  display: inline-flex;
  align-items: center;
  gap: 0.2rem;
  font-family: var(--evvy-font-mono);
  font-size: 0.72rem;
  font-weight: 700;
  padding: 0.18rem 0.5rem;
  border-radius: 50rem;
  font-variant-numeric: tabular-nums;
}
.et-tcs-delta i { font-size: 0.7rem; }
.et-tcs-delta-up   { background: rgba(177, 42, 56, 0.10); color: #B12A38; }
.et-tcs-delta-down { background: rgba(42, 106, 71, 0.12); color: #2A6A47; }
.et-tcs-delta-flat { background: rgba(148, 163, 184, 0.12); color: #6B7589; }
[data-bs-theme="dark"] .et-tcs-delta-up   { background: rgba(252, 165, 165, 0.16); color: #fca5a5; }
[data-bs-theme="dark"] .et-tcs-delta-down { background: rgba(134, 239, 172, 0.16); color: #86efac; }

/* ============================================================
   REDUCED MOTION
   ============================================================ */
@media (prefers-reduced-motion: reduce) {
  .ett-hero-bg, .ett-sparkline-wrap::after,
  .ett-live-dot, .ett-ticker-track,
  .ett-idx-card-pulse .ett-idx-pulse-dot { animation: none; }
}
