/* ============================================
   MAD MUDA — Jarvis Command Center
   Full responsive PWA with Jarvis-style animations
   ============================================ */

@import url('https://fonts.googleapis.com/css2?family=Cinzel:wght@400;700;900&family=Rajdhani:wght@300;400;600;700&family=JetBrains+Mono:wght@300;400;600&display=swap');

:root {
  --void:        #04040d;
  --void-2:      #080818;
  --void-3:      #0d0d22;
  --gold:        #f0c040;
  --gold-dim:    #a07820;
  --gold-glow:   rgba(240,192,64,0.25);
  --emerald:     #2db872;
  --emerald-dim: #1a7a4a;
  --emerald-glow:rgba(45,184,114,0.2);
  --blue:        #4080ff;
  --blue-light:  #80b0ff;
  --red:         #ff4060;
  --text-1:      #f0f0ff;
  --text-2:      #9090c0;
  --text-3:      #505080;
  --border:      rgba(240,192,64,0.12);
  --glass:       rgba(13,13,34,0.25);
  --glass-border:rgba(240,192,64,0.3);
  --font-display:'Cinzel', serif;
  --font-ui:     'Rajdhani', sans-serif;
  --font-mono:   'JetBrains Mono', monospace;
  --safe-top:    env(safe-area-inset-top);
  --safe-bottom: env(safe-area-inset-bottom);
}

*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; -webkit-tap-highlight-color:transparent; }

html, body { height:100%; width:100%; overflow:hidden; background:var(--void); color:var(--text-1); font-family:var(--font-ui); font-size:14px; -webkit-font-smoothing:antialiased; }

#app { height:100%; display:flex; flex-direction:column; position:relative; overflow:hidden; }

/* === KEYFRAMES === */
@keyframes jarvisZoomIn { 0%{transform:scale(1.15);opacity:0;filter:blur(8px)} 100%{transform:scale(1);opacity:1;filter:blur(0)} }
@keyframes panelReveal { 0%{transform:translateY(40px);opacity:0} 100%{transform:translateY(0);opacity:1} }
@keyframes scanLine { 0%{top:-2px} 100%{top:100%} }
@keyframes dataStream { 0%{opacity:0;transform:translateY(10px) scale(0.95)} 60%{opacity:1;transform:translateY(-2px) scale(1.02)} 100%{opacity:1;transform:translateY(0) scale(1)} }
@keyframes orbPulse { 0%,100%{box-shadow:0 0 30px var(--emerald-glow),0 0 60px rgba(45,184,114,0.1);transform:scale(1)} 50%{box-shadow:0 0 50px var(--emerald-glow),0 0 100px rgba(45,184,114,0.15);transform:scale(1.03)} }
@keyframes geoRotate { from{transform:rotate(0deg)} to{transform:rotate(360deg)} }
@keyframes barGrow { 0%{width:0%} }
@keyframes fadeIn { 0%{opacity:0} 100%{opacity:1} }
@keyframes glowPulse { 0%,100%{opacity:0.4} 50%{opacity:0.8} }
@keyframes shimmer { 0%{background-position:-200% 0} 100%{background-position:200% 0} }
@keyframes hudRingSpin { from{transform:translate(-50%,-50%) rotate(0deg)} to{transform:translate(-50%,-50%) rotate(360deg)} }
@keyframes blink { 0%,100%{opacity:1} 50%{opacity:0} }
@keyframes panelReveal3D { 0%{transform:translateY(60px) rotateX(15deg) scale(0.9);opacity:0} 60%{transform:translateY(-5px) rotateX(-2deg) scale(1.02);opacity:1} 100%{transform:translateY(0) rotateX(2deg) scale(1);opacity:1} }
@keyframes holoPulse { 0%,100%{opacity:0.03} 50%{opacity:0.06} }
@keyframes ringRotate { from{transform:rotate(0deg)} to{transform:rotate(360deg)} }
@keyframes dataFlicker { 0%,100%{opacity:1} 92%{opacity:1} 93%{opacity:0.4} 94%{opacity:1} 97%{opacity:0.6} 98%{opacity:1} }

/* === SPLASH === */
.splash-screen { position:fixed; inset:0; z-index:1000; background:var(--void); display:flex; flex-direction:column; align-items:center; justify-content:center; }
.splash-bg { position:absolute; inset:0; background:url('assets/splash.png') center/cover no-repeat; opacity:0; animation:jarvisZoomIn 1.5s ease-out 0.3s forwards; }
.splash-overlay { position:absolute; inset:0; background:radial-gradient(circle at 50% 40%,transparent 30%,rgba(4,4,13,0.7) 70%); }
.splash-title { position:relative; z-index:2; font-family:var(--font-display); font-size:42px; font-weight:900; color:var(--gold); letter-spacing:8px; text-shadow:0 0 40px var(--gold-glow); opacity:0; animation:dataStream 0.8s ease-out 1s forwards; }
.splash-sub { position:relative; z-index:2; font-family:var(--font-mono); font-size:12px; color:var(--emerald); letter-spacing:4px; margin-top:12px; opacity:0; animation:dataStream 0.8s ease-out 1.3s forwards; }
.splash-loader { position:relative; z-index:2; width:120px; height:2px; background:rgba(240,192,64,0.15); border-radius:2px; margin-top:30px; overflow:hidden; opacity:0; animation:fadeIn 0.5s ease-out 1.5s forwards; }
.splash-loader-bar { height:100%; background:linear-gradient(90deg,var(--gold),var(--emerald)); border-radius:2px; width:0%; transition:width 0.3s ease; }

