﻿/* ── NAV ── */
nav{
  display:flex;align-items:center;justify-content:space-between;
  padding:.75rem 2rem;
  background:rgba(10,15,31,.97);border-bottom:1px solid var(--border);
  backdrop-filter:blur(14px);position:sticky;top:0;z-index:100;
}
.logo{display:flex;align-items:center;gap:.35rem;}
.logo img{height:32px;width:auto;}
.logo-entra{font-weight:800;font-size:1.15rem;color:var(--text);}
.logo-fx{font-weight:900;font-size:1.15rem;
  background:linear-gradient(135deg,var(--accent),var(--accent2));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;}
.nav-links{display:flex;gap:1.5rem;font-size:.88rem;}
.nav-links a{color:var(--muted);transition:color .15s;}
.nav-links a:hover{color:var(--text);}
.nav-links a.active{color:var(--accent);}
.nav-right{display:flex;align-items:center;gap:.85rem;}
#acctBadge{
  font-size:.8rem;padding:.3rem .85rem;border-radius:999px;
  background:var(--accentS);border:1px solid var(--accentB);color:var(--accent);
  font-weight:700;display:none;
}
.live-dot{display:inline-block;width:7px;height:7px;border-radius:50%;
  background:var(--up);animation:pulse 1.8s ease-in-out infinite;vertical-align:middle;margin-right:4px;}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1);}50%{opacity:.4;transform:scale(.7);}}

/* ── HERO ── */
.hero{
  padding:2.5rem 2rem 1.5rem;
  background:linear-gradient(135deg,var(--a06) 0%,transparent 60%);
  border-bottom:1px solid var(--border);
  display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1rem;
}
.hero-left h1{font-size:clamp(1.6rem,3vw,2.2rem);font-weight:900;letter-spacing:-.02em;margin-bottom:.3rem;}
.hero-left h1 span{background:linear-gradient(135deg,var(--accent),var(--accentL));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;}
.hero-left p{color:var(--muted);font-size:.95rem;}
.hero-right{display:flex;gap:.75rem;flex-wrap:wrap;}

/* ── EA CONNECT BAR ── */
.ea-bar{
  background:var(--bg2);border-bottom:1px solid var(--border);
  padding:.6rem 2rem;display:flex;align-items:center;gap:.75rem;flex-wrap:wrap;
  font-size:.82rem;
}
.ea-bar label{color:var(--muted);font-weight:600;font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;}
#eaHost{
  padding:.3rem .65rem;border-radius:6px;border:1px solid var(--border);
  background:var(--bg3);color:var(--text);font-size:.82rem;width:200px;outline:none;
}
#eaHost:focus{border-color:var(--accent);}
.ea-status{display:flex;align-items:center;gap:.4rem;font-size:.78rem;color:var(--muted);}
.ea-status.connected{color:var(--up);}
.ea-status.error{color:var(--dn);}
.badge-btn{
  padding:.3rem .8rem;border-radius:999px;border:1px solid var(--border);
  background:transparent;color:var(--text);font-size:.8rem;cursor:pointer;
  transition:all .15s;font-weight:600;
}
.badge-btn:hover{border-color:var(--accent);color:var(--accent);}
.badge-btn.primary{background:var(--accent);border-color:var(--accent);color:#fff;}
.badge-btn.primary:hover{background:#9333ea;}

/* ── WRAPPER ── */
.wrap{max-width:1300px;margin:0 auto;padding:1.8rem 2rem 3rem;}

/* ── KPI CARDS ── */
.kpi-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(210px,1fr));gap:1rem;margin-bottom:1.8rem;}
.kpi-card{
  background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);
  padding:1.2rem 1.4rem;transition:border-color .2s;position:relative;overflow:hidden;
}
.kpi-card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:2px;
  background:linear-gradient(90deg,var(--accent),var(--accent2));
}
.kpi-card:hover{border-color:var(--accentB);}
.kpi-label{font-size:.72rem;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);margin-bottom:.5rem;font-weight:700;}
.kpi-value{font-size:1.9rem;font-weight:900;letter-spacing:-.02em;color:var(--text);}
.kpi-sub{font-size:.75rem;color:var(--muted);margin-top:.35rem;}
.kpi-card.up .kpi-value{color:var(--up);}
.kpi-card.dn .kpi-value{color:var(--dn);}
.kpi-card.accent .kpi-value{color:var(--accent);}
.kpi-card.blue .kpi-value{color:var(--blue);}

