/* PolyCopy Dashboard — tokenised style sheet.
   Brand/semantic colours live exclusively in themes/*.css via CSS custom properties.
   Structural tokens (radius, gap, fonts) are defined in :root here as fallback-safe defaults. */

:root {
  /* Structural / non-colour tokens — safe defaults; themes only override colours. */
  --radius: 10px;
  --gap: 18px;
  --gap-sm: 10px;
}

*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{
  background:
    radial-gradient(1200px 800px at 8% -10%, rgba(61,199,255,.10), transparent 55%),
    radial-gradient(1000px 700px at 100% 0%, rgba(157,92,255,.10), transparent 55%),
    radial-gradient(900px 600px at 50% 100%, rgba(61,199,255,.04), transparent 60%),
    var(--bg);
  color:var(--text);
  font-family:'Exo 2', system-ui, sans-serif;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}

/* Faint graph-paper grid */
body::before{
  content:"";position:fixed;inset:0;pointer-events:none;
  background-image:
    linear-gradient(var(--bg-grid) 1px, transparent 1px),
    linear-gradient(90deg, var(--bg-grid) 1px, transparent 1px);
  background-size: 64px 64px;
  opacity:.45;
  mask-image: radial-gradient(ellipse at center, black 30%, transparent 80%);
  z-index:0;
}

/* Scanline / subtle texture */
body::after{
  content:"";position:fixed;inset:0;pointer-events:none;z-index:0;
  background:
    repeating-linear-gradient(0deg, rgba(255,255,255,.012) 0 1px, transparent 1px 3px);
  mix-blend-mode:overlay;
}

.mono{font-family:'JetBrains Mono', ui-monospace, monospace; font-variant-numeric: tabular-nums;}
.num{font-variant-numeric: tabular-nums;}

/* ------------- TOP BAR ------------- */
header.bar{
  position:relative; z-index:2;
  display:flex; align-items:center; justify-content:space-between;
  padding:16px 28px;
  border-bottom:1px solid var(--border);
  background: linear-gradient(180deg, var(--surface-2), var(--bg));
  backdrop-filter: blur(8px);
}
.brand{display:flex;align-items:center;gap:14px}
.brand-logo{
  width:42px; height:42px;
  border-radius:6px;
  filter: drop-shadow(0 0 12px var(--cyan-deep));
}
.brand-text{
  display:flex; flex-direction:column;
}
.brand-text .name{
  font-family:'Exo 2', sans-serif;
  font-weight:700; font-size:18px; letter-spacing:.5px;
  background:linear-gradient(90deg, var(--text) 0%, var(--text) 45%, var(--cyan) 55%, var(--cyan-2) 100%);
  -webkit-background-clip:text; background-clip:text; color:transparent;
}
.brand-text .sub{
  font-family:'JetBrains Mono', monospace;
  font-size:10.5px; color:var(--text-mute); letter-spacing:.18em; text-transform:uppercase;
  margin-top:2px;
}

.bar-meta{display:flex;align-items:center;gap:24px}
.meta-item{display:flex;flex-direction:column;align-items:flex-end;gap:2px}
.meta-item .label{font-size:10px; letter-spacing:.18em; text-transform:uppercase; color:var(--text-dim); font-family:'JetBrains Mono', monospace}
.meta-item .val{font-family:'JetBrains Mono', monospace; font-size:13px; font-weight:500; color:var(--text)}
.meta-item .val.live{display:flex;align-items:center;gap:8px}

.live-dot{
  width:7px;height:7px;border-radius:50%;background:var(--cyan);
  box-shadow:0 0 0 0 color-mix(in srgb, var(--cyan) 55%, transparent);
  animation: pulse 1.8s ease-out infinite;
}
@keyframes pulse{
  0%{box-shadow:0 0 0 0 color-mix(in srgb, var(--cyan) 55%, transparent)}
  70%{box-shadow:0 0 9px 0 color-mix(in srgb, var(--cyan) 0%, transparent)}
  100%{box-shadow:0 0 0 0 color-mix(in srgb, var(--cyan) 0%, transparent)}
}

/* Theme selector */
#theme-switch{
  font-family:'JetBrains Mono', monospace; font-size:11px;
  background:var(--surface-2); color:var(--text);
  border:1px solid var(--border); border-radius:4px;
  padding:5px 10px; cursor:pointer; letter-spacing:.06em;
}
#theme-switch:focus{outline:none; border-color:var(--cyan)}