/* === VIEW BACKGROUNDS === */
.view-bg { position:absolute; inset:0; background-size:cover; background-position:center; opacity:0; animation:jarvisZoomIn 1s ease-out forwards; z-index:0; }
.view-bg::after { content:''; position:absolute; inset:0; background:linear-gradient(180deg,rgba(4,4,13,0.3) 0%,rgba(4,4,13,0.6) 50%,rgba(4,4,13,0.9) 100%); }
.view-bg.city { background-image:url('assets/city-bg.png'); }
.view-bg.money { background-image:url('assets/money-bg.png'); }
.view-bg.agent { background-image:url('assets/agent-bg.png'); }

/* HUD scan line */
.hud-scanline { position:absolute; left:0; right:0; height:3px; background:linear-gradient(90deg,transparent 10%,var(--emerald) 40%,var(--gold) 60%,transparent 90%); opacity:0.5; z-index:1; animation:scanLine 3s linear infinite; pointer-events:none; box-shadow:0 0 20px var(--emerald-glow),0 0 40px rgba(45,184,114,0.1); }
.hud-scanline-2 { position:absolute; left:0; right:0; height:1px; background:linear-gradient(90deg,transparent,var(--gold),transparent); opacity:0.2; z-index:1; animation:scanLine 7s linear infinite; animation-delay:2s; pointer-events:none; }

/* HUD corners — bigger, glowing */
.hud-corner { position:absolute; width:40px; height:40px; border-color:var(--gold); border-style:solid; opacity:0.35; z-index:2; pointer-events:none; }
.hud-corner.tl { top:60px; left:12px; border-width:2px 0 0 2px; }
.hud-corner.tr { top:60px; right:12px; border-width:2px 2px 0 0; }
.hud-corner.bl { bottom:120px; left:12px; border-width:0 0 2px 2px; }
.hud-corner.br { bottom:120px; right:12px; border-width:0 2px 2px 0; }

/* Holographic grid overlay */
.holo-grid { position:absolute; inset:0; z-index:1; pointer-events:none; background-image:linear-gradient(rgba(240,192,64,0.03) 1px,transparent 1px),linear-gradient(90deg,rgba(240,192,64,0.03) 1px,transparent 1px); background-size:60px 60px; animation:holoPulse 4s ease-in-out infinite; }

/* Rotating HUD rings */
.hud-ring { position:absolute; border:1px solid rgba(240,192,64,0.08); border-radius:50%; pointer-events:none; z-index:1; }
.hud-ring-1 { width:500px; height:500px; top:50%; left:50%; transform:translate(-50%,-50%); animation:ringRotate 30s linear infinite; border-style:dashed; }
.hud-ring-2 { width:700px; height:700px; top:50%; left:50%; transform:translate(-50%,-50%); animation:ringRotate 45s linear infinite reverse; border-color:rgba(45,184,114,0.06); }
.hud-ring-3 { width:300px; height:300px; top:20%; left:50%; transform:translate(-50%,-50%); animation:ringRotate 20s linear infinite; border-color:rgba(240,192,64,0.1); }

/* Data flicker on values */
.stat-value { animation:dataFlicker 8s ease-in-out infinite; }
.revenue-amount { animation:dataFlicker 10s ease-in-out infinite; }

/* === TOP BAR === */
.mm-topbar { display:flex; align-items:center; justify-content:space-between; padding:12px 16px; padding-top:calc(12px + var(--safe-top)); position:relative; z-index:10; backdrop-filter:blur(12px); background:rgba(4,4,13,0.2); border-bottom:1px solid rgba(240,192,64,0.2); animation:panelReveal 0.6s ease-out forwards; box-shadow:0 2px 20px rgba(0,0,0,0.3); }
.mm-logo { font-family:var(--font-display); font-size:16px; font-weight:900; color:var(--text-2); letter-spacing:3px; }
.mm-logo span { color:var(--gold); }
.topbar-right { display:flex; align-items:center; gap:10px; }
.status-dot { width:6px; height:6px; background:var(--emerald); border-radius:50%; box-shadow:0 0 8px var(--emerald-glow); animation:glowPulse 2s ease-in-out infinite; }
.topbar-time { font-family:var(--font-mono); font-size:11px; color:var(--text-3); letter-spacing:1px; }
.icon-btn { width:32px; height:32px; border-radius:8px; border:1px solid var(--border); background:transparent; color:var(--text-3); font-size:14px; cursor:pointer; display:flex; align-items:center; justify-content:center; transition:all 0.2s; }
.icon-btn:hover { color:var(--gold); border-color:var(--gold-dim); }