/* ── WIN RATE CIRCLE ── */
.circle-wrap{display:flex;align-items:center;justify-content:center;gap:1rem;margin-top:.25rem;}
.ring-svg{width:80px;height:80px;}
.ring-bg{fill:none;stroke:var(--border);stroke-width:8;}
.ring-fg{fill:none;stroke:var(--accent);stroke-width:8;stroke-linecap:round;
  stroke-dasharray:220;stroke-dashoffset:220;transition:stroke-dashoffset 1.4s ease;}
.ring-text{font-size:.8rem;font-weight:800;fill:var(--text);}

/* ── CHARTS ROW ── */
.charts-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1.8rem;}
@media(max-width:900px){.charts-row{grid-template-columns:1fr;}}
.panel{
  background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);
  padding:1.3rem 1.4rem;
}
.panel-header{
  display:flex;align-items:center;justify-content:space-between;
  margin-bottom:1rem;padding-bottom:.75rem;border-bottom:1px solid var(--border);
}
.panel-title{font-size:.85rem;font-weight:700;text-transform:uppercase;
  letter-spacing:.08em;color:var(--text);display:flex;align-items:center;gap:.5rem;}
.panel-title svg{width:16px;height:16px;stroke:var(--accent);fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;}

/* ── PAIR TABLE ── */
.table-wrap{overflow-x:auto;}
table{width:100%;border-collapse:collapse;font-size:.88rem;}
thead th{font-size:.72rem;text-transform:uppercase;letter-spacing:.07em;color:var(--muted);
  padding:.5rem .6rem;text-align:left;border-bottom:1px solid var(--border);}
tbody tr{border-bottom:1px solid rgba(30,45,74,.5);transition:background .15s;}
tbody tr:hover{background:var(--a04);}
tbody td{padding:.55rem .6rem;color:var(--text);}
.td-pair{font-weight:700;font-family:"Courier New",monospace;color:var(--blue);}
.td-up{color:var(--up);font-weight:700;}
.td-dn{color:var(--dn);font-weight:700;}
.td-center{text-align:center;}
.wr-badge{display:inline-block;padding:.15rem .55rem;border-radius:999px;font-size:.72rem;font-weight:700;}
.wr-badge.good{background:rgba(34,197,94,.12);color:var(--up);}
.wr-badge.ok{background:var(--a12);color:var(--accent);}
.wr-badge.bad{background:rgba(239,68,68,.12);color:var(--dn);}

/* ── SIGNAL FEED ── */
.feed{max-height:320px;overflow-y:auto;display:flex;flex-direction:column;gap:.5rem;}
.feed::-webkit-scrollbar{width:4px;}
.feed::-webkit-scrollbar-thumb{background:var(--border);border-radius:999px;}
.feed-item{
  background:var(--bg3);border:1px solid var(--border);border-radius:8px;
  padding:.6rem .8rem;display:flex;align-items:flex-start;gap:.65rem;font-size:.8rem;
}
.feed-item.buy{border-left:3px solid var(--up);}
.feed-item.sell{border-left:3px solid var(--dn);}
.feed-badge{
  font-size:.65rem;font-weight:700;padding:.15rem .45rem;border-radius:4px;
  flex-shrink:0;margin-top:1px;
}
.feed-badge.buy{background:rgba(34,197,94,.15);color:var(--up);}
.feed-badge.sell{background:rgba(239,68,68,.15);color:var(--dn);}
.feed-badge.bos{background:rgba(58,180,255,.15);color:var(--blue);}
.feed-badge.choch{background:var(--accentS);color:var(--accent);}
.feed-sub{color:var(--muted);font-size:.72rem;margin-top:.2rem;}
.feed-time{margin-left:auto;color:var(--muted);font-size:.7rem;flex-shrink:0;padding-left:.5rem;}
.feed-sym{font-weight:700;font-family:"Courier New",monospace;color:var(--text);}
.feed-empty{color:var(--muted);font-size:.85rem;text-align:center;padding:2rem 0;}

/* ── FOOTER ── */
footer{
  text-align:center;padding:2.5rem 1rem;border-top:1px solid var(--border);
  margin-top:2rem;color:var(--muted);font-size:.8rem;
}
footer span{color:var(--accent);}

/* ── RESPONSIVE ── */
@media(max-width:768px){
  .wrap{padding:1rem;}
  .hero{padding:1.5rem 1rem;}
  nav{padding:.65rem 1rem;}
  .nav-links{display:none;}
  .ea-bar{padding:.6rem 1rem;}
  .kpi-value{font-size:1.5rem;}
}
@keyframes fadeUp{from{opacity:0;transform:translateY(14px);}to{opacity:1;transform:translateY(0);}}
.fade-up{animation:fadeUp .45s ease-out both;}