/* ==========================================================================
   Thunder Stallion — Coin detail page
   ========================================================================== */

.coin-hero { padding-top: calc(var(--nav-h) + 36px); }
.coin-back { display: inline-flex; align-items: center; gap: 8px; color: var(--text-dim); font-size: 14px; margin-bottom: 22px; transition: color var(--t-fast); }
.coin-back:hover { color: var(--cyan-bright); }
.coin-back svg { width: 16px; height: 16px; }

.coin-top { display: grid; grid-template-columns: 1.5fr 1fr; gap: 26px; align-items: stretch; }

.coin-id-card { position: relative; overflow: hidden; padding: 30px; }
.coin-id-card__glow { position: absolute; top: -80px; right: -40px; width: 240px; height: 240px; background: radial-gradient(circle, rgba(138, 61, 255, 0.3), transparent 70%); pointer-events: none; }
.coin-id__head { display: flex; align-items: center; gap: 18px; margin-bottom: 26px; }
.coin-id__logo { width: 78px; height: 78px; border-radius: 20px; object-fit: cover; box-shadow: 0 0 0 1px var(--border-strong), var(--glow-purple); background: var(--surface-2); }
.coin-id__title h1 { font-size: clamp(28px, 4vw, 40px); display: flex; align-items: center; gap: 12px; flex-wrap: wrap; }
.coin-id__title .ticker { font-family: var(--font-mono); color: var(--text-dim); font-size: 18px; font-weight: 500; }
.coin-id__tags { display: flex; gap: 8px; margin-top: 12px; flex-wrap: wrap; }

.coin-price-row { display: flex; align-items: flex-end; gap: 16px; margin-bottom: 26px; flex-wrap: wrap; }
.coin-price { font-family: var(--font-mono); font-size: clamp(32px, 5vw, 48px); font-weight: 700; letter-spacing: -0.02em; }
.coin-price-row .delta { font-size: 18px; padding-bottom: 8px; }

/* Links / actions */
.coin-links { display: flex; gap: 10px; flex-wrap: wrap; }
.coin-link { display: inline-flex; align-items: center; gap: 8px; padding: 10px 15px; border-radius: var(--r-pill); background: var(--surface); border: 1px solid var(--border); font-size: 13.5px; font-weight: 500; color: var(--text-dim); transition: all var(--t-fast) var(--ease); }
.coin-link:hover { color: var(--text); border-color: var(--border-glow); box-shadow: var(--glow-soft); transform: translateY(-2px); }
.coin-link svg { width: 16px; height: 16px; }

/* Contract address copy */
.contract { display: flex; align-items: center; gap: 12px; margin-top: 22px; padding: 13px 16px; border-radius: var(--r-md); background: var(--bg-0); border: 1px solid var(--border); }
.contract span { font-size: 11px; color: var(--text-faint); text-transform: uppercase; letter-spacing: 0.1em; }
.contract code { font-family: var(--font-mono); font-size: 13.5px; color: var(--cyan-bright); flex: 1; overflow: hidden; text-overflow: ellipsis; }
.contract button { display: inline-flex; align-items: center; gap: 6px; padding: 8px 13px; border-radius: var(--r-sm); background: var(--surface-2); border: 1px solid var(--border); color: var(--text); font-size: 13px; font-weight: 600; transition: all var(--t-fast); }
.contract button:hover { border-color: var(--border-glow); color: var(--cyan-bright); }
.contract button.copied { color: var(--up); border-color: var(--up); }

/* Stats panel */
.coin-stats { display: grid; grid-template-columns: repeat(2, 1fr); gap: 1px; background: var(--border); border-radius: var(--r-lg); overflow: hidden; }
.coin-stat { padding: 20px; background: var(--surface-solid); }
.coin-stat span { display: block; font-size: 12px; color: var(--text-faint); text-transform: uppercase; letter-spacing: 0.08em; margin-bottom: 7px; }
.coin-stat b { font-family: var(--font-mono); font-size: 21px; font-weight: 700; }

/* Chart placeholder */
.chart-card { margin-top: 26px; padding: 0; overflow: hidden; }
.chart-card__head { display: flex; align-items: center; justify-content: space-between; padding: 20px 24px; border-bottom: 1px solid var(--border); }
.chart-card__tabs { display: flex; gap: 4px; }
.chart-card__tabs button { padding: 6px 13px; border-radius: var(--r-sm); font-size: 13px; color: var(--text-dim); font-family: var(--font-mono); }
.chart-card__tabs button.active { background: var(--surface-2); color: var(--cyan-bright); }
.chart-ph { position: relative; height: 360px; display: grid; place-items: center; background: radial-gradient(600px 300px at 50% 120%, rgba(25, 227, 255, 0.08), transparent 70%); }
.chart-ph__grid { position: absolute; inset: 0; background-image: linear-gradient(rgba(124,150,255,0.06) 1px, transparent 1px), linear-gradient(90deg, rgba(124,150,255,0.06) 1px, transparent 1px); background-size: 48px 48px; }
.chart-ph svg { width: 100%; height: 100%; position: absolute; inset: 0; }
.chart-ph__note { position: relative; z-index: 2; text-align: center; color: var(--text-faint); }
.chart-ph__note .badge { margin-bottom: 10px; }

/* Live DexScreener embedded chart */
.chart-embed { position: relative; width: 100%; height: clamp(380px, 56vh, 560px); background: var(--bg-0); }
.chart-embed iframe { position: absolute; inset: 0; width: 100%; height: 100%; border: 0; display: block; }

/* About + related */
.coin-body { display: grid; grid-template-columns: 1.5fr 1fr; gap: 26px; margin-top: 26px; align-items: start; }
.about-card { padding: 28px; }
.about-card h3 { font-size: 20px; margin-bottom: 14px; }
.about-card p { color: var(--text-dim); margin-bottom: 14px; }
.about-card .tag-row { display: flex; gap: 8px; flex-wrap: wrap; margin-top: 18px; }

.related-card { padding: 24px; }
.related-card h3 { font-size: 18px; margin-bottom: 16px; }
.related-item { display: flex; align-items: center; gap: 12px; padding: 12px; border-radius: var(--r-md); transition: background var(--t-fast); cursor: pointer; }
.related-item:hover { background: rgba(124, 150, 255, 0.08); }
.related-item img, .related-item .ph { width: 38px; height: 38px; border-radius: 10px; object-fit: cover; background: var(--surface-2); }
.related-item .m { flex: 1; min-width: 0; }
.related-item .m b { font-size: 14.5px; display: block; }
.related-item .m span { font-size: 12px; color: var(--text-dim); }

/* skeleton wrapper for coin page */
.coin-skeleton .sk-line { height: 16px; }