/* === BODY === */
.view-body { flex:1; overflow-y:auto; overflow-x:hidden; -webkit-overflow-scrolling:touch; position:relative; z-index:5; }

/* === GLASS PANELS (3D Jarvis) === */
.view-body { perspective:1200px; }
.glass-panel { margin:12px 14px; padding:16px; background:var(--glass); border:1px solid var(--glass-border); border-radius:14px; backdrop-filter:blur(12px); position:relative; overflow:hidden; opacity:0; transform:translateY(30px) rotateX(2deg); transform-style:preserve-3d; transition:transform 0.4s ease,box-shadow 0.4s ease; }
.glass-panel.revealed { animation:panelReveal3D 0.7s ease-out forwards; }
.glass-panel:hover { transform:translateY(-2px) rotateX(0deg) scale(1.01); box-shadow:0 8px 32px rgba(240,192,64,0.08),0 0 1px var(--gold-dim),inset 0 0 30px rgba(240,192,64,0.02); }
.glass-panel::before { content:''; position:absolute; top:0; left:0; right:0; height:1px; background:linear-gradient(90deg,transparent,var(--gold),transparent); opacity:0.6; }
.glass-panel::after { content:''; position:absolute; top:-100%; left:0; right:0; height:100%; background:linear-gradient(180deg,transparent 0%,rgba(240,192,64,0.04) 50%,transparent 100%); transition:top 0.6s ease; pointer-events:none; }
.glass-panel:hover::after { top:100%; }
.panel-header { display:flex; align-items:center; justify-content:space-between; margin-bottom:14px; }
.panel-title { font-family:var(--font-ui); font-size:11px; font-weight:700; letter-spacing:2px; text-transform:uppercase; color:var(--gold); }
.panel-badge { font-family:var(--font-mono); font-size:10px; padding:2px 8px; border-radius:20px; letter-spacing:1px; }
.badge-green { background:rgba(45,184,114,0.1); color:var(--emerald); border:1px solid rgba(45,184,114,0.2); }
.badge-gold { background:rgba(240,192,64,0.1); color:var(--gold); border:1px solid rgba(240,192,64,0.2); }
.badge-red { background:rgba(255,64,96,0.1); color:var(--red); border:1px solid rgba(255,64,96,0.2); }
.badge-blue { background:rgba(64,128,255,0.1); color:var(--blue-light); border:1px solid rgba(64,128,255,0.2); }

/* === REVENUE === */
.revenue-hero { text-align:center; padding:32px 20px 24px; position:relative; z-index:1; opacity:0; animation:dataStream 0.8s ease-out 0.2s forwards; }
.revenue-label { font-size:11px; font-weight:700; letter-spacing:3px; text-transform:uppercase; color:var(--text-3); margin-bottom:8px; }
.revenue-amount { font-family:var(--font-display); font-size:48px; font-weight:900; color:var(--gold); text-shadow:0 0 40px rgba(240,192,64,0.4); line-height:1; letter-spacing:-1px; margin-bottom:6px; }
.revenue-amount.counting { background:linear-gradient(90deg,var(--gold) 40%,var(--emerald) 50%,var(--gold) 60%); background-size:200% auto; -webkit-background-clip:text; -webkit-text-fill-color:transparent; animation:shimmer 2s linear infinite; }
.revenue-change { font-family:var(--font-mono); font-size:13px; color:var(--emerald); }

/* === STATS === */
.stat-grid { display:grid; grid-template-columns:1fr 1fr; gap:10px; }
.stat-box { background:rgba(4,4,13,0.2); border:1px solid rgba(240,192,64,0.2); border-radius:12px; padding:14px; text-align:center; position:relative; overflow:hidden; backdrop-filter:blur(8px); transition:all 0.3s ease; box-shadow:0 0 15px rgba(240,192,64,0.03); }
.stat-box:hover { border-color:rgba(240,192,64,0.4); box-shadow:0 0 25px rgba(240,192,64,0.08),inset 0 0 20px rgba(240,192,64,0.02); transform:translateY(-2px); }
.stat-box::before { content:''; position:absolute; top:0; left:0; width:12px; height:12px; border-top:1px solid var(--gold-dim); border-left:1px solid var(--gold-dim); opacity:0.4; }
.stat-box::after { content:''; position:absolute; bottom:0; right:0; width:12px; height:12px; border-bottom:1px solid var(--gold-dim); border-right:1px solid var(--gold-dim); opacity:0.4; }
.stat-value { font-family:var(--font-mono); font-size:22px; font-weight:600; color:var(--gold); text-shadow:0 0 20px var(--gold-glow); line-height:1; margin-bottom:4px; }
.stat-value.green { color:var(--emerald); text-shadow:0 0 20px var(--emerald-glow); }
.stat-value.blue { color:var(--blue-light); }
.stat-value.red { color:var(--red); }
.stat-label { font-size:10px; font-weight:700; letter-spacing:1.5px; text-transform:uppercase; color:var(--text-3); }