.pill{
  display:inline-flex; align-items:center; gap:7px;
  padding:5px 10px; border-radius:4px;
  border:1px solid var(--border);
  background:var(--surface-2);
  font-family:'JetBrains Mono', monospace; font-size:11px; letter-spacing:.04em;
}
.pill.good{border-color:color-mix(in srgb, var(--green) 40%, transparent); color:var(--green); background:color-mix(in srgb, var(--green) 8%, transparent)}
.pill.warn{border-color:color-mix(in srgb, var(--yellow) 40%, transparent); color:var(--yellow); background:color-mix(in srgb, var(--yellow) 8%, transparent)}
.pill.bad {border-color:color-mix(in srgb, var(--red) 40%, transparent); color:var(--red); background:color-mix(in srgb, var(--red) 8%, transparent)}

/* ------------- HERO / MASCOT ------------- */
.hero{
  position:relative; z-index:1;
  max-width:1480px;
  margin:24px auto 0;
  padding:0 28px;
}
.hero-card{
  display:grid;
  grid-template-columns: 290px 1fr;
  gap:0;
  background:
    linear-gradient(135deg, color-mix(in srgb, var(--cyan) 8%, transparent) 0%, transparent 40%),
    linear-gradient(225deg, color-mix(in srgb, var(--violet) 10%, transparent) 0%, transparent 50%),
    linear-gradient(180deg, var(--surface), var(--surface-2));
  border:1px solid var(--border);
  border-radius:12px;
  overflow:hidden;
  position:relative;
}
.hero-card::before{
  content:"";position:absolute;left:0;right:0;top:0;height:1px;
  background:linear-gradient(90deg, transparent, var(--cyan) 30%, var(--violet) 70%, transparent);
  opacity:.7;
}
.hero-card::after{
  content:"";position:absolute; right:-200px; top:-150px; width:600px; height:600px;
  border-radius:50%;
  border:1px dashed color-mix(in srgb, var(--cyan) 8%, transparent);
  box-shadow: 0 0 0 60px transparent, 0 0 0 120px color-mix(in srgb, var(--violet) 2%, transparent);
  pointer-events:none;
}

.mascot-stage{
  position:relative;
  background:
    radial-gradient(circle at 50% 65%, color-mix(in srgb, var(--cyan) 20%, transparent) 0%, transparent 55%),
    radial-gradient(circle at 30% 30%, color-mix(in srgb, var(--violet) 18%, transparent) 0%, transparent 50%),
    linear-gradient(180deg, var(--surface-3), var(--bg));
  display:flex; align-items:flex-end; justify-content:center;
  overflow:hidden;
  border-right:1px solid var(--border);
  min-height:240px;
}
.mascot-stage::before{
  content:""; position:absolute; left:50%; top:55%;
  transform:translate(-50%,-50%);
  width:240px; height:240px; border-radius:50%;
  border:1px solid color-mix(in srgb, var(--cyan) 15%, transparent);
  box-shadow:
    0 0 0 18px color-mix(in srgb, var(--cyan) 3%, transparent),
    0 0 0 40px color-mix(in srgb, var(--violet) 4%, transparent),
    inset 0 0 60px color-mix(in srgb, var(--cyan) 6%, transparent);
}
.mascot-stage::after{
  content:""; position:absolute; left:50%; bottom:-30px;
  transform:translateX(-50%);
  width:200px; height:40px; border-radius:50%;
  background:radial-gradient(ellipse at center, color-mix(in srgb, var(--cyan) 40%, transparent), transparent 70%);
  filter:blur(8px);
}
.mascot-img{
  position:relative; z-index:2;
  height:260px; width:auto;
  filter: drop-shadow(0 12px 24px color-mix(in srgb, var(--cyan) 35%, transparent)) drop-shadow(0 0 40px color-mix(in srgb, var(--violet) 15%, transparent));
  animation: floaty 4.5s ease-in-out infinite;
}
@keyframes floaty{
  0%,100%{transform:translateY(0)}
  50%{transform:translateY(-6px)}
}

