/* Kintara Gold Strategy — design system.
   Faithful to the in-game HUD / marketplace: dark metallic panels, embossed
   depth, gold currency accents, green/red action colors, Cinzel wordmark. */

@import url('https://fonts.googleapis.com/css2?family=Cinzel:wght@500;700;900&display=swap');

:root {
  /* panels & surfaces */
  --panel: linear-gradient(165deg, #6f7379 0%, #4a4d52 38%, #35383d 100%);
  --panel-edge: #0a0a0a;
  --inset: linear-gradient(180deg, #0c0d10, #14161c);
  --inset2: linear-gradient(180deg, rgba(14,16,20,.96), rgba(8,9,12,.98));
  --cell: linear-gradient(180deg, rgba(30,32,38,.95), rgba(16,18,22,.98));
  --bd: #0a0a0a;
  --bd2: #050505;
  /* text */
  --text: #eceff3;
  --text2: #cfd6e0;
  --muted: #9aa3ad;
  --faint: #7a8290;
  /* accents */
  --gold: #ffd46b;
  --gold-soft: #ffe066;
  --gold-grad: linear-gradient(180deg, #caa23e, #8a6e1e);
  --green: #4ade80;
  --green-grad: linear-gradient(180deg, #3d8f63, #2a6b45);
  --red: #ff7e7e;
  --red-grad: linear-gradient(180deg, #d24a4a, #8b2020);
  --blue: #6ab0ef;
  --sky: #5fa1cf;
  --purple: #a78bfa;
  /* shadows */
  --hi: inset 0 1px 0 rgba(255,255,255,.14);
  --lo: inset 0 -1px 0 rgba(0,0,0,.24);
  --drop: 0 2px 0 rgba(0,0,0,.42);
  --float: 0 18px 48px rgba(0,0,0,.55);
  --serif: 'Cinzel', 'Trajan Pro', Georgia, 'Times New Roman', serif;
  --sans: system-ui, 'Segoe UI', Roboto, sans-serif;
}

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body {
  font-family: var(--sans);
  color: var(--text);
  background: #07080a;
  min-height: 100vh;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

/* ---- ambient background ---- */
.bg { position: fixed; inset: 0; z-index: -1; overflow: hidden; }
.bg__sky {
  position: absolute; inset: 0;
  background:
    radial-gradient(120% 70% at 50% -10%, rgba(95,161,207,.20), transparent 60%),
    linear-gradient(180deg, #0d1014 0%, #0a0b0e 40%, #08090b 100%);
}
.bg__glow {
  position: absolute; inset: 0;
  background:
    radial-gradient(40% 30% at 12% 8%, rgba(255,212,107,.07), transparent 70%),
    radial-gradient(45% 35% at 92% 90%, rgba(61,143,99,.08), transparent 70%);
}
.bg__grain { position: absolute; inset: 0; opacity: .04;
  background-image: radial-gradient(rgba(255,255,255,.5) .5px, transparent .5px);
  background-size: 3px 3px; }

/* ---- topbar ---- */
.topbar {
  position: sticky; top: 0; z-index: 50;
  display: flex; align-items: center; justify-content: space-between;
  gap: 16px; padding: 12px clamp(14px, 3vw, 34px);
  background: linear-gradient(180deg, rgba(12,13,16,.92), rgba(12,13,16,.66));
  backdrop-filter: blur(10px);
  border-bottom: 1px solid rgba(0,0,0,.6);
  box-shadow: 0 1px 0 rgba(255,255,255,.05), 0 8px 24px rgba(0,0,0,.4);
}
.brand { display: flex; align-items: center; gap: 12px; }
.brand__coin { width: 38px; height: 38px; filter: drop-shadow(0 2px 6px rgba(255,200,80,.35)); }
.brand__txt { display: flex; flex-direction: column; line-height: 1; }
.brand__name {
  font-family: var(--serif); font-weight: 900; letter-spacing: .14em;
  font-size: 22px; color: #fff;
  text-shadow: 0 0 16px rgba(255,212,107,.35), 0 2px 4px rgba(0,0,0,.6);
}
.brand__sub { font-size: 10.5px; font-weight: 700; letter-spacing: .22em;
  color: var(--gold); text-transform: uppercase; margin-top: 5px; opacity: .85; }

.topbar__meta { display: flex; align-items: center; gap: 12px; font-size: 12.5px; color: var(--muted); }
.acct { font-weight: 700; color: var(--text2); }
.dot { color: var(--faint); }
.updated { color: var(--muted); font-variant-numeric: tabular-nums; }

.chip {
  font-size: 10px; font-weight: 800; letter-spacing: .08em; text-transform: uppercase;
  padding: 4px 9px; border-radius: 999px; border: 1px solid var(--bd2);
}
.chip--mode { color: #cfe9ff; background: linear-gradient(180deg, rgba(74,154,230,.35), rgba(30,60,100,.4)); }
.chip--mode.live { color: #d6ffe4; background: linear-gradient(180deg, rgba(61,143,99,.5), rgba(30,80,50,.5)); box-shadow: 0 0 0 1px rgba(74,222,128,.4), 0 0 14px rgba(74,222,128,.25); }
.chip--mode.demo { color: var(--gold); background: linear-gradient(180deg, rgba(202,162,62,.4), rgba(90,70,24,.4)); }

/* ---- buttons ---- */
.btn {
  font: 800 11.5px/1 var(--sans); letter-spacing: .03em; cursor: pointer;
  color: var(--text); border: 2px solid var(--bd2); border-radius: 9px;
  padding: 8px 12px; background: linear-gradient(180deg, #5c6066, #3f4247);
  box-shadow: var(--hi), var(--drop); transition: transform .12s, filter .12s, box-shadow .12s;
}
.btn:hover { filter: brightness(1.08); }
.btn:active { transform: translateY(1px) scale(.98); box-shadow: inset 0 4px 10px rgba(0,0,0,.4); }
.btn--ghost { background: linear-gradient(180deg, #34373c, #26282c); color: var(--text2); }
.btn--gold { background: var(--gold-grad); color: #2a210a; }
.btn--green { background: var(--green-grad); color: #eafff0; }
.btn:disabled { opacity: .5; cursor: not-allowed; filter: saturate(.6); }

/* ---- layout ---- */
.wrap { max-width: 1320px; margin: 0 auto; padding: 22px clamp(14px, 3vw, 34px) 40px; }
/* full-width bands (hero chart, market table) */
.band { width: 100%; margin-top: 18px; }
/* masonry card cluster — packs cards to balanced columns, no fixed-row gaps */
.masonry { columns: 3; column-gap: 18px; margin-top: 18px; }
.masonry > .panel { break-inside: avoid; margin: 0 0 18px; width: 100%; }
@media (max-width: 1080px) { .masonry { columns: 2; } }
@media (max-width: 680px) { .masonry { columns: 1; } }

/* ---- panels ---- */
.panel {
  border-radius: 14px; border: 2px solid var(--panel-edge);
  background: var(--panel); box-shadow: var(--hi), var(--lo), var(--drop);
  padding: 14px 14px 13px; color: var(--text); min-width: 0;
}
.panel__head { display: flex; align-items: center; justify-content: space-between; gap: 10px;
  margin: -2px 0 11px; padding-bottom: 9px; border-bottom: 1px solid rgba(0,0,0,.4);
  box-shadow: 0 1px 0 rgba(255,255,255,.05); }
.panel__title { font-size: 12.5px; font-weight: 800; letter-spacing: .07em; text-transform: uppercase; color: #f1f3f6;
  text-shadow: 0 1px 0 rgba(255,255,255,.18), 0 -1px 0 rgba(0,0,0,.45); display: flex; align-items: center; gap: 8px; }
.panel__title .ic { width: 15px; height: 15px; opacity: .9; }
.panel__hint { font-size: 10.5px; font-weight: 700; color: var(--muted); letter-spacing: .02em; }

/* ---- hero stat cards ---- */
.stats { display: grid; grid-template-columns: repeat(4, 1fr); gap: 18px; }
@media (max-width: 1080px) { .stats { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 560px) { .stats { grid-template-columns: 1fr; } }
.stat {
  position: relative; overflow: hidden;
  border-radius: 14px; border: 2px solid var(--panel-edge); background: var(--panel);
  box-shadow: var(--hi), var(--lo), var(--drop); padding: 14px 16px 15px;
}
.stat::after { content: ''; position: absolute; right: -30px; top: -30px; width: 110px; height: 110px;
  border-radius: 50%; background: radial-gradient(circle, var(--accent, rgba(255,212,107,.16)), transparent 68%); }
.stat__label { font-size: 10.5px; font-weight: 800; letter-spacing: .1em; text-transform: uppercase; color: var(--muted); }
.stat__val { font-size: 30px; font-weight: 900; letter-spacing: -.01em; margin: 7px 0 3px;
  font-variant-numeric: tabular-nums; display: flex; align-items: baseline; gap: 8px; }
.stat__val .unit { font-size: 14px; font-weight: 700; color: var(--muted); }
.stat__val .coin { width: 22px; height: 22px; transform: translateY(2px); }
.stat__sub { font-size: 11.5px; font-weight: 700; color: var(--text2); }
.stat--gold .stat__val { color: var(--gold); text-shadow: 0 0 18px rgba(255,212,107,.25); }
.stat--pnl { --accent: rgba(74,222,128,.18); }

/* ---- key/value rows ---- */
.kv { display: flex; align-items: baseline; justify-content: space-between; gap: 12px; padding: 7px 0;
  border-bottom: 1px dashed rgba(255,255,255,.06); }
.kv:last-child { border-bottom: 0; }
.kv__k { font-size: 12px; color: var(--muted); font-weight: 600; }
.kv__v { font-size: 13.5px; font-weight: 800; color: var(--text); font-variant-numeric: tabular-nums; }
.kv__v.gold { color: var(--gold); }
.big { font-size: 19px; }

/* numbers / deltas */
.num { font-variant-numeric: tabular-nums; }
.pos { color: var(--green); }
.neg { color: var(--red); }
.gold-t { color: var(--gold); }
.muted { color: var(--muted); }

/* ---- price ladder (strategy) ---- */
.ladder { margin-top: 6px; }
.ladder svg { width: 100%; height: auto; display: block; }

/* ---- chart ---- */
.chart { width: 100%; }
.chart svg { width: 100%; height: auto; display: block; }
.chart__legend { display: flex; flex-wrap: wrap; gap: 14px; margin-top: 10px; font-size: 11px; color: var(--muted); font-weight: 700; }
.chart__legend i { display: inline-block; width: 16px; height: 0; vertical-align: middle; margin-right: 6px; }
.lg-price i { border-top: 3px solid var(--gold); }
.lg-cost i { border-top: 3px dashed var(--green); }
.lg-target i { border-top: 3px dashed var(--gold-soft); }
.lg-vol i { border-top: 8px solid rgba(106,176,239,.4); height: 8px; border-radius: 2px; }

/* ---- tables ---- */
.tbl-wrap { border-radius: 10px; border: 2px solid var(--bd2); background: var(--inset);
  box-shadow: inset 0 2px 8px rgba(0,0,0,.45); overflow: hidden; }
.tbl { width: 100%; border-collapse: collapse; font-size: 12px; }
.tbl thead th { font-size: 10px; font-weight: 800; letter-spacing: .06em; text-transform: uppercase;
  color: var(--muted); text-align: right; padding: 10px 13px; background: rgba(255,255,255,.02);
  border-bottom: 1px solid rgba(0,0,0,.5); position: sticky; top: 0; white-space: nowrap; }
.tbl thead th:first-child { text-align: left; padding-left: 15px; }
.tbl thead th:last-child, .tbl tbody td:last-child { padding-right: 16px; }
.tbl tbody td { padding: 10px 13px; text-align: right; border-bottom: 1px solid rgba(255,255,255,.04);
  font-variant-numeric: tabular-nums; color: var(--text2); }
.tbl tbody td:first-child { text-align: left; color: var(--text); font-weight: 700; padding-left: 15px; }
.tbl tbody tr:last-child td { border-bottom: 0; }
.tbl tbody tr:hover { background: rgba(255,255,255,.05); }
.tbl tbody tr.is-buy { background: rgba(74,222,128,.10); }
.tbl tbody tr.is-buy:hover { background: rgba(74,222,128,.16); }
.tbl tbody tr.is-floor td:first-child::after { content: 'FLOOR'; margin-left: 8px; font-size: 8.5px;
  font-weight: 800; letter-spacing: .08em; color: var(--gold); border: 1px solid rgba(255,212,107,.4);
  padding: 1px 5px; border-radius: 999px; vertical-align: middle; }
.tbl tbody tr.is-ours td:first-child { color: var(--gold); }
.tbl-scroll { max-height: 340px; overflow: auto; }

/* badges / tags */
.tag { font-size: 9px; font-weight: 800; letter-spacing: .06em; padding: 2px 6px; border-radius: 999px;
  text-transform: uppercase; border: 1px solid currentColor; }
.tag--buy { color: var(--green); }
.tag--ours { color: var(--gold); }
.tag--sell { color: var(--red); }
.seller { color: var(--muted); font-weight: 600; }

/* status pill (table STATUS column) */
.pill-status { display: inline-block; font-size: 9.5px; font-weight: 800; letter-spacing: .05em;
  text-transform: uppercase; padding: 3px 9px; border-radius: 999px; color: var(--muted);
  border: 1px solid rgba(255,255,255,.12); background: rgba(255,255,255,.03); }
.pill-status.live { color: var(--green); border-color: rgba(74,222,128,.35); background: rgba(74,222,128,.08); }
.pill-status.locked { color: var(--red); border-color: rgba(255,126,126,.35); background: rgba(255,126,126,.08); }

/* recs list */
.rec { display: flex; align-items: center; gap: 12px; padding: 10px 12px; border-radius: 10px;
  border: 1px solid rgba(0,0,0,.4); background: rgba(0,0,0,.16); margin-bottom: 8px; }
.rec:last-child { margin-bottom: 0; }
.rec--buy { box-shadow: inset 0 0 0 1px rgba(74,222,128,.18); }
.rec--relist { box-shadow: inset 0 0 0 1px rgba(255,212,107,.18); }
.rec__main { flex: 1; min-width: 0; }
.rec__title { font-size: 12.5px; font-weight: 800; color: var(--text); }
.rec__meta { font-size: 11px; color: var(--muted); margin-top: 3px; font-weight: 600; }
.rec__profit { text-align: right; }
.rec__profit b { font-size: 14px; font-weight: 900; }
.rec__profit small { display: block; font-size: 10px; color: var(--muted); font-weight: 700; }
.subhead { font-size: 11px; font-weight: 800; letter-spacing: .08em; text-transform: uppercase;
  color: var(--muted); margin: 4px 0 8px; display: flex; align-items: center; gap: 8px; }
.subhead::after { content: ''; flex: 1; height: 1px; background: linear-gradient(90deg, rgba(255,255,255,.1), transparent); }

/* activity log */
.feed { display: flex; flex-direction: column; gap: 2px; max-height: 280px; overflow: auto; }
.feed__row { display: grid; grid-template-columns: auto 1fr auto; gap: 10px; align-items: center;
  padding: 8px 10px; border-radius: 8px; font-size: 12px; }
.feed__row:nth-child(odd) { background: rgba(255,255,255,.025); }
.feed__when { font-size: 10.5px; color: var(--faint); font-variant-numeric: tabular-nums; }
.feed__amt { font-variant-numeric: tabular-nums; font-weight: 800; }

.empty { color: var(--faint); font-size: 12px; font-style: italic; padding: 12px 4px; text-align: center; }

/* footer */
.foot { max-width: 1320px; margin: 0 auto; padding: 8px clamp(14px,3vw,34px) 30px; color: var(--faint);
  font-size: 11px; line-height: 1.6; }
.foot b { color: var(--muted); }
.foot .pill { display: inline-block; padding: 1px 7px; border-radius: 999px; border: 1px solid rgba(255,255,255,.12);
  font-weight: 700; color: var(--muted); }

/* toast */
.toast { position: fixed; bottom: 22px; left: 50%; transform: translateX(-50%);
  background: var(--inset2); border: 2px solid var(--bd2); border-radius: 10px; padding: 11px 18px;
  font-size: 12.5px; font-weight: 700; box-shadow: var(--float); z-index: 100; color: var(--text); }
.toast.err { box-shadow: var(--float), 0 0 0 1px rgba(210,74,74,.5); color: var(--red); }

/* scrollbars */
*::-webkit-scrollbar { width: 9px; height: 9px; }
*::-webkit-scrollbar-track { background: var(--inset); border-radius: 8px; }
*::-webkit-scrollbar-thumb { background: linear-gradient(180deg, #7a8494, #454a54); border-radius: 8px; border: 1px solid var(--bd2); }
*::-webkit-scrollbar-thumb:hover { background: linear-gradient(180deg, #8c96a6, #525860); }

.spin { animation: spin 1s linear infinite; display: inline-block; }
@keyframes spin { to { transform: rotate(360deg); } }
.skeleton { color: var(--faint); font-size: 13px; padding: 30px; text-align: center; }