/* === STREAMS === */
.stream-row { display:flex; align-items:center; gap:10px; margin-bottom:10px; }
.stream-label { font-family:var(--font-mono); font-size:10px; font-weight:600; letter-spacing:1px; color:var(--text-3); width:70px; flex-shrink:0; }
.stream-bar-wrap { flex:1; height:6px; background:rgba(255,255,255,0.05); border-radius:3px; overflow:hidden; }
.stream-bar { height:100%; border-radius:3px; animation:barGrow 1.2s ease-out forwards; position:relative; }
.stream-bar::after { content:''; position:absolute; right:0; top:0; bottom:0; width:20px; background:linear-gradient(90deg,transparent,rgba(255,255,255,0.3)); }
.stream-val { font-family:var(--font-mono); font-size:11px; font-weight:600; color:var(--text-2); width:40px; text-align:right; }

/* === QUEUE === */
.queue-item { display:flex; align-items:center; gap:12px; padding:12px 0; border-bottom:1px solid var(--border); }
.queue-item:last-child { border-bottom:none; }
.queue-thumb { width:44px; height:44px; border-radius:10px; background:var(--void-3); border:1px solid var(--border); display:flex; align-items:center; justify-content:center; font-size:20px; flex-shrink:0; }
.queue-info { flex:1; min-width:0; }
.queue-title { font-size:13px; font-weight:600; color:var(--text-1); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.queue-meta { font-family:var(--font-mono); font-size:10px; color:var(--text-3); margin-top:2px; }
.queue-actions { display:flex; gap:6px; }
.q-btn { width:32px; height:32px; border-radius:8px; border:1px solid var(--border); background:transparent; cursor:pointer; display:flex; align-items:center; justify-content:center; font-size:14px; transition:all 0.2s; }
.q-btn.approve { color:var(--emerald); }
.q-btn.approve:hover { background:rgba(45,184,114,0.15); border-color:var(--emerald); }
.q-btn.reject { color:var(--red); }
.q-btn.reject:hover { background:rgba(255,64,96,0.15); border-color:var(--red); }

/* === TRADES === */
.trade-row { display:flex; align-items:center; padding:10px 0; border-bottom:1px solid var(--border); font-family:var(--font-mono); font-size:12px; }
.trade-row:last-child { border-bottom:none; }
.trade-symbol { font-weight:700; color:var(--gold); width:60px; }
.trade-qty { color:var(--text-2); width:40px; }
.trade-price { color:var(--text-2); flex:1; }
.trade-pnl { width:60px; text-align:right; font-weight:600; }
.trade-pnl.up { color:var(--emerald); }
.trade-pnl.down { color:var(--red); }

/* === BUTTONS === */
.mm-btn { display:flex; align-items:center; justify-content:center; gap:8px; padding:12px 20px; border-radius:12px; border:1px solid var(--gold); background:rgba(240,192,64,0.04); color:var(--gold); font-family:var(--font-ui); font-size:12px; font-weight:700; letter-spacing:1.5px; text-transform:uppercase; cursor:pointer; transition:all 0.3s; position:relative; overflow:hidden; backdrop-filter:blur(8px); box-shadow:0 0 10px rgba(240,192,64,0.05),inset 0 0 10px rgba(240,192,64,0.02); }
.mm-btn:hover { background:rgba(240,192,64,0.1); box-shadow:0 0 30px rgba(240,192,64,0.15),0 0 60px rgba(240,192,64,0.05),inset 0 0 20px rgba(240,192,64,0.03); transform:translateY(-1px); }
.mm-btn.emerald { border-color:var(--emerald-dim); background:rgba(45,184,114,0.06); color:var(--emerald); }
.mm-btn.emerald:hover { background:rgba(45,184,114,0.12); box-shadow:0 0 20px var(--emerald-glow); }

/* === NAV === */
.mm-nav { display:flex; justify-content:space-around; align-items:center; padding:10px 0 calc(10px + var(--safe-bottom)); background:rgba(4,4,13,0.9); backdrop-filter:blur(24px); border-top:1px solid var(--border); flex-shrink:0; position:relative; z-index:20; }
.nav-tab { display:flex; flex-direction:column; align-items:center; gap:4px; padding:6px 24px; border:none; background:none; cursor:pointer; color:var(--text-3); font-family:var(--font-ui); font-size:10px; font-weight:600; letter-spacing:1.5px; text-transform:uppercase; transition:color 0.2s; position:relative; }
.nav-tab.active { color:var(--gold); }
.nav-tab.active::after { content:''; position:absolute; top:-1px; left:50%; transform:translateX(-50%); width:20px; height:2px; background:var(--gold); box-shadow:0 0 8px var(--gold-glow); }
.nav-tab.active .nav-icon { filter:drop-shadow(0 0 6px var(--gold)); }
.nav-icon { font-size:20px; line-height:1; }

/* === AGENT ORB === */
.agent-orb-container { display:flex; justify-content:center; padding:30px 0; position:relative; }
.agent-orb { width:120px; height:120px; border-radius:50%; background:radial-gradient(circle at 40% 35%,var(--emerald),rgba(45,184,114,0.2) 60%,transparent); animation:orbPulse 3s ease-in-out infinite; position:relative; }
.agent-orb::before { content:''; position:absolute; top:50%; left:50%; width:160px; height:160px; border:1px solid rgba(240,192,64,0.2); border-radius:50%; animation:hudRingSpin 12s linear infinite; }
.agent-orb::after { content:''; position:absolute; top:50%; left:50%; width:200px; height:200px; border:1px dashed rgba(45,184,114,0.15); border-radius:50%; animation:hudRingSpin 20s linear infinite reverse; }
.orb-label { text-align:center; font-family:var(--font-mono); font-size:10px; letter-spacing:3px; color:var(--emerald); opacity:0.6; margin-top:20px; }

/* === CHAT === */
.chat-container { flex:1; overflow-y:auto; padding:10px 14px; display:flex; flex-direction:column; gap:10px; }
.chat-msg { max-width:85%; padding:10px 14px; border-radius:12px; font-size:13px; line-height:1.5; animation:panelReveal 0.3s ease-out forwards; }
.chat-msg.user { align-self:flex-end; background:rgba(240,192,64,0.1); border:1px solid rgba(240,192,64,0.2); color:var(--gold); }
.chat-msg.ai { align-self:flex-start; background:var(--glass); border:1px solid var(--glass-border); color:var(--text-1); }
.typing-cursor { display:inline-block; width:2px; height:14px; background:var(--emerald); margin-left:4px; vertical-align:middle; animation:blink 0.8s ease-in-out infinite; }
.chip-row { display:flex; gap:8px; padding:8px 14px; overflow-x:auto; flex-shrink:0; }
.chip { padding:8px 14px; border-radius:20px; border:1px solid var(--border); background:var(--glass); color:var(--text-2); font-family:var(--font-ui); font-size:12px; font-weight:600; white-space:nowrap; cursor:pointer; transition:all 0.2s; }
.chip:hover { color:var(--gold); border-color:var(--gold-dim); }
.chat-input-bar { padding:10px 14px; background:rgba(4,4,13,0.9); backdrop-filter:blur(24px); border-top:1px solid var(--border); display:flex; gap:10px; align-items:center; flex-shrink:0; }
.chat-input { flex:1; background:var(--glass); border:1px solid var(--border); border-radius:12px; padding:12px 14px; color:var(--text-1); font-family:var(--font-ui); font-size:14px; outline:none; }
.chat-input:focus { border-color:var(--gold-dim); }
.chat-input::placeholder { color:var(--text-3); }
.send-btn { width:44px; height:44px; border-radius:12px; border:1px solid rgba(240,192,64,0.3); background:rgba(240,192,64,0.08); color:var(--gold); font-size:18px; cursor:pointer; display:flex; align-items:center; justify-content:center; transition:all 0.2s; flex-shrink:0; }
.send-btn:hover { background:rgba(240,192,64,0.18); box-shadow:0 0 16px var(--gold-glow); }

/* === DIVIDER === */
.mm-divider { height:1px; background:linear-gradient(90deg,transparent,var(--border),transparent); margin:14px 0; }

/* === RESPONSIVE === */
@media (min-width:768px) {
  .mm-topbar { padding:16px 40px; }
  .mm-logo { font-size:20px; }
  .view-body { padding:0 calc((100% - 700px)/2); }
  .glass-panel { margin:16px 0; padding:20px; border-radius:18px; }
  .revenue-amount { font-size:64px; }
  .stat-grid { grid-template-columns:repeat(4,1fr); }
  .mm-nav { max-width:400px; margin:0 auto; border-radius:20px 20px 0 0; }
  .chat-msg { max-width:60%; }
  .agent-orb { width:160px; height:160px; }
  .agent-orb::before { width:220px; height:220px; }
  .agent-orb::after { width:280px; height:280px; }
}

@media (min-width:1200px) {
  .view-body { padding:0 calc((100% - 900px)/2); }
  .stat-grid { gap:16px; }
  .stat-value { font-size:28px; }
}

/* Staggered reveals */
.glass-panel:nth-child(1).revealed { animation-delay:0.1s; }
.glass-panel:nth-child(2).revealed { animation-delay:0.25s; }
.glass-panel:nth-child(3).revealed { animation-delay:0.4s; }
.glass-panel:nth-child(4).revealed { animation-delay:0.55s; }
.glass-panel:nth-child(5).revealed { animation-delay:0.7s; }

/* Scrollbar */
.view-body::-webkit-scrollbar { width:3px; }
.view-body::-webkit-scrollbar-track { background:transparent; }
.view-body::-webkit-scrollbar-thumb { background:var(--gold-dim); border-radius:3px; }

/* === PAGE TRANSITIONS === */
@keyframes viewSlideIn { 0%{transform:scale(0.92) translateY(20px);opacity:0;filter:blur(6px)} 100%{transform:scale(1) translateY(0);opacity:1;filter:blur(0)} }
@keyframes viewSlideOut { 0%{transform:scale(1);opacity:1} 100%{transform:scale(1.05);opacity:0;filter:blur(4px)} }
.view-enter { animation:viewSlideIn 0.6s cubic-bezier(0.22,1,0.36,1) forwards; }
.view-exit { animation:viewSlideOut 0.3s ease-in forwards; }

/* === PARTICLE BOKEH BACKGROUND === */
@keyframes particleFloat1 { 0%{transform:translate(0,0) scale(1);opacity:0.15} 25%{transform:translate(40px,-60px) scale(1.2);opacity:0.25} 50%{transform:translate(-20px,-120px) scale(0.8);opacity:0.1} 75%{transform:translate(60px,-180px) scale(1.1);opacity:0.2} 100%{transform:translate(0,-250px) scale(1);opacity:0} }
@keyframes particleFloat2 { 0%{transform:translate(0,0) scale(0.8);opacity:0.1} 33%{transform:translate(-50px,-80px) scale(1.3);opacity:0.2} 66%{transform:translate(30px,-160px) scale(0.9);opacity:0.15} 100%{transform:translate(-20px,-280px) scale(1);opacity:0} }
@keyframes particleDrift { 0%{transform:translateX(-5px)} 50%{transform:translateX(5px)} 100%{transform:translateX(-5px)} }

.particle-field { position:absolute; inset:0; z-index:1; pointer-events:none; overflow:hidden; }
.particle { position:absolute; border-radius:50%; background:radial-gradient(circle,var(--gold) 0%,transparent 70%); filter:blur(1px); }
.particle:nth-child(1) { width:4px; height:4px; left:15%; bottom:20%; animation:particleFloat1 12s ease-in-out infinite; }
.particle:nth-child(2) { width:3px; height:3px; left:45%; bottom:10%; animation:particleFloat2 15s ease-in-out 2s infinite; }
.particle:nth-child(3) { width:5px; height:5px; left:75%; bottom:30%; animation:particleFloat1 18s ease-in-out 4s infinite; opacity:0.12; }
.particle:nth-child(4) { width:2px; height:2px; left:30%; bottom:5%; animation:particleFloat2 10s ease-in-out 1s infinite; background:radial-gradient(circle,var(--emerald) 0%,transparent 70%); }
.particle:nth-child(5) { width:3px; height:3px; left:60%; bottom:15%; animation:particleFloat1 14s ease-in-out 3s infinite; background:radial-gradient(circle,var(--emerald) 0%,transparent 70%); }
.particle:nth-child(6) { width:4px; height:4px; left:85%; bottom:25%; animation:particleFloat2 16s ease-in-out 5s infinite; }
.particle:nth-child(7) { width:2px; height:2px; left:10%; bottom:40%; animation:particleFloat1 20s ease-in-out 6s infinite; background:radial-gradient(circle,var(--blue) 0%,transparent 70%); }
.particle:nth-child(8) { width:3px; height:3px; left:50%; bottom:35%; animation:particleFloat2 13s ease-in-out 7s infinite; }

/* === HOLOGRAPHIC NAV BAR === */
.mm-nav { background:rgba(4,4,13,0.85); box-shadow:0 -4px 30px rgba(0,0,0,0.4),inset 0 1px 0 rgba(240,192,64,0.08); }
.mm-nav::before { content:''; position:absolute; top:0; left:0; right:0; height:1px; background:linear-gradient(90deg,transparent 10%,rgba(240,192,64,0.15) 30%,rgba(45,184,114,0.2) 50%,rgba(240,192,64,0.15) 70%,transparent 90%); }
.nav-tab { position:relative; }
.nav-tab::before { content:''; position:absolute; inset:-4px -8px; border-radius:12px; background:transparent; transition:all 0.3s ease; }
.nav-tab.active::before { background:rgba(240,192,64,0.04); box-shadow:0 0 20px rgba(240,192,64,0.06); }
.nav-tab:not(.active):hover { color:var(--text-2); }
.nav-tab:not(.active):hover::before { background:rgba(240,192,64,0.02); }

/* === REVENUE HERO FLOATING 3D === */
.revenue-hero { perspective:800px; }
.revenue-hero::before { content:''; position:absolute; inset:-20px; background:radial-gradient(ellipse at 50% 40%,rgba(240,192,64,0.06) 0%,transparent 60%); z-index:-1; animation:glowPulse 4s ease-in-out infinite; }
.revenue-hero::after { content:''; position:absolute; bottom:0; left:20%; right:20%; height:1px; background:linear-gradient(90deg,transparent,rgba(240,192,64,0.2),transparent); }
.revenue-amount { transform:translateZ(20px); text-shadow:0 0 40px rgba(240,192,64,0.4),0 0 80px rgba(240,192,64,0.15),0 2px 4px rgba(0,0,0,0.5); }

/* === HOLOGRAPHIC DATA RINGS (City View) === */
@keyframes dataRingSpin { from{transform:rotate(0deg)} to{transform:rotate(360deg)} }
@keyframes dataRingPulse { 0%,100%{stroke-dashoffset:0;opacity:0.6} 50%{stroke-dashoffset:20;opacity:1} }
.data-ring-container { position:absolute; top:50%; left:50%; width:0; height:0; z-index:1; pointer-events:none; }
.data-ring { position:absolute; border-radius:50%; border:1px solid transparent; }
.data-ring-1 { width:400px; height:400px; top:-200px; left:-200px; border-image:conic-gradient(from 0deg,rgba(240,192,64,0.15),transparent 30%,rgba(45,184,114,0.1) 50%,transparent 80%,rgba(240,192,64,0.15)) 1; animation:dataRingSpin 25s linear infinite; }
.data-ring-2 { width:600px; height:600px; top:-300px; left:-300px; border-image:conic-gradient(from 180deg,rgba(45,184,114,0.1),transparent 25%,rgba(240,192,64,0.08) 50%,transparent 75%,rgba(45,184,114,0.1)) 1; animation:dataRingSpin 40s linear infinite reverse; }

/* === HUD CROSSHAIR === */
.hud-crosshair { position:absolute; top:50%; left:50%; width:40px; height:40px; z-index:1; pointer-events:none; transform:translate(-50%,-50%); }
.hud-crosshair::before { content:''; position:absolute; top:50%; left:0; right:0; height:1px; background:linear-gradient(90deg,transparent 15%,rgba(240,192,64,0.12) 40%,rgba(240,192,64,0.2) 50%,rgba(240,192,64,0.12) 60%,transparent 85%); }
.hud-crosshair::after { content:''; position:absolute; left:50%; top:0; bottom:0; width:1px; background:linear-gradient(180deg,transparent 15%,rgba(240,192,64,0.12) 40%,rgba(240,192,64,0.2) 50%,rgba(240,192,64,0.12) 60%,transparent 85%); }

/* === LOGIN PAGE (Jarvis Theme) === */
.login-screen { position:relative; display:flex; flex-direction:column; align-items:center; justify-content:center; height:100vh; overflow:hidden; }
.login-bg-img { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; opacity:0; animation:jarvisZoomIn 1.2s ease-out 0.2s forwards; filter:brightness(0.4) saturate(1.2); }
.login-overlay { position:absolute; inset:0; background:radial-gradient(ellipse at 50% 30%,rgba(4,4,13,0.3) 0%,rgba(4,4,13,0.7) 50%,rgba(4,4,13,0.95) 100%); z-index:1; }
.login-content { position:relative; z-index:10; width:100%; max-width:360px; padding:0 24px; display:flex; flex-direction:column; align-items:center; opacity:0; animation:dataStream 0.8s ease-out 0.8s forwards; }

.login-header { text-align:center; margin-bottom:40px; }
.login-logo { margin-bottom:8px; }
.logo-mad { font-family:var(--font-display); font-size:36px; font-weight:900; color:var(--text-2); letter-spacing:4px; }
.logo-muda { font-family:var(--font-display); font-size:36px; font-weight:900; color:var(--gold); letter-spacing:4px; text-shadow:0 0 30px var(--gold-glow); }
.login-tagline { font-family:var(--font-mono); font-size:11px; letter-spacing:4px; color:var(--emerald); margin-top:6px; text-transform:uppercase; }
.login-divider-line { width:60px; height:1px; background:linear-gradient(90deg,transparent,var(--gold),transparent); margin:16px auto 0; opacity:0.4; }

.login-form { width:100%; display:flex; flex-direction:column; gap:16px; }
.field-group { display:flex; flex-direction:column; gap:6px; }
.field-label { font-family:var(--font-mono); font-size:10px; font-weight:600; letter-spacing:2px; color:var(--text-3); text-transform:uppercase; }
.field-input { background:rgba(13,13,34,0.6); border:1px solid rgba(240,192,64,0.15); border-radius:12px; padding:14px 16px; color:var(--text-1); font-family:var(--font-ui); font-size:14px; outline:none; backdrop-filter:blur(12px); transition:all 0.3s ease; }
.field-input:focus { border-color:var(--gold-dim); box-shadow:0 0 20px rgba(240,192,64,0.08),inset 0 0 10px rgba(240,192,64,0.02); }
.field-input::placeholder { color:var(--text-3); }

.login-error { font-family:var(--font-mono); font-size:12px; color:var(--red); text-align:center; padding:8px 12px; background:rgba(255,64,96,0.08); border:1px solid rgba(255,64,96,0.2); border-radius:8px; }

.login-btn { width:100%; padding:14px; border-radius:12px; border:1px solid var(--gold); background:rgba(240,192,64,0.06); color:var(--gold); font-family:var(--font-ui); font-size:13px; font-weight:700; letter-spacing:2px; text-transform:uppercase; cursor:pointer; transition:all 0.3s ease; position:relative; overflow:hidden; backdrop-filter:blur(8px); box-shadow:0 0 15px rgba(240,192,64,0.06); }
.login-btn:hover { background:rgba(240,192,64,0.12); box-shadow:0 0 30px rgba(240,192,64,0.15),0 0 60px rgba(240,192,64,0.05); transform:translateY(-1px); }
.login-btn:disabled { opacity:0.5; cursor:not-allowed; transform:none; }
.login-btn::before { content:''; position:absolute; top:0; left:-100%; width:100%; height:100%; background:linear-gradient(90deg,transparent,rgba(240,192,64,0.1),transparent); transition:left 0.5s; }
.login-btn:hover::before { left:100%; }

.login-divider { width:100%; text-align:center; position:relative; margin:4px 0; }
.login-divider::before { content:''; position:absolute; top:50%; left:0; right:0; height:1px; background:linear-gradient(90deg,transparent,var(--border),transparent); }

.login-btn-secondary { width:100%; padding:12px; border-radius:12px; border:1px solid rgba(45,184,114,0.2); background:rgba(45,184,114,0.04); color:var(--emerald); font-family:var(--font-ui); font-size:12px; font-weight:700; letter-spacing:2px; text-transform:uppercase; cursor:pointer; transition:all 0.3s ease; }
.login-btn-secondary:hover { background:rgba(45,184,114,0.1); box-shadow:0 0 20px var(--emerald-glow); border-color:var(--emerald-dim); }

.login-footer { margin-top:40px; text-align:center; display:flex; flex-direction:column; gap:4px; }
.login-studio { font-family:var(--font-mono); font-size:9px; letter-spacing:2px; color:var(--text-3); text-transform:uppercase; opacity:0.5; }
.login-version { font-family:var(--font-mono); font-size:9px; letter-spacing:1px; color:var(--text-3); opacity:0.3; }

/* === ENHANCED AGENT ORB (3 geometry rings) === */
.agent-orb { box-shadow:0 0 40px var(--emerald-glow),0 0 80px rgba(45,184,114,0.1),inset 0 0 30px rgba(45,184,114,0.15); }
.agent-orb-container::before { content:''; position:absolute; top:50%; left:50%; width:250px; height:250px; transform:translate(-50%,-50%); border:1px solid rgba(240,192,64,0.06); border-radius:50%; animation:hudRingSpin 35s linear infinite; border-style:dotted; }

/* === MINI HUD ELEMENTS === */
.hud-label { position:absolute; font-family:var(--font-mono); font-size:8px; letter-spacing:2px; color:rgba(240,192,64,0.2); text-transform:uppercase; pointer-events:none; z-index:2; }
.hud-label.top-left { top:80px; left:20px; }
.hud-label.top-right { top:80px; right:20px; }
.hud-label.bot-left { bottom:130px; left:20px; }

/* === GLITCH TEXT EFFECT === */
@keyframes glitchText { 0%,92%,100%{transform:none;text-shadow:0 0 40px var(--gold-glow)} 93%{transform:translate(2px,-1px);text-shadow:-2px 0 var(--emerald)} 94%{transform:translate(-2px,1px);text-shadow:2px 0 var(--red)} 95%{transform:none;text-shadow:0 0 40px var(--gold-glow)} }
.revenue-amount { animation:glitchText 12s ease-in-out infinite,dataFlicker 10s ease-in-out infinite; }

/* === LOADING STATES === */
@keyframes loadingPulse { 0%,100%{opacity:0.3} 50%{opacity:0.8} }
.loading-skeleton { background:linear-gradient(90deg,rgba(240,192,64,0.03) 25%,rgba(240,192,64,0.08) 50%,rgba(240,192,64,0.03) 75%); background-size:200% 100%; animation:shimmer 1.5s linear infinite; border-radius:8px; }

/* === ENHANCED CHAT MESSAGES === */
.chat-msg.ai { position:relative; }
.chat-msg.ai::before { content:''; position:absolute; top:0; left:0; width:2px; height:100%; background:linear-gradient(180deg,var(--emerald),transparent); border-radius:1px; }
.chat-msg.user::before { content:''; position:absolute; top:0; right:0; width:2px; height:100%; background:linear-gradient(180deg,var(--gold),transparent); border-radius:1px; }
.chat-msg.user { position:relative; }

/* === STAT BOX CONNECTOR LINES === */
.stat-grid { position:relative; }
.stat-grid::before { content:''; position:absolute; top:50%; left:0; right:0; height:1px; background:linear-gradient(90deg,transparent,rgba(240,192,64,0.08),transparent); z-index:0; }
.stat-grid::after { content:''; position:absolute; left:50%; top:0; bottom:0; width:1px; background:linear-gradient(180deg,transparent,rgba(240,192,64,0.08),transparent); z-index:0; }
.stat-box { z-index:1; }

/* === STREAM BAR GLOW === */
.stream-bar { box-shadow:0 0 8px rgba(255,255,255,0.05); }
.stream-bar::before { content:''; position:absolute; top:-2px; bottom:-2px; left:0; right:0; background:inherit; filter:blur(4px); opacity:0.3; z-index:-1; }
