/* ────────────────────────────────────────────────
   ByteForge Quant — shared theme
   Used by: index.html (portal), forex/index.html
   Page-specific styles stay inline in each page.
   ──────────────────────────────────────────────── */

*,*::before,*::after { margin:0; padding:0; box-sizing:border-box; }

:root {
  --obsidian:       #040404;
  --surface:        #0d0d0d;
  --elevated:       #161616;
  --border:         rgba(255,255,255,.06);
  --border-hover:   rgba(255,255,255,.1);
  --phosphor:       #22dd7a;
  --phosphor-dim:   rgba(34,221,122,.12);
  --phosphor-glow:  rgba(34,221,122,.25);
  --red:            #ff3b3b;
  --red-dim:        rgba(255,59,59,.12);
  --amber:          #e8b84b;
  --amber-dim:      rgba(232,184,75,.12);
  --text-primary:   #e0ede5;
  --text-secondary: #5a8a6a;
  --text-muted:     #2a5a3a;
  --smoke:          #7a9a85;
  --grain: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.04'/%3E%3C/svg%3E");
}

html, body { height:100%; margin:0; }
body {
  font-family: 'DM Sans', sans-serif;
  background: var(--obsidian);
  color: var(--text-primary);
  min-height: 100vh;
  display: flex;
  flex-direction: column;
}
body::after {
  content:''; position:fixed; inset:0;
  background: var(--grain);
  pointer-events:none; z-index:9999; opacity:.5;
}

/* ── Background atmosphere ── */
.bg {
  position: fixed; inset: 0;
  background:
    radial-gradient(ellipse 50% 40% at 70% 20%, rgba(34,221,122,.04) 0%, transparent 70%),
    radial-gradient(ellipse 40% 50% at 15% 85%, rgba(10,30,15,.9)    0%, transparent 60%);
  z-index: 0;
}
.bg-grid {
  position: fixed; inset: 0;
  background-image:
    linear-gradient(rgba(255,255,255,.01) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.01) 1px, transparent 1px);
  background-size: 80px 80px;
  mask-image: radial-gradient(ellipse 70% 70% at 50% 50%, black, transparent);
  z-index: 0;
}

/* ── Utility ── */
.mono { font-family: 'JetBrains Mono', monospace; }

@keyframes pulse {
  0%,100% { opacity:1; transform:scale(1); }
  50%      { opacity:.4; transform:scale(.8); }
}
@keyframes fadeIn {
  from { opacity:0; transform:translateY(16px); }
  to   { opacity:1; transform:translateY(0); }
}

/* ── Header (outer) ── */
header {
  position: relative; z-index: 2;
  border-bottom: 1px solid var(--border);
  padding: 1.5rem 3rem;
  display: flex;
  justify-content: space-between;
  align-items: center;
  background: rgba(4,4,4,.8);
  backdrop-filter: blur(8px);
}

/* ── Logo ── */
.logo {
  font-family: 'Bebas Neue', sans-serif;
  font-size: 1.2rem;
  letter-spacing: 3px;
  color: var(--text-primary);
  display: flex;
  align-items: center;
  gap: .6rem;
  text-decoration: none;
}
.logo .dot {
  width: 8px; height: 8px;
  border-radius: 50%;
  background: var(--phosphor);
  box-shadow: 0 0 12px var(--phosphor);
  animation: pulse 2s ease-in-out infinite;
}
.logo .slash {
  color: var(--text-muted);
  font-size: 1rem;
  margin: 0 .1rem;
}
.logo .sub {
  color: var(--phosphor);
  letter-spacing: 2px;
}

/* ── Status badge (cards + detail page headers) ── */
.status-badge {
  display: flex;
  align-items: center;
  gap: .35rem;
  padding: .25rem .7rem;
  font-family: 'JetBrains Mono', monospace;
  font-size: .58rem;
  font-weight: 500;
  letter-spacing: 1.5px;
  text-transform: uppercase;
}
.status-badge .dot { width:5px; height:5px; border-radius:50%; background:currentColor; }
.status-badge.running       { background: var(--phosphor-dim); color: var(--phosphor); }
.status-badge.running .dot  { animation: pulse 2s infinite; box-shadow: 0 0 6px var(--phosphor); }
.status-badge.stopped       { background: var(--red-dim);      color: var(--red); }
.status-badge.idle          { background: var(--amber-dim);    color: var(--amber); }
.status-badge.loading       { background: rgba(255,255,255,.04); color: var(--smoke); }
.status-badge.offline       { background: rgba(255,255,255,.04); color: var(--smoke); }

/* ── Footer (outer) ── */
footer {
  position: relative; z-index: 2;
  border-top: 1px solid var(--border);
  padding: 1.5rem 3rem;
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  gap: 1rem;
}
footer p {
  font-family: 'JetBrains Mono', monospace;
  font-size: .6rem;
  color: rgba(90,138,106,.75);
  letter-spacing: 1.5px;
  text-transform: uppercase;
}
footer a {
  color: var(--smoke);
  text-decoration: none;
  transition: color .2s;
}
footer a:hover { color: var(--phosphor); }

/* ── Shared mobile padding adjustments ── */
@media (max-width: 768px) {
  header { padding: 1.25rem 1.5rem; }
  footer { padding: 1.5rem; justify-content: center; text-align: center; }
}
