/* breadcrumb position on price pages (style itself is global)
   ============================================================ */
.crumb { padding: 18px 0 14px; }

/* ============================================================
   Coindaily - coin detail / price page
   Complements styles.css (base tokens, nav, footer, panels).
   ============================================================ */


/* ---------- Coin hero ---------- */
.coin-hero { padding: 16px 0 22px; border-bottom: 1px solid var(--hairline); }
.coin-head { display: flex; align-items: center; gap: 14px; flex-wrap: wrap; }
.coin-logo { width: 42px; height: 42px; border-radius: 50%; object-fit: cover; background: #16171b; }
.coin-title { display: flex; align-items: center; gap: 10px; }
.coin-title .nm { font-size: 23px; font-weight: 700; color: var(--tx-hi); letter-spacing: -0.02em; }
.coin-title .sym { font-family: var(--mono); font-size: 12px; color: var(--tx-mid); background: var(--panel-2); border: 1px solid var(--hairline); padding: 2px 7px; border-radius: 5px; text-transform: uppercase; }
.rank-badge { font-family: var(--mono); font-size: 11px; color: var(--amber); border: 1px solid rgba(201,154,75,.3); background: rgba(201,154,75,.06); padding: 3px 8px; border-radius: 5px; }
.coin-actions { margin-left: auto; display: flex; gap: 8px; }
.coin-actions .btn { height: 34px; }
.btn-watch { border: 1px solid var(--hairline); color: var(--tx); }
.btn-watch:hover { border-color: rgba(255,255,255,.2); background: var(--panel-2); }

.price-row { display: flex; align-items: flex-end; gap: 28px; margin-top: 22px; flex-wrap: wrap; }
.price-main .price-big { font-family: var(--mono); font-size: 38px; font-weight: 600; color: var(--tx-hi); letter-spacing: -0.02em; line-height: 1; }
.price-main .price-meta { display: flex; align-items: center; gap: 10px; margin-top: 10px; }
.price-chg { font-family: var(--mono); font-size: 14px; font-weight: 600; padding: 3px 8px; border-radius: 6px; }
.price-chg.up { color: var(--up); background: var(--up-bg); }
.price-chg.down { color: var(--down); background: var(--down-bg); }
.price-usd { font-family: var(--mono); font-size: 13px; color: var(--tx-dim); }

.range { flex: 1; min-width: 240px; max-width: 360px; }
.range-head { display: flex; justify-content: space-between; align-items: baseline; font-family: var(--mono); font-size: 12px; color: var(--tx); margin-bottom: 7px; }
.range-head .lab { font-family: var(--sans); font-size: 11px; color: var(--tx-dim); text-transform: uppercase; letter-spacing: .06em; }
.range-track { height: 5px; border-radius: 3px; background: linear-gradient(90deg, var(--down), var(--amber-dim), var(--up)); position: relative; opacity: .75; }
.range-track i { position: absolute; top: -3px; width: 2px; height: 11px; background: var(--tx-hi); border-radius: 1px; }
.range-lbl { display: flex; justify-content: space-between; font-family: var(--mono); font-size: 11px; color: var(--tx-mid); margin-top: 7px; }

/* ---------- Main grid ---------- */
.coin-grid { display: grid; grid-template-columns: 1fr 336px; gap: 18px; align-items: start; padding: 22px 0; }
.coin-main { display: flex; flex-direction: column; gap: 18px; }
.coin-side { display: flex; flex-direction: column; gap: 18px; }

/* ---------- Chart ---------- */
.chart-tabs { display: flex; gap: 1px; background: var(--hairline-2); border: 1px solid var(--hairline); border-radius: var(--r-sm); overflow: hidden; }
.chart-tabs button { padding: 4px 11px; font-family: var(--mono); font-size: 11px; color: var(--tx-dim); background: var(--panel); transition: .12s; }
.chart-tabs button.active { color: var(--amber); }
.chart-tabs button:hover { color: var(--tx); }
.chart-wrap { position: relative; padding: 14px 16px 6px; }
.chart-svg { width: 100%; height: 300px; display: block; }
.chart-ylab { position: absolute; right: 18px; font-family: var(--mono); font-size: 10px; color: var(--tx-dim); background: var(--panel); padding: 0 4px; transform: translateY(-50%); }
.chart-meta { display: flex; justify-content: space-between; padding: 10px 16px 14px; font-family: var(--mono); font-size: 11px; color: var(--tx-dim); border-top: 1px solid var(--hairline-2); }

/* ===== Supply panel ===== */
.sup-verified { display: inline-flex; align-items: center; gap: 5px; font-family: var(--mono); font-size: 10.5px; font-weight: 600; color: #5f9277; }
.sup-cards { display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px; padding: 15px 16px 6px; }
.sup-card { background: var(--panel-2); border: 1px solid var(--hairline); border-radius: 12px; padding: 13px 15px; }
.sup-card-h { font-size: 11.5px; color: var(--tx-mid); font-weight: 600; margin-bottom: 11px; }
.sup-card-h small { color: var(--tx-dim); font-weight: 400; }
.sup-gauge-row { display: flex; align-items: center; gap: 12px; }
.sup-gauge { width: 56px; height: 56px; flex: none; }
.sup-gauge-v { font-family: var(--mono); font-size: 19px; font-weight: 700; line-height: 1; }
.sup-gauge-l { font-size: 11px; font-weight: 600; margin-top: 5px; }
.sup-inf-v { font-family: var(--mono); font-size: 21px; font-weight: 700; line-height: 1; color: var(--tx-hi); }
.sup-inf-l { font-size: 11.5px; color: var(--tx-mid); margin-top: 6px; }
.sup-table { padding: 8px 16px 2px; }
.sup-row { display: flex; justify-content: space-between; align-items: center; padding: 11px 2px; border-top: 1px solid var(--hairline-2); font-size: 13px; }
.sup-row:first-child { border-top: none; }
.sup-row .k { color: var(--tx-mid); }
.sup-row .v { font-family: var(--mono); color: var(--tx-hi); font-weight: 600; }
.sup-foot { padding: 6px 16px 14px; font-size: 11px; color: var(--tx-dim); font-family: var(--mono); }

/* ===== Market Cap + Gains/Losses panels ===== */
.mc-top { display: flex; align-items: baseline; gap: 12px; padding: 14px 16px 0; }
.mc-now { font-family: var(--mono); font-size: 18px; font-weight: 700; color: var(--tx-hi); }
.mc-chg { font-family: var(--mono); font-size: 13px; font-weight: 600; }
.mc-hi { margin-left: auto; font-family: var(--mono); font-size: 11px; color: var(--tx-dim); }
.mc-foot { display: flex; justify-content: flex-end; padding: 0 16px 14px; }
.mc-lo { font-family: var(--mono); font-size: 11px; color: var(--tx-dim); }
.mc-svg { width: 100%; height: 230px; display: block; }
.gl-svg { width: 100%; height: 190px; display: block; }
.gl-top { display: flex; align-items: baseline; justify-content: space-between; padding: 14px 16px 0; }
.gl-net { font-size: 12px; color: var(--tx-mid); }
.gl-net b { font-family: var(--mono); }
.gl-pos, .gl-neg, .gl-sum { font-family: var(--mono); font-size: 12.5px; font-weight: 600; }
.gl-foot { display: flex; justify-content: flex-end; padding: 0 16px 14px; }
@media (max-width: 560px) { .sup-cards { grid-template-columns: 1fr; } }
.chart-meta b { color: var(--tx); font-weight: 500; }

/* ---------- Performance ---------- */
.perf-grid { display: grid; grid-template-columns: repeat(6, 1fr); }
.perf-cell { padding: 15px 12px; border-right: 1px solid var(--hairline-2); text-align: center; }
.perf-cell:last-child { border-right: none; }
.perf-cell .l { font-size: 10px; color: var(--tx-dim); text-transform: uppercase; letter-spacing: .05em; margin-bottom: 7px; }
.perf-cell .v { font-family: var(--mono); font-size: 13.5px; font-weight: 600; }

/* ---------- KPI stats (sidebar) ---------- */
.kpi { display: flex; justify-content: space-between; align-items: flex-start; padding: 12px 16px; border-bottom: 1px solid var(--hairline-2); font-size: 13px; }
.kpi:last-child { border-bottom: none; }
.kpi .k { color: var(--tx-mid); display: flex; flex-direction: column; gap: 2px; }
.kpi .k .sub { font-size: 10px; color: var(--tx-faint); }
.kpi .v { font-family: var(--mono); color: var(--tx-hi); text-align: right; display: flex; flex-direction: column; gap: 3px; align-items: flex-end; }
.kpi .v .sub { font-size: 10px; color: var(--tx-dim); }
.kpi .rk { font-family: var(--mono); font-size: 10px; color: var(--amber); border: 1px solid rgba(201,154,75,.25); border-radius: 4px; padding: 1px 5px; }
.supply-bar { width: 150px; height: 4px; border-radius: 2px; background: var(--panel-2); overflow: hidden; margin-top: 4px; }
.supply-bar i { display: block; height: 100%; background: var(--amber); }

/* ---------- Converter ---------- */
.conv { padding: 16px; }
.conv-row { display: flex; align-items: center; gap: 10px; background: var(--bg); border: 1px solid var(--hairline); border-radius: 8px; padding: 11px 13px; margin-bottom: 9px; }
.conv-row .u { font-family: var(--mono); font-size: 12px; color: var(--tx-mid); min-width: 38px; }
.conv-row input { flex: 1; width: 100%; background: none; border: none; color: var(--tx-hi); font-family: var(--mono); font-size: 16px; outline: none; text-align: right; }
.conv-rate { font-family: var(--mono); font-size: 11px; color: var(--tx-dim); text-align: center; }

/* ---------- About ---------- */
.about { padding: 16px 18px; }
.about p { font-size: 13.5px; line-height: 1.7; color: var(--tx); }
.about p + p { margin-top: 12px; }
.tag-row { display: flex; gap: 7px; flex-wrap: wrap; margin-top: 16px; }
.tagx { font-size: 11px; color: var(--tx-mid); border: 1px solid var(--hairline); border-radius: 5px; padding: 4px 10px; }

/* ---------- Markets table ---------- */
.mkt-table { width: 100%; border-collapse: collapse; }
.mkt-table thead th { text-align: right; font-size: 10px; color: var(--tx-dim); font-weight: 500; letter-spacing: .05em; text-transform: uppercase; padding: 11px 14px; border-bottom: 1px solid var(--hairline); }
.mkt-table th:nth-child(1), .mkt-table th:nth-child(2), .mkt-table td:nth-child(1), .mkt-table td:nth-child(2) { text-align: left; }
.mkt-table td { padding: 12px 14px; border-bottom: 1px solid var(--hairline-2); text-align: right; font-family: var(--mono); font-size: 12.5px; color: var(--tx); }
.mkt-table tbody tr:last-child td { border-bottom: none; }
.mkt-table tbody tr:hover { background: rgba(255,255,255,.018); }
.mkt-table .rk { color: var(--tx-dim); width: 30px; }
.mkt-ex { display: flex; align-items: center; gap: 9px; font-family: var(--sans); font-weight: 500; color: var(--tx-hi); }
.mkt-ex img { width: 18px; height: 18px; border-radius: 4px; object-fit: cover; }
.mkt-pair { font-family: var(--mono); color: var(--tx); }
.trust { display: inline-block; width: 7px; height: 7px; border-radius: 50%; }
.mkt-table td.mkt-trade { text-align: right; padding-left: 8px; }
.mkt-trade-btn { display: inline-flex; align-items: center; gap: 4px; font-family: var(--sans); font-size: 12px; font-weight: 600; color: var(--amber); background: rgba(201,154,75,.08); border: 1px solid var(--amber-dim); border-radius: 5px; padding: 5px 12px; text-decoration: none; white-space: nowrap; transition: .14s; }
.mkt-trade-btn:hover { background: var(--amber); color: #15100a; border-color: var(--amber); }

/* ---------- Links / similar ---------- */
.link-row { display: flex; flex-wrap: wrap; gap: 8px; padding: 15px 16px; }
.link-chip { display: inline-flex; align-items: center; gap: 7px; font-size: 12px; color: var(--tx); border: 1px solid var(--hairline); border-radius: 6px; padding: 6px 11px; transition: .12s; }
.link-chip:hover { border-color: rgba(255,255,255,.2); color: var(--tx-hi); background: var(--panel-2); }
.sim-row { display: flex; align-items: center; gap: 11px; padding: 11px 16px; border-bottom: 1px solid var(--hairline-2); font-size: 13px; }
.sim-row:last-child { border-bottom: none; }
.sim-row:hover { background: rgba(255,255,255,.018); }
.sim-row img { width: 22px; height: 22px; border-radius: 50%; object-fit: cover; }
.sim-row .s { font-weight: 600; color: var(--tx-hi); }
.sim-row .n { font-size: 11px; color: var(--tx-dim); }
.sim-row .px { margin-left: auto; font-family: var(--mono); color: var(--tx); text-align: right; }
.sim-row .px small { display: block; font-size: 10px; }

@media (max-width: 1000px) {
  .coin-grid { grid-template-columns: 1fr; }
  .perf-grid { grid-template-columns: repeat(3, 1fr); }
  .perf-cell:nth-child(3) { border-right: none; }
  .perf-cell:nth-child(n+4) { border-top: 1px solid var(--hairline-2); }
}

/* ============================================================
   Live-data loading skeleton - shimmer the dynamic values until
   real Coinranking data lands, so no placeholder numbers flash.
   ============================================================ */
@keyframes pp-shimmer { 0% { background-position: 100% 0; } 100% { background-position: 0 0; } }
body.pp-loading #px-big,
body.pp-loading #px-chg,
body.pp-loading #px-usd,
body.pp-loading #range-low,
body.pp-loading #range-high,
body.pp-loading [data-perf],
body.pp-loading .kpi .v {
  color: transparent !important;
  background: linear-gradient(90deg, var(--panel-2) 25%, var(--elevated) 37%, var(--panel-2) 63%);
  background-size: 400% 100%;
  animation: pp-shimmer 1.3s ease-in-out infinite;
  border-radius: 4px;
}
body.pp-loading .kpi .v .rk,
body.pp-loading .kpi .v .sub,
body.pp-loading .kpi .v .supply-bar { visibility: hidden; }
body.pp-chart-loading #chart-svg { opacity: 0; }
body.pp-chart-loading #chart-wrap { position: relative; }
body.pp-chart-loading #chart-wrap::after {
  content: ""; position: absolute; inset: 14px 14px 30px;
  background: linear-gradient(90deg, var(--panel-2) 25%, var(--elevated) 37%, var(--panel-2) 63%);
  background-size: 400% 100%; animation: pp-shimmer 1.3s ease-in-out infinite; border-radius: 6px;
}
/* extend the skeleton to the Supply / Market Cap / Gains & Losses / Markets panels */
body.pp-loading #sup-circ-pct, body.pp-loading #sup-circ-risk,
body.pp-loading #sup-mo, body.pp-loading #sup-mo-l, body.pp-loading #sup-yr, body.pp-loading #sup-yr-l,
body.pp-loading #sup-circ, body.pp-loading #sup-total, body.pp-loading #sup-max,
body.pp-panels-loading #mc-now, body.pp-panels-loading #mc-chg, body.pp-panels-loading #mc-hi, body.pp-panels-loading #mc-lo,
body.pp-panels-loading #gl-sum, body.pp-panels-loading #gl-pos, body.pp-panels-loading #gl-neg {
  color: transparent !important;
  background: linear-gradient(90deg, var(--panel-2) 25%, var(--elevated) 37%, var(--panel-2) 63%);
  background-size: 400% 100%; animation: pp-shimmer 1.3s ease-in-out infinite; border-radius: 4px;
}
body.pp-loading #sup-gauge { opacity: 0; }
body.pp-panels-loading #mc-svg, body.pp-panels-loading #gl-svg { opacity: 0; }
body.pp-panels-loading #mc-wrap, body.pp-panels-loading #gl-wrap { position: relative; }
body.pp-panels-loading #mc-wrap::after, body.pp-panels-loading #gl-wrap::after {
  content: ""; position: absolute; inset: 8px;
  background: linear-gradient(90deg, var(--panel-2) 25%, var(--elevated) 37%, var(--panel-2) 63%);
  background-size: 400% 100%; animation: pp-shimmer 1.3s ease-in-out infinite; border-radius: 6px;
}
.mkt-skel td { vertical-align: middle; }
.mkt-skel .sk { display: inline-block; height: 11px; width: 64px; border-radius: 4px; vertical-align: middle;
  background: linear-gradient(90deg, var(--panel-2) 25%, var(--elevated) 37%, var(--panel-2) 63%);
  background-size: 400% 100%; animation: pp-shimmer 1.3s ease-in-out infinite; }
.mkt-skel .sk-ex { width: 104px; }
/* Markets dash empty-state (real tickers never landed) - centred + muted, never modelled rows. */
.mkt-empty { text-align: center; color: var(--tx-dim); padding: 24px; font-family: var(--mono); }