.hero-content{
  padding:26px 30px;
  display:flex; flex-direction:column; gap:18px;
  position:relative;
}
.speech{
  align-self:flex-start;
  background:linear-gradient(135deg, color-mix(in srgb, var(--cyan) 12%, transparent), color-mix(in srgb, var(--violet) 10%, transparent));
  border:1px solid color-mix(in srgb, var(--cyan) 30%, transparent);
  border-radius:10px;
  padding:10px 14px;
  font-family:'JetBrains Mono', monospace; font-size:12px;
  color:var(--text);
  max-width:560px;
  position:relative;
  line-height:1.5;
}
.speech::before{
  content:""; position:absolute; left:-7px; top:14px;
  width:12px; height:12px;
  background:linear-gradient(135deg, color-mix(in srgb, var(--cyan) 12%, transparent), color-mix(in srgb, var(--violet) 10%, transparent));
  border-left:1px solid color-mix(in srgb, var(--cyan) 30%, transparent);
  border-bottom:1px solid color-mix(in srgb, var(--cyan) 30%, transparent);
  transform: rotate(45deg);
}
.speech b{color:var(--cyan); font-weight:600}
.speech .v{color:var(--green); font-weight:600}
.speech .m{color:var(--violet-2); font-weight:600}

.hero-stats{
  display:grid; grid-template-columns: repeat(4, 1fr);
  gap:16px;
}
.hs{
  padding:12px 14px;
  background:color-mix(in srgb, var(--text) 2%, transparent);
  border:1px solid var(--border-soft);
  border-radius:8px;
  position:relative; overflow:hidden;
}
.hs .l{font-family:'JetBrains Mono', monospace; font-size:10px; letter-spacing:.14em; text-transform:uppercase; color:var(--text-dim); margin-bottom:6px}
.hs .v{font-family:'JetBrains Mono', monospace; font-size:22px; font-weight:500; color:var(--text); line-height:1}
.hs .v.green{color:var(--green)} .hs .v.cyan{color:var(--cyan)} .hs .v.violet{color:var(--violet-2)} .hs .v.amber{color:var(--yellow)}
.hs .d{font-family:'JetBrains Mono', monospace; font-size:10.5px; color:var(--text-mute); margin-top:6px}

/* ------------- LAYOUT ------------- */
main{
  position:relative; z-index:1;
  max-width:1480px;
  margin:0 auto;
  padding:18px 28px 60px;
  display:flex; flex-direction:column; gap:18px;
}

.row{display:grid;gap:18px}
.row.kpis{grid-template-columns: repeat(5, minmax(0,1fr))}
.row.two-thirds-third{grid-template-columns: 2fr 1fr}
.row.half-half{grid-template-columns: 1fr 1fr}

@media (max-width: 1180px){
  .row.kpis{grid-template-columns: repeat(2, minmax(0,1fr))}
  .row.two-thirds-third, .row.half-half{grid-template-columns: 1fr}
  .hero-card{grid-template-columns:1fr}
  .mascot-stage{border-right:none; border-bottom:1px solid var(--border)}
  .hero-stats{grid-template-columns: repeat(2,1fr)}
}

/* ------------- PANEL BASE ------------- */
.panel{
  background:linear-gradient(180deg, var(--surface), var(--surface-2));
  border:1px solid var(--border);
  border-radius:10px;
  overflow:hidden;
  position:relative;
}
.panel::before{
  content:"";position:absolute;left:0;right:0;top:0;height:1px;
  background:linear-gradient(90deg, transparent, var(--cyan), var(--violet), transparent);
  opacity:.45;
}
.panel-head{
  display:flex; align-items:center; justify-content:space-between;
  padding:14px 18px 12px;
  border-bottom:1px solid var(--border-soft);
}
.panel-head h2{
  font-family:'Exo 2', sans-serif;
  font-weight:600; font-size:13px; letter-spacing:.1em; text-transform:uppercase;
  color:var(--text);
  display:flex; align-items:center; gap:8px;
}
.panel-head h2::before{
  content:""; width:6px; height:6px; border-radius:50%;
  background:var(--cyan);
  box-shadow:0 0 8px var(--cyan);
}
.panel-head .tag{
  font-family:'JetBrains Mono', monospace; font-size:10px;
  color:var(--text-dim); letter-spacing:.12em; text-transform:uppercase;
}
.panel-body{padding:16px 18px}

