:root{
  --bg:#ffffff;
  --bg-2:#f8fafc;
  --panel:#ffffff;
  --text:#0f172a;
  --muted:#64748b;
  --muted-2:#94a3b8;
  --border:#e5e7eb;
  --border-strong:#d1d5db;
  --up:#16a34a;
  --down:#dc2626;
  --accent:#16a34a;
  --accent-2:#0ea5e9;
  --chip-bg:#f1f5f9;
  --chip-active-bg:#dcfce7;
  --chip-active-fg:#166534;
  --shadow-sm: 0 1px 2px rgba(15,23,42,.05);
  --shadow-md: 0 4px 14px rgba(15,23,42,.06);
  --radius:12px;
  --fng-extreme-fear:#b91c1c;--fng-fear:#ea580c;
  --fng-neutral:#a3a3a3;--fng-greed:#16a34a;--fng-extreme-greed:#15803d;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font:15px/1.55 system-ui,-apple-system,Segoe UI,Roboto,Inter,Arial,sans-serif;
  background:var(--bg);color:var(--text);
}
a{color:var(--accent);text-decoration:none}
a:hover{text-decoration:underline}
.skip{position:absolute;left:-9999px;top:0}
.skip:focus{left:8px;top:8px;background:#000;color:#fff;padding:8px 12px;border-radius:6px;z-index:9}

.container{max-width:1320px;margin:0 auto;padding:0 20px}

/* ---- stats bar (topo) ---- */
.stats-bar{
  display:flex;flex-wrap:wrap;gap:18px;
  font-size:.83rem;color:var(--muted);
  padding:10px 14px;margin:14px 0 0;border:1px solid var(--border);border-radius:10px;
  background:var(--bg-2);
}
.stats-bar strong{color:var(--text);font-weight:600}
.stats-bar .is-up{color:var(--up)} .stats-bar .is-down{color:var(--down)}

/* ---- header ---- */
.site-header{
  background:#fff;border-bottom:1px solid var(--border);
  position:sticky;top:0;z-index:5;
}
.header-inner{display:flex;align-items:center;justify-content:space-between;height:64px;padding:0 20px;max-width:1320px;margin:0 auto}
.brand{font-weight:800;font-size:1.2rem;color:var(--text);display:flex;align-items:center;gap:6px}
.brand-mark{color:var(--accent);font-size:1.4rem}
.nav a{margin-left:22px;color:var(--text);font-weight:500;font-size:.95rem}
.nav a:hover{color:var(--accent);text-decoration:none}

/* ---- hero ---- */
.hero{padding:28px 0 6px}
.hero h1{font-size:clamp(1.45rem,2.2vw,1.95rem);margin:0 0 .35rem;line-height:1.25;letter-spacing:-.01em}
.lead{color:var(--muted);font-size:1rem;max-width:780px;margin:0}

/* ---- summary cards ---- */
.summary-cards{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));
  gap:14px;margin:18px 0 22px;
}
.summary-card{
  background:#fff;border:1px solid var(--border);border-radius:var(--radius);
  padding:14px 16px;box-shadow:var(--shadow-sm);
}
.summary-card header{
  font-size:.82rem;color:var(--muted);text-transform:uppercase;
  letter-spacing:.06em;font-weight:600;
  display:flex;justify-content:space-between;align-items:center;
}
.summary-card .sym{color:var(--muted-2);font-size:.75rem;font-weight:500}
.summary-card .value{font-size:1.45rem;font-weight:700;margin:8px 0 2px;letter-spacing:-.01em}
.summary-card .delta{margin:0;font-weight:600;font-size:.95rem}
.summary-card .delta small{color:var(--muted);font-weight:500;margin-left:2px}
.trend-card .trend-list{list-style:none;margin:8px 0 0;padding:0;display:flex;flex-direction:column;gap:6px}
.trend-card .trend-list li{display:flex;align-items:center;gap:8px;font-size:.92rem}
.trend-card .trend-list img{border-radius:50%}
.trend-card .t-name{flex:1;color:var(--text);font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.trend-card .t-pct{font-weight:600;font-variant-numeric:tabular-nums}

.is-up{color:var(--up)} .is-down{color:var(--down)}

/* ---- filters ---- */
.filters{
  display:flex;flex-wrap:wrap;gap:12px;justify-content:space-between;
  align-items:center;margin:18px 0 12px;
}
.chips{display:flex;flex-wrap:wrap;gap:8px}
.chip{
  background:var(--chip-bg);color:var(--text);
  padding:8px 14px;border-radius:999px;font-size:.88rem;font-weight:600;
  border:1px solid transparent;transition:background .15s;
}
.chip:hover{background:#e2e8f0;text-decoration:none}
.chip.active{background:var(--chip-active-bg);color:var(--chip-active-fg);border-color:#bbf7d0}

.search{display:flex;align-items:center;gap:6px}
.search input[type="search"]{
  border:1px solid var(--border-strong);border-radius:8px;
  padding:8px 12px;font-size:.92rem;width:240px;background:#fff;color:var(--text);
}
.search input[type="search"]:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(22,163,74,.12)}
.search button{
  background:var(--accent);color:#fff;border:0;border-radius:8px;
  padding:8px 14px;font-weight:600;cursor:pointer;font-size:.92rem;
}
.search button:hover{background:#15803d}

/* ---- coins table ---- */
.table-wrap{overflow-x:auto;border:1px solid var(--border);border-radius:var(--radius);background:#fff;box-shadow:var(--shadow-sm)}
.coins-table{width:100%;border-collapse:collapse;font-size:.92rem;min-width:980px}
.coins-table th,.coins-table td{
  padding:11px 12px;border-bottom:1px solid var(--border);
  text-align:left;vertical-align:middle;white-space:nowrap;
}
.coins-table tbody tr:hover{background:#fafbfc}
.coins-table tbody tr:last-child td{border-bottom:0}
.coins-table th{
  color:var(--muted);font-weight:600;font-size:.78rem;
  text-transform:uppercase;letter-spacing:.05em;
  background:#fafbfc;
}
.coins-table .num{text-align:right;font-variant-numeric:tabular-nums}
.coins-table .rank{color:var(--muted);font-weight:600;width:40px}
.coins-table .coin-cell{min-width:200px}
.coins-table .coin-link{display:flex;align-items:center;gap:8px;color:var(--text)}
.coins-table .coin-link:hover{color:var(--accent);text-decoration:none}
.coins-table .coin-link img{border-radius:50%}
.coins-table .c-name{font-weight:600}
.coins-table .c-sym{color:var(--muted);font-size:.78rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase}
.trend-card .trend-list a{display:flex;align-items:center;gap:8px;color:var(--text);flex:1;min-width:0}
.trend-card .trend-list a:hover{color:var(--accent);text-decoration:none}
.coins-table .spark-col{width:140px}
.coins-table .empty{text-align:center;color:var(--muted);padding:32px}
.spark{display:block;margin-left:auto}

/* ---- pagination ---- */
.pagination{
  display:flex;flex-wrap:wrap;gap:6px;justify-content:center;
  margin:24px 0 8px;
}
.pagination .page{
  min-width:38px;text-align:center;padding:8px 12px;
  border:1px solid var(--border);border-radius:8px;
  background:#fff;color:var(--text);font-weight:500;font-size:.92rem;
}
.pagination .page:hover{border-color:var(--accent);color:var(--accent);text-decoration:none}
.pagination .current{background:var(--accent);color:#fff;border-color:var(--accent);font-weight:700}
.pagination .gap{border:0;cursor:default;color:var(--muted)}
.pagination-meta{text-align:center;color:var(--muted);font-size:.85rem;margin:0 0 28px}

/* ---- breadcrumbs ---- */
.breadcrumbs{font-size:.88rem;color:var(--muted);padding-top:18px}
.breadcrumbs a{color:var(--accent)}

/* ---- prose ---- */
.prose{max-width:820px;margin:30px 0;color:var(--text)}
.prose h2{margin:1.5rem 0 .35rem;font-size:1.15rem;font-weight:700}
.prose p{color:#334155;margin:.35rem 0 .95rem;font-size:.97rem}

/* ---- fear & greed gauge ---- */
.gauge-card{
  margin:24px auto;max-width:420px;text-align:center;
  background:#fff;border:1px solid var(--border);border-radius:var(--radius);
  padding:30px 20px;box-shadow:var(--shadow-md);
}
.gauge-card[data-tone="extreme-fear"]   { box-shadow:0 0 0 3px var(--fng-extreme-fear)  inset, var(--shadow-md); }
.gauge-card[data-tone="fear"]           { box-shadow:0 0 0 3px var(--fng-fear)          inset, var(--shadow-md); }
.gauge-card[data-tone="neutral"]        { box-shadow:0 0 0 3px var(--fng-neutral)       inset, var(--shadow-md); }
.gauge-card[data-tone="greed"]          { box-shadow:0 0 0 3px var(--fng-greed)         inset, var(--shadow-md); }
.gauge-card[data-tone="extreme-greed"]  { box-shadow:0 0 0 3px var(--fng-extreme-greed) inset, var(--shadow-md); }
.gauge-value{font-size:4rem;font-weight:800;line-height:1;color:var(--text)}
.gauge-value .of{font-size:1rem;color:var(--muted);font-weight:500;margin-left:6px}
.gauge-label{font-size:1.3rem;margin:.4rem 0 0;font-weight:600}
.gauge-meta{color:var(--muted);margin:.6rem 0 0;font-size:.9rem}

/* tabela do fear&greed reaproveita estilo de coins-table */
.rank-table{width:100%;border-collapse:collapse;font-size:.94rem;background:#fff;border:1px solid var(--border);border-radius:var(--radius)}
.rank-table th,.rank-table td{padding:10px 12px;border-bottom:1px solid var(--border);text-align:left}
.rank-table tbody tr:last-child td{border-bottom:0}
.rank-table th{color:var(--muted);font-weight:600;font-size:.78rem;text-transform:uppercase;letter-spacing:.05em;background:#fafbfc}
.rank-table .num{text-align:right;font-variant-numeric:tabular-nums}

.empty{color:var(--muted)}

/* ---- adsense slot ---- */
.ad-slot{margin:24px 0;min-height:90px}

/* ---- footer ---- */
.site-footer{margin-top:40px;padding:24px 0 32px;border-top:1px solid var(--border);color:var(--muted);font-size:.88rem;background:var(--bg-2)}
.site-footer .disclaimer{margin-top:6px;font-size:.82rem;line-height:1.55}

/* ---- responsive ---- */
@media (max-width:760px){
  .stats-bar{font-size:.78rem;gap:12px}
  .summary-cards{grid-template-columns:1fr 1fr}
  .filters{flex-direction:column;align-items:stretch}
  .search input[type="search"]{width:100%}
}

/* ============= COIN DETAIL PAGE ============= */
.coin-hero{display:flex;flex-wrap:wrap;align-items:center;gap:16px;margin:18px 0 6px}
.coin-hero .coin-icon{width:48px;height:48px;border-radius:50%}
.coin-hero h1{font-size:clamp(1.4rem,2.2vw,1.9rem);margin:0;font-weight:800;letter-spacing:-.01em}
.coin-hero h1 .sym{color:var(--muted);font-weight:600;font-size:.72em;margin-left:6px;text-transform:uppercase}
.coin-hero .rank-badge{background:var(--chip-bg);color:var(--text);padding:4px 10px;border-radius:6px;font-size:.78rem;font-weight:700}

.coin-price-row{display:flex;flex-wrap:wrap;align-items:baseline;gap:14px;margin:12px 0 18px}
.coin-price-row .price{font-size:2.4rem;font-weight:800;line-height:1;letter-spacing:-.02em}
.coin-price-row .delta{font-size:1.05rem;font-weight:700;padding:3px 10px;border-radius:6px}
.coin-price-row .delta.is-up{background:#dcfce7;color:#166534}
.coin-price-row .delta.is-down{background:#fee2e2;color:#991b1b}

.coin-grid{display:grid;grid-template-columns:1fr;gap:18px;margin:8px 0 28px}
@media (min-width:900px){.coin-grid{grid-template-columns:2fr 1fr}}

.chart-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:16px;box-shadow:var(--shadow-sm)}
.chart-card header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}
.chart-card h2{margin:0;font-size:1rem;font-weight:700}
.chart-card .range-info{color:var(--muted);font-size:.85rem}

.big-chart{display:block;width:100%;height:auto}
.big-chart .gridline{stroke:#eef0f3;stroke-width:1;stroke-dasharray:3,3}
.big-chart .gridtext{fill:var(--muted-2);font-size:11px;font-family:inherit}
.big-chart .area{fill-opacity:.12}
.big-chart .line{fill:none;stroke-width:2;stroke-linejoin:round;stroke-linecap:round}

.metrics-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:6px 0;box-shadow:var(--shadow-sm)}
.metrics-card h2{padding:14px 16px 6px;margin:0;font-size:1rem;font-weight:700}
.metrics-card dl{margin:0;display:grid;grid-template-columns:1fr auto;column-gap:12px}
.metrics-card dt,.metrics-card dd{margin:0;padding:10px 16px;font-size:.92rem;border-top:1px solid var(--border)}
.metrics-card dt{color:var(--muted);font-weight:500}
.metrics-card dd{font-weight:600;text-align:right;font-variant-numeric:tabular-nums}

.coin-about{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:20px;box-shadow:var(--shadow-sm);margin:20px 0}
.coin-about h2{margin:0 0 .6rem;font-size:1.1rem;font-weight:700}
.coin-about .desc{color:#334155;font-size:.97rem;line-height:1.65;max-height:18em;overflow:hidden;position:relative}
.coin-about .desc.expanded{max-height:none}
.coin-about .desc::after{content:"";position:absolute;left:0;right:0;bottom:0;height:48px;background:linear-gradient(transparent,#fff)}
.coin-about .desc.expanded::after{display:none}
.coin-about .desc a{color:var(--accent-2)}
.coin-about .expand{background:none;border:0;color:var(--accent);font-weight:600;cursor:pointer;padding:8px 0 0;font-size:.92rem}

.coin-links{display:flex;flex-wrap:wrap;gap:8px;margin-top:14px}
.coin-links a{
  background:var(--chip-bg);color:var(--text);
  padding:6px 12px;border-radius:6px;font-size:.85rem;font-weight:500;
}
.coin-links a:hover{background:#e2e8f0;text-decoration:none;color:var(--accent)}

/* ============= NEWS PAGE ============= */
.news-grid{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:18px;margin:18px 0 28px;
}
.news-card{
  display:flex;flex-direction:column;background:#fff;border:1px solid var(--border);
  border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);
  transition:transform .15s, box-shadow .15s;
}
.news-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}
.news-card--featured{grid-column:span 2}
@media (max-width:760px){.news-card--featured{grid-column:auto}}
.news-thumb{display:block;aspect-ratio:16/9;background:var(--bg-2);overflow:hidden}
.news-thumb img{width:100%;height:100%;object-fit:cover;display:block}
.news-body{padding:14px 16px 16px;display:flex;flex-direction:column;gap:8px;flex:1}
.news-meta{display:flex;flex-wrap:wrap;gap:8px;align-items:center;font-size:.78rem;color:var(--muted)}
.news-source{background:var(--chip-bg);color:var(--text);font-weight:600;padding:2px 8px;border-radius:4px;font-size:.74rem;text-transform:uppercase;letter-spacing:.04em}
.news-lang{background:#eff6ff;color:#1e40af;font-weight:600;padding:2px 6px;border-radius:4px;font-size:.7rem}
.news-title{margin:0;font-size:1.02rem;line-height:1.35;font-weight:700}
.news-title a{color:var(--text)}
.news-title a:hover{color:var(--accent);text-decoration:none}
.news-card--featured .news-title{font-size:1.25rem}
.news-desc{margin:0;color:#475569;font-size:.9rem;line-height:1.55}

/* ============= CURRENCY SWITCHER ============= */
.ccy-switcher{position:relative}
.ccy-dropdown{position:relative}
.ccy-dropdown summary{
  list-style:none;cursor:pointer;
  display:inline-flex;align-items:center;gap:6px;
  background:var(--chip-bg);border:1px solid var(--border);
  padding:6px 12px;border-radius:8px;font-size:.88rem;font-weight:600;color:var(--text);
}
.ccy-dropdown summary::-webkit-details-marker{display:none}
.ccy-dropdown summary:hover{border-color:var(--accent)}
.ccy-caret{font-size:.7rem;color:var(--muted)}
.ccy-menu{
  position:absolute;right:0;top:calc(100% + 6px);
  background:#fff;border:1px solid var(--border);border-radius:10px;
  box-shadow:var(--shadow-md);
  list-style:none;margin:0;padding:6px;min-width:200px;z-index:20;
}
.ccy-menu li{margin:0}
.ccy-menu a{
  display:flex;flex-direction:column;gap:2px;
  padding:8px 12px;border-radius:6px;color:var(--text);
}
.ccy-menu a:hover{background:var(--chip-bg);text-decoration:none}
.ccy-menu a.active{background:var(--chip-active-bg);color:var(--chip-active-fg)}
.ccy-menu small{color:var(--muted);font-size:.78rem;font-weight:400}

/* ============= COIN PAGE EXTRAS ============= */
.coin-cats{display:flex;flex-wrap:wrap;gap:6px;margin-left:auto}
.cat-chip{
  background:var(--chip-bg);color:var(--text);
  font-size:.74rem;font-weight:600;padding:3px 9px;border-radius:6px;
}

.chart-range{padding:12px 4px 0;margin-top:6px;border-top:1px solid var(--border)}
.range-bar{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.range-label{font-size:.82rem;color:var(--muted);font-weight:600;text-transform:uppercase;letter-spacing:.05em}
.range-low,.range-high{font-size:.85rem;color:var(--muted);font-variant-numeric:tabular-nums}
.range-track{
  position:relative;flex:1;height:6px;min-width:120px;
  background:linear-gradient(90deg,#fee2e2,#dcfce7);
  border-radius:999px;overflow:visible;
}
.range-fill{display:none}
.range-marker{
  position:absolute;top:50%;width:12px;height:12px;
  background:#fff;border:3px solid var(--accent);border-radius:50%;
  transform:translate(-50%, -50%);box-shadow:0 0 0 2px rgba(22,163,74,.15);
}

.tech-grid{display:grid;grid-template-columns:1fr;gap:18px;margin:18px 0}
@media (min-width:900px){.tech-grid{grid-template-columns:1fr 1fr}}
.tech-card{
  background:#fff;border:1px solid var(--border);border-radius:var(--radius);
  padding:18px 18px 16px;box-shadow:var(--shadow-sm);
}
.tech-card h2{margin:0 0 10px;font-size:1.05rem;font-weight:700}
.tech-card h3{font-size:.95rem;font-weight:700;margin:0 0 8px}
.tech-card dl{margin:0;display:grid;grid-template-columns:1fr auto;column-gap:12px;row-gap:0}
.tech-card dt,.tech-card dd{margin:0;padding:9px 0;font-size:.92rem;border-top:1px solid var(--border)}
.tech-card dt:first-of-type,.tech-card dd:first-of-type{border-top:0}
.tech-card dt{color:var(--muted);font-weight:500}
.tech-card dd{font-weight:600;text-align:right;font-variant-numeric:tabular-nums}
.tech-cats{margin-top:14px;padding-top:12px;border-top:1px solid var(--border);font-size:.88rem;color:var(--muted)}
.tech-cats strong{color:var(--text);margin-right:6px}
.tech-cats .cat-chip{margin:3px 4px 0 0;display:inline-block}

.sentiment-bar{display:flex;border-radius:8px;overflow:hidden;height:32px;font-size:.78rem;font-weight:600;color:#fff}
.sent-up{background:#16a34a;display:flex;align-items:center;justify-content:flex-start;padding-left:10px;white-space:nowrap}
.sent-down{background:#dc2626;display:flex;align-items:center;justify-content:flex-end;padding-right:10px;white-space:nowrap}
.sent-note{margin:8px 0 0;font-size:.8rem;color:var(--muted)}

.conv-table{width:100%;border-collapse:collapse;font-size:.92rem;margin-top:6px}
.conv-table td{padding:7px 0;border-top:1px solid var(--border);font-variant-numeric:tabular-nums}
.conv-table tr:first-child td{border-top:0}
.conv-table .num{text-align:right;font-weight:600}

.date-meta{display:block;color:var(--muted);font-size:.78rem;font-weight:400;margin-top:1px}

.metrics-card dd small{display:inline-block;margin-left:4px;font-size:.8rem}

/* aumentar colunas da tabela pra acomodar spark maior */
.coins-table .spark-col{width:170px}

/* prose h3 para FAQ */
.prose h3{margin:1.3rem 0 .3rem;font-size:1.02rem;font-weight:700;color:var(--text)}

/* ============= TABELA COMPACTA + COLUNAS ORDENAVEIS ============= */
.coins-table{min-width:1100px}
.coins-table th,.coins-table td{padding:10px 10px}
.coins-table .rank-col{width:50px}
.coins-table .coin-th{width:auto}
.coins-table .coin-cell{min-width:180px;width:1%;white-space:nowrap}
.coins-table .num{width:1%;white-space:nowrap}
.coins-table .spark-col{width:240px}
.coins-table .empty{width:auto}

/* cabecalho ordenavel */
.th-sort a{
  display:inline-flex;align-items:center;gap:4px;
  color:var(--muted);font-weight:600;font-size:.78rem;
  text-transform:uppercase;letter-spacing:.05em;
  white-space:nowrap;
}
.th-sort a:hover{color:var(--accent);text-decoration:none}
.th-sort--active a{color:var(--text)}
.sort-arrow{font-size:.72rem;line-height:1}
.sort-arrow.muted{color:var(--muted-2);opacity:.55}
.th-sort.num a{justify-content:flex-end;width:100%}

/* ============= AUTOCOMPLETE ============= */
.search-wrap{position:relative}
.search-results{
  position:absolute;top:calc(100% + 6px);left:0;right:0;
  min-width:340px;max-width:480px;max-height:420px;overflow-y:auto;
  background:#fff;border:1px solid var(--border);border-radius:10px;
  box-shadow:var(--shadow-md);z-index:30;padding:4px;
}
.search-result{
  display:grid;grid-template-columns:24px 1fr auto auto auto auto;
  align-items:center;gap:10px;
  padding:8px 10px;border-radius:6px;color:var(--text);
  font-size:.9rem;text-decoration:none;
}
.search-result:hover,
.search-result.active{background:var(--chip-bg);text-decoration:none}
.search-result img{border-radius:50%}
.search-result .sr-name{font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.search-result .sr-sym{color:var(--muted);font-size:.78rem;font-weight:600;text-transform:uppercase}
.search-result .sr-rank{color:var(--muted);font-size:.78rem;font-weight:500}
.search-result .sr-price{font-variant-numeric:tabular-nums;font-weight:600;color:var(--text)}
.search-result .sr-chg{font-variant-numeric:tabular-nums;font-weight:600;font-size:.85rem}
.search-empty{padding:14px;color:var(--muted);text-align:center;font-size:.9rem}

@media (max-width:760px){
  .search-results{position:fixed;left:8px;right:8px;top:auto;min-width:0;max-width:none}
  .search-result{grid-template-columns:24px 1fr auto auto}
  .search-result .sr-rank,.search-result .sr-chg{display:none}
}

/* ============= HERO ROW + MINI FNG ============= */
.hero-row{
  display:grid;grid-template-columns:1fr;gap:18px;
  align-items:start;padding-top:18px;
}
@media (min-width:900px){
  .hero-row{grid-template-columns:1fr 320px}
}
.hero-row .hero{padding:0}

.fng-mini{
  display:flex;flex-direction:column;gap:8px;
  background:#fff;border:1px solid var(--border);border-radius:var(--radius);
  padding:14px 16px;text-decoration:none;color:var(--text);
  box-shadow:var(--shadow-sm);transition:transform .15s, box-shadow .15s;
  border-top:4px solid var(--fng-neutral);
}
.fng-mini:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);text-decoration:none}
.fng-mini[data-tone="extreme-fear"]  { border-top-color:var(--fng-extreme-fear) }
.fng-mini[data-tone="fear"]          { border-top-color:var(--fng-fear) }
.fng-mini[data-tone="neutral"]       { border-top-color:var(--fng-neutral) }
.fng-mini[data-tone="greed"]         { border-top-color:var(--fng-greed) }
.fng-mini[data-tone="extreme-greed"] { border-top-color:var(--fng-extreme-greed) }
.fng-mini header{
  display:flex;justify-content:space-between;align-items:baseline;
  font-size:.78rem;color:var(--muted);font-weight:600;
  text-transform:uppercase;letter-spacing:.05em;
}
.fng-mini-title{color:var(--text)}
.fng-mini-date{color:var(--muted-2);font-size:.75rem}
.fng-mini-body{display:flex;align-items:center;gap:12px}
.fng-mini-gauge{flex:0 0 auto;width:140px;height:auto}
.fng-mini-meta{display:flex;flex-direction:column;gap:2px;line-height:1.1}
.fng-mini-value{font-size:2.2rem;font-weight:800;letter-spacing:-.02em;color:var(--text)}
.fng-mini-label{font-size:.95rem;font-weight:600;color:var(--text)}
.fng-mini-trend{display:flex;align-items:center;gap:10px;padding-top:6px;border-top:1px solid var(--border)}
.fng-mini-trend .spark{flex:1;height:30px}
.fng-mini-trend small{color:var(--muted);font-size:.72rem;text-transform:uppercase;letter-spacing:.05em;font-weight:600}

/* ============= FEAR & GREED PAGE ============= */
.fng-hero{
  display:grid;grid-template-columns:1fr;gap:18px;margin:18px 0 6px;
}
@media (min-width:900px){
  .fng-hero{grid-template-columns:380px 1fr}
}
.gauge-card{margin:0;max-width:none;text-align:center}
.gauge-zones{
  display:flex;justify-content:space-between;gap:4px;
  margin-top:18px;padding-top:14px;border-top:1px solid var(--border);
  font-size:.7rem;color:var(--muted);font-weight:600;
}
.gauge-zones .z{padding:3px 6px;border-radius:4px}
.gauge-zones .z-ef{background:#fee2e2;color:#991b1b}
.gauge-zones .z-f {background:#fed7aa;color:#9a3412}
.gauge-zones .z-n {background:#e5e7eb;color:#374151}
.gauge-zones .z-g {background:#bbf7d0;color:#166534}
.gauge-zones .z-eg{background:#86efac;color:#14532d}

.fng-summary{
  background:#fff;border:1px solid var(--border);border-radius:var(--radius);
  padding:18px 20px;box-shadow:var(--shadow-sm);
}
.fng-summary h2{margin:0 0 12px;font-size:1.05rem;font-weight:700}
.summary-stats{
  margin:0;display:grid;grid-template-columns:repeat(3,1fr);gap:12px;
}
.summary-stats > div{
  background:var(--bg-2);border-radius:8px;padding:10px 12px;
  display:flex;flex-direction:column;gap:2px;
}
.summary-stats dt{font-size:.78rem;color:var(--muted);font-weight:600;text-transform:uppercase;letter-spacing:.04em;margin:0}
.summary-stats dd{margin:0;font-size:1.4rem;font-weight:800;color:var(--text);font-variant-numeric:tabular-nums}

.fng-chart-card{
  background:#fff;border:1px solid var(--border);border-radius:var(--radius);
  padding:16px 18px 14px;box-shadow:var(--shadow-sm);margin:14px 0 18px;
}
.fng-chart-card > header{
  display:flex;justify-content:space-between;align-items:center;
  flex-wrap:wrap;gap:10px;margin-bottom:10px;
}
.fng-chart-card h2{margin:0;font-size:1.05rem;font-weight:700}
.fng-range{display:flex;gap:6px;background:var(--chip-bg);border-radius:8px;padding:3px}
.range-chip{
  padding:6px 14px;border-radius:6px;font-size:.84rem;font-weight:600;
  color:var(--muted);background:transparent;
}
.range-chip:hover{color:var(--text);text-decoration:none;background:rgba(255,255,255,.6)}
.range-chip.active{background:#fff;color:var(--accent);box-shadow:var(--shadow-sm)}

.fng-chart{display:block;width:100%;height:auto}
.fng-chart .gridline{stroke:rgba(15,23,42,.08);stroke-width:1;stroke-dasharray:3,3}
.fng-chart .gridtext{fill:var(--muted-2);font-size:11px;font-family:inherit}
.fng-chart .fng-line{filter:drop-shadow(0 1px 1px rgba(15,23,42,.15))}

.fng-chart-legend{
  display:flex;flex-wrap:wrap;gap:14px;margin:10px 0 0;
  font-size:.78rem;color:var(--muted);font-weight:500;
}
.fng-chart-legend .leg{display:inline-block;width:14px;height:10px;border-radius:3px;margin-right:5px;vertical-align:-1px}
.leg-ef{background:#fee2e2}
.leg-f {background:#fed7aa}
.leg-n {background:#e5e7eb}
.leg-g {background:#bbf7d0}
.leg-eg{background:#86efac}

.zone-pill{
  display:inline-block;padding:3px 10px;border-radius:999px;
  font-size:.78rem;font-weight:600;
}
.zone-pill.zone-extreme-fear  {background:#fee2e2;color:#991b1b}
.zone-pill.zone-fear          {background:#fed7aa;color:#9a3412}
.zone-pill.zone-neutral       {background:#e5e7eb;color:#374151}
.zone-pill.zone-greed         {background:#bbf7d0;color:#166534}
.zone-pill.zone-extreme-greed {background:#86efac;color:#14532d}

.fng-history{margin:18px 0 6px}
.fng-history h2{font-size:1.05rem;font-weight:700;margin:0 0 10px}

/* ============= FNG AJAX LOADING ============= */
.fng-chart-loading{
  display:flex;align-items:center;justify-content:center;gap:8px;
  padding:8px;color:var(--muted);font-size:.9rem;
}
.fng-chart-loading .spinner{
  display:inline-block;width:14px;height:14px;
  border:2px solid var(--chip-bg);border-top-color:var(--accent);
  border-radius:50%;animation:spin .8s linear infinite;
}
@keyframes spin { to { transform: rotate(360deg) } }

/* range com 6 chips precisa de wrap em mobile */
.fng-range{flex-wrap:wrap}
@media (max-width:600px){
  .fng-range{width:100%}
  .range-chip{flex:1;text-align:center;padding:6px 8px;font-size:.8rem}
}

/* Suaviza a troca do SVG sem flicker */
#fng-chart-wrap{transition:opacity .15s}
#fng-chart-wrap.is-loading{opacity:.5}

/* fix: [hidden] precisa ganhar do display:flex */
.fng-chart-loading[hidden]{display:none !important}

/* fade smooth durante troca de range */
#fng-chart-wrap{transition:opacity .2s ease}
#fng-chart-wrap.is-swapping{opacity:.25}

/* animacao de "desenhar" a linha quando entra novo grafico */
.fng-chart .fng-line.is-drawing{
  stroke-dasharray:6000;
  stroke-dashoffset:6000;
  animation:fng-draw 1.1s cubic-bezier(.4,.0,.2,1) forwards;
}
@keyframes fng-draw {
  to { stroke-dashoffset: 0 }
}

/* ============= LAYOUT FINAL DA TABELA ============= */
/* Trick: todas as colunas com width:1% encolhem ao conteudo + padding,
   e a coluna do sparkline com width:auto absorve TODO o leftover.
   Resultado: nome da moeda colado, numeros enxutos, grafico bem grande. */
.coins-table{table-layout:auto;min-width:1000px}
.coins-table th,
.coins-table td{width:1%;padding:10px 12px}
.coins-table .coin-cell,
.coins-table .coin-th{padding-right:18px}
.coins-table .spark-col{
  width:auto !important;          /* engole o espaco que sobrar */
  min-width:300px;
  padding-right:16px;
}
.coins-table .spark{
  width:100%;
  height:64px;
  max-width:none;
  display:block;
}

/* ============= FIX FINAL TABELA - LARGURAS EXPLICITAS ============= */
/* Estrategia: cada coluna numerica tem largura fixa, a do grafico cresce. */
.coins-table .rank-col,
.coins-table .rank{width:42px !important}
.coins-table .coin-cell,
.coins-table .coin-th{width:200px !important;padding-right:18px}
.coins-table .th-sort,
.coins-table td.num{width:92px !important;padding:10px 8px !important}
.coins-table .spark-col{
  width:auto !important;
  min-width:380px;
  padding:10px 16px 10px 12px !important;
}
.coins-table .spark{
  width:100% !important;
  height:72px !important;
  max-width:none !important;
  display:block;
  margin:0 !important;
}

/* ============= GRAFICO MAIOR AINDA - APERTA NUMERICAS ============= */
.coins-table{font-size:.88rem !important;min-width:1100px !important}
.coins-table .rank-col,
.coins-table .rank{width:36px !important;padding-left:10px !important;padding-right:6px !important}
.coins-table .coin-cell,
.coins-table .coin-th{width:180px !important;padding-right:14px !important}
.coins-table .th-sort,
.coins-table td.num{width:76px !important;padding:9px 6px !important;font-size:.86rem}
.coins-table .th-sort a{font-size:.72rem !important;gap:2px}
.coins-table .spark-col{
  width:auto !important;
  min-width:520px !important;
  padding:9px 14px 9px 10px !important;
}
.coins-table .spark{
  width:100% !important;
  height:84px !important;
  max-width:none !important;
  display:block;
  margin:0 !important;
}

/* ============= ESPACAMENTO ENTRE LINHAS DA TABELA ============= */
.coins-table th,
.coins-table .th-sort,
.coins-table td,
.coins-table td.num{padding-top:14px !important;padding-bottom:14px !important}
.coins-table .spark-col{padding-top:10px !important;padding-bottom:10px !important}

/* Traçado do sparkline mais fino tambem via CSS (caso a inline width nao seja respeitada) */
.spark polyline{stroke-width:1.3 !important}

/* Mais ar entre secoes (resumos, filtros, tabela) */
.summary-cards{margin-bottom:28px !important}
.filters{margin:22px 0 16px !important}
.table-wrap{margin-bottom:8px}

/* ============= GRAFICO MENOR + CHIPS COMO BOTOES ============= */
.coins-table .spark-col{
  min-width:380px !important;
  padding-top:8px !important;
  padding-bottom:8px !important;
}
.coins-table .spark{
  height:56px !important;
}

/* Chips e cabecalhos sortaveis viram botoes (sem aspecto de link) */
.chip{cursor:pointer}
.chip.is-sorting{transition:transform .1s;transform:scale(.97)}
.th-sort a{cursor:pointer}
.coins-table tr.is-moving{transition:background .25s;background:rgba(22,163,74,.04)}

/* ============= LAYOUT ESTILO COINGECKO ============= */
/* Mais ar entre colunas, setas so nas ativas */
.coins-table th,
.coins-table .th-sort,
.coins-table td,
.coins-table td.num{padding-left:16px !important;padding-right:16px !important}
.coins-table .rank-col,
.coins-table .rank{padding-left:14px !important;padding-right:8px !important}
.coins-table .coin-cell,
.coins-table .coin-th{padding-right:20px !important}

/* esconder a setinha quando inativa */
.th-sort .sort-arrow.muted{display:none}
.th-sort--active .sort-arrow{margin-left:4px;font-size:.75rem}

/* coluna do grafico: titulo limpo, sem padding excessivo */
.coins-table .spark-col{padding-left:14px !important;padding-right:14px !important}

/* ============= HEADER COM 2 SWITCHERS (lang + ccy) ============= */
.header-switchers{display:flex;gap:8px;align-items:center}
.lang-switcher{position:relative}
@media (max-width:760px){
  .header-inner{flex-wrap:wrap;height:auto;padding:10px 16px}
  .nav{order:3;width:100%;margin-top:8px}
  .nav a{margin-left:0;margin-right:16px}
  .header-switchers{order:2}
}

/* ============= FIX FINAL: chart visivel sem corte ============= */
/* Remove min-width que estava jogando a coluna do grafico pra fora do viewport */
.coins-table{min-width:0 !important}
.coins-table .spark-col{
  min-width:280px !important;
  padding-left:14px !important;
  padding-right:18px !important;
}
.coins-table .spark{
  height:60px !important;
}
.coins-table .spark-col,
.coins-table .spark-col + *{display:table-cell !important}

/* Focus ring discreto nos headers (era um quadrado preto feio) */
.th-sort a:focus,
.th-sort a:focus-visible{
  outline:none;
  box-shadow:0 0 0 2px rgba(22,163,74,.25);
  border-radius:4px;
}
.chip:focus,
.chip:focus-visible{
  outline:none;
  box-shadow:0 0 0 3px rgba(22,163,74,.18);
}

/* ============= FIX ESPECIFICIDADE: spark column visivel ============= */
/* O seletor 'td.num' (tag+class, 0-1-1) era mais especifico que '.spark-col' (0-1-0)
   e estava forcando width:76px na coluna do grafico. Aqui igualamos especificidade. */
.coins-table th.spark-col,
.coins-table td.spark-col{
  width:auto !important;
  min-width:240px !important;
  max-width:none !important;
  padding-left:14px !important;
  padding-right:14px !important;
}
.coins-table th.spark-col{
  color:var(--muted);
  font-weight:600;
  font-size:.78rem;
  text-transform:uppercase;
  letter-spacing:.05em;
  text-align:right;
}
.coins-table td.spark-col .spark{
  display:block !important;
  width:100% !important;
  height:56px !important;
  margin:0 !important;
}

/* ============= OVERRIDE FINAL - forca bruta com maior especificidade ============= */
/* Usa .table-wrap .coins-table (0-2-1) pra sobrepor td.num e .spark-col anteriores */
.table-wrap .coins-table th.spark-col,
.table-wrap .coins-table td.spark-col{
  width:28% !important;
  min-width:300px !important;
  max-width:none !important;
  padding:14px 18px 14px 14px !important;
}

/* Garante que o titulo do header apareca */
.table-wrap .coins-table th.spark-col{
  text-align:right !important;
  color:#64748b !important;
  font-size:.78rem !important;
  font-weight:600 !important;
  text-transform:uppercase !important;
  letter-spacing:.05em !important;
  overflow:visible !important;
}

/* SVG do sparkline esticando ate 100% da td */
.table-wrap .coins-table td.spark-col svg.spark,
.table-wrap .coins-table .spark{
  width:100% !important;
  height:68px !important;
  max-width:none !important;
  min-width:0 !important;
  display:block !important;
  margin:0 !important;
}

/* Encolher numericas pra liberar mais espaco pro grafico */
.coins-table .th-sort,
.coins-table td.num{
  width:72px !important;
  padding-left:10px !important;
  padding-right:10px !important;
}

/* ============= ULTIMA TENTATIVA: header spark visivel ============= */
/* Reset agressivo de qualquer coisa que possa estar escondendo o titulo */
.coins-table th.spark-col,
.coins-table th.spark-col *{
  visibility:visible !important;
  opacity:1 !important;
  text-indent:0 !important;
  color:#64748b !important;
}
.coins-table th.spark-col{
  display:table-cell !important;
  background:#fafbfc !important;
  text-align:right !important;
}

/* ============= MARGEM DIREITA NO GRAFICO ============= */
/* Tira o grafico da borda da tabela */
.table-wrap .coins-table th.spark-col,
.table-wrap .coins-table td.spark-col{
  padding-right:28px !important;
  padding-left:14px !important;
}
.table-wrap .coins-table td.spark-col svg.spark,
.table-wrap .coins-table .spark{
  margin-right:6px !important;
}

/* ============= FIX DEFINITIVO: tabela cabe no container ============= */
/* Problema: as colunas todas somavam > largura disponivel, jogando spark-col pra fora */

/* Encolher cada coluna pro minimo necessario */
.table-wrap .coins-table{
  font-size:.85rem !important;
  min-width:0 !important;
}
.table-wrap .coins-table .rank-col,
.table-wrap .coins-table .rank{width:36px !important;padding:12px 8px !important}
.table-wrap .coins-table .coin-th,
.table-wrap .coins-table .coin-cell{width:170px !important;padding:12px 8px 12px 12px !important}
.table-wrap .coins-table .th-sort,
.table-wrap .coins-table td.num{
  width:74px !important;
  padding:12px 6px !important;
  font-size:.83rem !important;
}
/* Spark column: largura fixa, NAO percentual, cabe sempre */
.table-wrap .coins-table th.spark-col,
.table-wrap .coins-table td.spark-col{
  width:260px !important;
  min-width:260px !important;
  max-width:260px !important;
  padding:10px 18px 10px 12px !important;
  text-align:right !important;
  color:#64748b !important;
  background:#fafbfc;
  font-size:.78rem !important;
  font-weight:600 !important;
  text-transform:uppercase !important;
  letter-spacing:.05em !important;
}
.table-wrap .coins-table td.spark-col{background:#fff}
.table-wrap .coins-table td.spark-col .spark,
.table-wrap .coins-table td.spark-col svg.spark{
  width:100% !important;
  height:62px !important;
  display:block !important;
  margin:0 !important;
}

/* ============================================================
   NEWS TICKER (banner horizontal no topo do site)
   ============================================================ */
.news-ticker{
  display:flex;
  align-items:stretch;
  background:#0f172a;
  color:#e2e8f0;
  font-size:.84rem;
  border-bottom:1px solid #1e293b;
  overflow:hidden;
  position:relative;
}
.news-ticker-label{
  display:flex;
  align-items:center;
  gap:.45rem;
  padding:.55rem 1.1rem .55rem .9rem;
  background:#dc2626;
  color:#fff;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:.05em;
  font-size:.72rem;
  white-space:nowrap;
  flex-shrink:0;
  text-decoration:none;
  position:relative;
  z-index:2;
}
.news-ticker-label:hover{ background:#b91c1c }
.news-ticker-label::after{
  content:"";
  position:absolute;
  right:-12px;
  top:0; bottom:0;
  width:12px;
  background:linear-gradient(115deg,#dc2626 50%,transparent 50.5%);
}
.news-ticker-dot{
  width:8px; height:8px;
  border-radius:50%;
  background:#fff;
  animation:tickerPulse 1.4s ease-in-out infinite;
  flex-shrink:0;
}
@keyframes tickerPulse{
  0%,100%{opacity:1; transform:scale(1)}
  50%{opacity:.35; transform:scale(.65)}
}
.news-ticker-viewport{
  flex:1;
  overflow:hidden;
  position:relative;
  -webkit-mask-image:linear-gradient(90deg,transparent 0,#000 28px,#000 calc(100% - 40px),transparent 100%);
          mask-image:linear-gradient(90deg,transparent 0,#000 28px,#000 calc(100% - 40px),transparent 100%);
}
.news-ticker-track{
  display:inline-flex;
  align-items:center;
  gap:.55rem;
  white-space:nowrap;
  padding-left:1.4rem;
  animation:tickerScroll 80s linear infinite;
  will-change:transform;
}
.news-ticker:hover .news-ticker-track{
  animation-play-state:paused;
}
.news-ticker-item{
  display:inline-flex;
  align-items:baseline;
  gap:.5rem;
  color:#e2e8f0;
  text-decoration:none;
  font-weight:500;
  padding:.6rem 0;
  transition:color .12s ease;
}
.news-ticker-item:hover .news-ticker-title{
  color:#fbbf24;
  text-decoration:underline;
}
.news-ticker-title{ color:#e2e8f0 }
.news-ticker-source{
  color:#94a3b8;
  font-size:.7rem;
  font-weight:500;
  text-transform:uppercase;
  letter-spacing:.04em;
  padding:.12rem .4rem;
  border:1px solid #334155;
  border-radius:3px;
}
.news-ticker-sep{
  color:#475569;
  opacity:.7;
  font-size:.9rem;
}
.news-ticker-more{
  display:flex;
  align-items:center;
  padding:0 1rem;
  color:#cbd5e1;
  text-decoration:none;
  font-size:.74rem;
  font-weight:600;
  text-transform:uppercase;
  letter-spacing:.04em;
  white-space:nowrap;
  flex-shrink:0;
  border-left:1px solid #1e293b;
  background:#0b1220;
}
.news-ticker-more:hover{ color:#fbbf24; background:#111827 }
@keyframes tickerScroll{
  0%{ transform:translate3d(0,0,0) }
  100%{ transform:translate3d(-50%,0,0) }
}
@media (prefers-reduced-motion: reduce){
  .news-ticker-track{ animation:none; padding-left:.6rem }
}
@media (max-width: 720px){
  .news-ticker{ font-size:.78rem }
  .news-ticker-label{ font-size:.65rem; padding:.45rem .7rem }
  .news-ticker-more{ display:none }
  .news-ticker-source{ display:none }
  .news-ticker-track{ animation-duration:55s }
}

/* Ancora de noticia: garante espaco acima e pisca rapidinho ao chegar via #hash */
.news-card{ scroll-margin-top:110px }
.news-card:target{
  animation: newsHighlight 1.6s ease-out 1;
  border-color:#fbbf24 !important;
  box-shadow:0 0 0 3px rgba(251,191,36,.25);
}
@keyframes newsHighlight{
  0%   { box-shadow:0 0 0 0 rgba(251,191,36,.65) }
  60%  { box-shadow:0 0 0 10px rgba(251,191,36,.18) }
  100% { box-shadow:0 0 0 3px rgba(251,191,36,.25) }
}