/* ------------- KPI CARD ------------- */
.kpi{
  background:linear-gradient(180deg, var(--surface), var(--surface-2));
  border:1px solid var(--border);
  border-radius:10px;
  padding:18px 20px;
  position:relative; overflow:hidden;
}
.kpi::before{
  content:""; position:absolute; left:0; top:0; bottom:0; width:2px;
  background:linear-gradient(180deg, var(--cyan), var(--violet));
  opacity:.6;
}
.kpi .kpi-label{
  font-family:'JetBrains Mono', monospace;
  font-size:10px; letter-spacing:.16em; text-transform:uppercase;
  color:var(--text-dim);
  margin-bottom:14px;
  display:flex; align-items:center; justify-content:space-between;
}
.kpi .kpi-value{
  font-family:'JetBrains Mono', monospace;
  font-weight:500; font-size:30px; letter-spacing:-.01em;
  line-height:1; color:var(--text);
}
.kpi .kpi-value.green{color:var(--green)}
.kpi .kpi-value.red{color:var(--red)}
.kpi .kpi-value.cyan{color:var(--cyan)}
.kpi .kpi-value.violet{color:var(--violet-2)}
.kpi .kpi-foot{
  margin-top:12px;
  display:flex; align-items:center; justify-content:space-between;
  font-size:11px; color:var(--text-mute);
  font-family:'JetBrains Mono', monospace;
}
.kpi .delta.up{color:var(--green)} .kpi .delta.down{color:var(--red)}

.kpi .spark{position:absolute; right:14px; bottom:14px; opacity:.85}

/* ------------- TABLES ------------- */
table.t{
  width:100%; border-collapse:collapse;
  font-family:'JetBrains Mono', monospace;
  font-size:12px;
  font-variant-numeric: tabular-nums;
}
table.t th{
  text-align:left; font-weight:500; color:var(--text-dim);
  font-size:10px; letter-spacing:.14em; text-transform:uppercase;
  padding:10px 12px;
  border-bottom:1px solid var(--border);
  background:color-mix(in srgb, var(--text) 1.5%, transparent);
}
table.t th.right, table.t td.right{text-align:right}
table.t td{
  padding:11px 12px;
  border-bottom:1px solid var(--border-soft);
  color:var(--text);
}
table.t tr:last-child td{border-bottom:none}
table.t tr:hover td{background:color-mix(in srgb, var(--cyan) 4%, transparent)}

.wallet-cell{display:flex; align-items:center; gap:10px}
.wallet-cell .swatch{
  width:8px; height:8px; border-radius:2px;
  box-shadow:0 0 8px currentColor;
}
.wallet-cell .addr{color:var(--text-dim); font-size:10.5px}

.pos{color:var(--green)} .neg{color:var(--red)} .neu{color:var(--text-mute)}

.chip{
  display:inline-flex; align-items:center; gap:5px;
  padding:2px 8px; border-radius:3px;
  font-family:'JetBrains Mono', monospace; font-size:10px;
  letter-spacing:.04em; text-transform:uppercase;
  border:1px solid transparent;
}
.chip.win{background:color-mix(in srgb, var(--green) 10%, transparent); color:var(--green); border-color:color-mix(in srgb, var(--green) 25%, transparent)}
.chip.lose{background:color-mix(in srgb, var(--red) 10%, transparent); color:var(--red); border-color:color-mix(in srgb, var(--red) 25%, transparent)}
.chip.pending{background:color-mix(in srgb, var(--yellow) 10%, transparent); color:var(--yellow); border-color:color-mix(in srgb, var(--yellow) 25%, transparent)}
.chip.matched{background:color-mix(in srgb, var(--cyan) 10%, transparent); color:var(--cyan); border-color:color-mix(in srgb, var(--cyan) 28%, transparent)}
.chip.unmatched{background:color-mix(in srgb, var(--red) 8%, transparent); color:var(--red); border-color:color-mix(in srgb, var(--red) 22%, transparent)}
.chip.yes{background:color-mix(in srgb, var(--green) 8%, transparent); color:var(--green); border-color:color-mix(in srgb, var(--green) 22%, transparent)}
.chip.no{background:color-mix(in srgb, var(--red) 8%, transparent); color:var(--red); border-color:color-mix(in srgb, var(--red) 22%, transparent)}

/* ------------- KILL-SWITCH PANEL ------------- */
.ks-row{
  display:flex; flex-direction:column; gap:6px;
  padding:14px 0;
  border-bottom:1px solid var(--border-soft);
}
.ks-row:last-child{border-bottom:none}
.ks-row:first-child{padding-top:0}
.ks-row .ks-head{
  display:flex; align-items:center; justify-content:space-between;
  font-family:'JetBrains Mono', monospace; font-size:11px;
}
.ks-row .ks-label{color:var(--text); letter-spacing:.04em}
.ks-row .ks-vals{color:var(--text-mute); font-size:11px}
.ks-row .ks-vals b{color:var(--text); font-weight:500}
.bar{
  height:7px; border-radius:4px; background:var(--border-soft); overflow:hidden; position:relative;
}
.bar > i{display:block; height:100%; border-radius:4px;}
.bar.low > i{background:linear-gradient(90deg, var(--cyan-deep), var(--cyan))}
.bar.mid > i{background:linear-gradient(90deg, var(--cyan), var(--violet-2))}
.bar.high > i{background:linear-gradient(90deg, var(--violet), var(--red))}

.breaker{
  display:flex; align-items:center; justify-content:space-between;
  margin-top:16px; padding:13px 14px;
  border:1px solid color-mix(in srgb, var(--green) 25%, transparent);
  border-radius:8px;
  background:linear-gradient(90deg, color-mix(in srgb, var(--green) 6%, transparent), color-mix(in srgb, var(--green) 2%, transparent));
}
.breaker .label{font-family:'JetBrains Mono', monospace; font-size:11px; color:var(--text-mute); letter-spacing:.08em; text-transform:uppercase}
.breaker .value{font-family:'JetBrains Mono', monospace; font-size:14px; color:var(--green); display:flex; gap:8px; align-items:center}
.breaker .live-dot{background:var(--green); animation:pulse-g 1.8s ease-out infinite}
@keyframes pulse-g{
  0%{box-shadow:0 0 0 0 color-mix(in srgb, var(--green) 55%, transparent)}
  70%{box-shadow:0 0 9px 0 color-mix(in srgb, var(--green) 0%, transparent)}
  100%{box-shadow:0 0 0 0 color-mix(in srgb, var(--green) 0%, transparent)}
}

/* ------------- AGENTS ------------- */
.agent-grid{
  display:grid; grid-template-columns:repeat(2, minmax(0,1fr));
  gap:10px;
}
.agent{
  display:flex; align-items:center; justify-content:space-between;
  padding:10px 12px;
  background:color-mix(in srgb, var(--text) 2%, transparent);
  border:1px solid var(--border-soft);
  border-radius:6px;
  transition: border-color .2s;
}
.agent:hover{border-color:color-mix(in srgb, var(--cyan) 40%, transparent)}
.agent .a-left{display:flex; align-items:center; gap:10px}
.agent .a-name{font-family:'JetBrains Mono', monospace; font-size:12px; color:var(--text)}
.agent .a-port{font-family:'JetBrains Mono', monospace; font-size:10px; color:var(--text-dim); margin-left:6px}
.agent .a-lat{font-family:'JetBrains Mono', monospace; font-size:10.5px; color:var(--text-mute)}
.status-dot{
  width:8px; height:8px; border-radius:50%;
  background:var(--green);
  box-shadow:0 0 10px var(--green);
  animation: blink 2.4s ease-in-out infinite;
}
.status-dot.warn{background:var(--yellow); box-shadow:0 0 10px var(--yellow)}
.status-dot.bad{background:var(--red); box-shadow:0 0 10px var(--red)}
@keyframes blink{ 0%,100%{opacity:1} 50%{opacity:.45} }

/* ------------- RECENT FEED ------------- */
.feed{display:flex; flex-direction:column;}
.feed-item{
  display:grid; grid-template-columns: 74px 1fr 1fr auto auto;
  gap:14px; align-items:center;
  padding:11px 0;
  border-bottom:1px solid var(--border-soft);
  font-family:'JetBrains Mono', monospace; font-size:12px;
}
.feed-item:last-child{border-bottom:none}
.feed-item .ts{color:var(--text-dim); font-size:11px}
.feed-item .mkt{color:var(--text); overflow:hidden; text-overflow:ellipsis; white-space:nowrap}
.feed-item .from{color:var(--text-mute); font-size:11px}

/* ------------- FUNNEL ------------- */
.funnel-summary{
  display:grid; grid-template-columns: repeat(3, 1fr);
  gap:12px;
  margin-bottom:16px;
}
.funnel-summary .b{
  padding:14px;
  border:1px solid var(--border-soft);
  border-radius:8px;
  background:color-mix(in srgb, var(--text) 2%, transparent);
}
.funnel-summary .b .l{font-family:'JetBrains Mono', monospace; font-size:10px; letter-spacing:.14em; text-transform:uppercase; color:var(--text-dim); margin-bottom:6px}
.funnel-summary .b .v{font-family:'JetBrains Mono', monospace; font-size:22px; color:var(--text); font-weight:500}
.funnel-summary .b .v.g{color:var(--green)} .funnel-summary .b .v.r{color:var(--red)} .funnel-summary .b .v.y{color:var(--cyan)}

.reason{
  display:grid; grid-template-columns: 1fr 60px 80px;
  align-items:center;
  padding:9px 0;
  border-bottom:1px solid var(--border-soft);
  font-family:'JetBrains Mono', monospace; font-size:11.5px;
}
.reason:last-child{border-bottom:none}
.reason .r-name{color:var(--text)}
.reason .r-count{color:var(--text-mute); text-align:right}
.reason .r-bar{height:5px; background:var(--border-soft); border-radius:3px; margin-left:12px; overflow:hidden}
.reason .r-bar > i{display:block; height:100%; background:linear-gradient(90deg, var(--violet-deep), var(--cyan))}

/* ------------- FOOTER ------------- */
footer{
  position:relative; z-index:1;
  border-top:1px solid var(--border);
  padding:18px 28px;
  font-family:'JetBrains Mono', monospace;
  font-size:10.5px;
  color:var(--text-dim);
  display:flex; justify-content:space-between; align-items:center;
  gap:20px; flex-wrap:wrap;
  letter-spacing:.06em;
  background:linear-gradient(180deg, transparent, var(--bg));
}
footer a{color:var(--cyan); text-decoration:none}
footer .ftr-warn{color:var(--text-mute)}
footer .ftr-mascot{
  display:flex; align-items:center; gap:8px;
  color:var(--text-mute);
}
footer .ftr-mascot img{
  width:22px; height:22px; border-radius:50%;
  object-fit:cover; object-position:center top;
  border:1px solid var(--border);
}

/* small util */
.hr-dotted{height:0; border-bottom:1px dashed var(--border); margin:8px 0 16px}
.legend{display:flex; gap:14px; font-family:'JetBrains Mono', monospace; font-size:10px; color:var(--text-dim); letter-spacing:.06em; text-transform:uppercase; flex-wrap:wrap}
.legend span{display:inline-flex; align-items:center; gap:6px}
.legend i{width:8px; height:8px; border-radius:2px; display:inline-block; box-shadow:0 0 6px currentColor}

.mkt-title{color:var(--text)}
.small{font-size:10.5px}
.dim{color:var(--text-dim)}
.mute{color:var(--text-mute)}

/* ------------- LOGIN PAGE ------------- */
form.login{
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  gap:14px;
  min-height:100vh;
  font-family:'JetBrains Mono', ui-monospace, monospace;
}
form.login input{
  background:var(--surface-2,#111); color:var(--text,#e8e8f0);
  border:1px solid var(--border,#2a2a3a); border-radius:6px;
  padding:11px 16px; font-size:14px; width:260px; outline:none;
  font-family:inherit;
}
form.login input:focus{border-color:var(--cyan,#3dc7ff)}
form.login button{
  background:linear-gradient(135deg, var(--cyan-deep,#0e7abf), var(--cyan,#3dc7ff));
  color:#000; font-weight:600; border:none; border-radius:6px;
  padding:10px 32px; font-size:13px; cursor:pointer; letter-spacing:.06em;
  font-family:inherit;
}
form.login button:hover{opacity:.88}
form.login #err{color:var(--red,#ff4f6a); font-size:12px; min-height:1em}
