/* dashboard_theme.css
   Modern dark dashboard theme for AgenticAI
   Drop into /static/css/dashboard_theme.css
*/

/* =========================
   Theme variables (change here)
   ========================= */
:root{
  --bg: #0b0d0f;
  --panel: #0f1113;
  --card: #131416;
  --muted: #9aa4ad;
  --accent: #00d4ff; /* cyan */
  --accent-2: #7be495; /* green accent */
  --danger: #ff5c66;
  --glass: rgba(255,255,255,0.02);
  --border: rgba(255,255,255,0.04);
  --glass-2: rgba(0,0,0,0.6);
  --shadow: 0 8px 30px rgba(2,6,23,0.6);
  --radius: 12px;
  --mono: "SFMono-Regular", "Roboto Mono", Menlo, monospace;
  --ui-font: 'Inter', "Segoe UI", Roboto, Arial, sans-serif;
}

/* =========================
   Global resets + base
   ========================= */
*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  min-height:100%;
  font-family:var(--ui-font);
  background: radial-gradient(1200px 600px at 10% 8%, rgba(0,212,255,0.03), transparent),
              linear-gradient(180deg, var(--bg) 0%, #060607 100%);
  color:#e6eef3;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  line-height:1.45;
  font-size:14px;
  padding-bottom:48px;
}

/* =========================
   Header — Clean Hamburger Layout
   ========================= */
.main-header{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:0 20px;
  height:52px;
  position:sticky;
  top:0;
  z-index:1200;
  background: linear-gradient(180deg, rgba(11,13,15,0.95), rgba(6,6,7,0.9));
  border-bottom:1px solid rgba(0,212,255,0.08);
  backdrop-filter: blur(12px);
  box-shadow: 0 2px 16px rgba(0,0,0,0.4);
}

/* Logo */
.logo-link{ text-decoration:none; }
.logo{
  display:flex;
  align-items:center;
  gap:8px;
  white-space:nowrap;
}
.logo-icon{
  font-size:1.2rem;
  filter: drop-shadow(0 0 6px rgba(0,212,255,0.4));
}
.logo-text{
  font-weight:800;
  font-size:1.05rem;
  background: linear-gradient(135deg, var(--accent), #7be495);
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
  background-clip:text;
}

/* Header right: login + hamburger */
.header-right{
  display:flex;
  align-items:center;
  gap:12px;
}
.header-login-btn{
  display:inline-flex;
  align-items:center;
  gap:5px;
  padding:6px 16px;
  background: linear-gradient(135deg, var(--accent), #00b8e6);
  color:#000;
  font-weight:700;
  font-size:0.82rem;
  border-radius:8px;
  text-decoration:none;
  box-shadow: 0 2px 10px rgba(0,212,255,0.2);
  transition: all .2s ease;
}
.header-login-btn:hover{
  transform:translateY(-1px);
  box-shadow: 0 4px 16px rgba(0,212,255,0.35);
}

/* Hamburger button — always visible */
.hamburger-btn{
  display:flex;
  flex-direction:column;
  gap:4px;
  cursor:pointer;
  padding:8px;
  border-radius:8px;
  transition: background 0.2s;
}
.hamburger-btn:hover{ background:rgba(255,255,255,0.05); }
.hamburger-line{
  display:block;
  width:20px;
  height:2px;
  background:var(--accent);
  border-radius:2px;
  transition:all .3s ease;
}

/* =========================
   Side Menu (slide-out panel)
   ========================= */
.side-menu{
  display:none;
  position:fixed;
  top:0;
  right:0;
  width:280px;
  height:100vh;
  background:rgba(10,10,12,0.98);
  border-left:1px solid rgba(0,212,255,0.08);
  box-shadow: -8px 0 30px rgba(0,0,0,0.5);
  backdrop-filter:blur(16px);
  z-index:2000;
  flex-direction:column;
  overflow-y:auto;
}
.side-menu.open{ display:flex; }

/* Side menu header */
.side-menu-header{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:14px 20px;
  border-bottom:1px solid rgba(0,212,255,0.06);
  flex-shrink:0;
}
.side-menu-close{
  font-size:1.1rem;
  color:var(--muted);
  cursor:pointer;
  padding:5px 9px;
  border-radius:8px;
  background:rgba(255,255,255,0.04);
  border:1px solid rgba(255,255,255,0.06);
  transition:all .2s;
  line-height:1;
}
.side-menu-close:hover{
  color:var(--danger);
  background:rgba(255,92,102,0.08);
  border-color:rgba(255,92,102,0.2);
}

/* Side menu items */
.side-menu-items{
  flex:1;
  padding:8px 0;
  overflow-y:auto;
}
.side-menu-section-label{
  padding:10px 22px 4px;
  font-size:0.68rem;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:1px;
  color:rgba(0,212,255,0.4);
}
.side-menu-items a{
  display:flex !important;
  align-items:center;
  gap:10px;
  padding:11px 22px;
  font-size:0.88rem;
  font-weight:500;
  text-decoration:none;
  color:#c0cdd4;
  transition:all .18s ease;
  border-left:3px solid transparent;
  width:100%;
  box-sizing:border-box;
}
.side-menu-items a:hover{
  color:#fff;
  background:rgba(0,212,255,0.05);
  border-left-color:var(--accent);
  padding-left:26px;
}
.nav-icon{ font-size:0.95rem; width:20px; text-align:center; }
.side-menu-divider{
  height:1px;
  background:rgba(255,255,255,0.04);
  margin:6px 18px;
}

/* Side menu auth (bottom) */
.side-menu-auth{
  padding:16px 20px;
  border-top:1px solid rgba(255,255,255,0.04);
  flex-shrink:0;
}
.side-login-btn{
  display:block;
  text-align:center;
  padding:11px 20px;
  background: linear-gradient(135deg, var(--accent), #00b8e6);
  color:#000 !important;
  font-weight:700;
  font-size:0.9rem;
  border-radius:10px;
  text-decoration:none;
  box-shadow: 0 3px 14px rgba(0,212,255,0.2);
  transition:all .2s;
}
.side-login-btn:hover{
  transform:translateY(-1px);
  box-shadow: 0 5px 18px rgba(0,212,255,0.35);
}
.side-logout-btn{
  display:block;
  text-align:center;
  padding:10px 20px;
  color:var(--muted);
  font-weight:600;
  font-size:0.85rem;
  border:1px solid rgba(255,255,255,0.08);
  border-radius:10px;
  text-decoration:none;
  transition:all .2s;
}
.side-logout-btn:hover{
  color:var(--danger);
  border-color:rgba(255,92,102,0.3);
  background:rgba(255,92,102,0.06);
}

/* Menu overlay */
.menu-overlay{
  display:none;
  position:fixed;
  inset:0;
  background:rgba(0,0,0,0.55);
  backdrop-filter:blur(3px);
  z-index:1900;
}
.menu-overlay.open{ display:block; }
body.menu-open{ overflow:hidden; }

/* Dashboard page title (replaces bare <header> in dashboard) */
.dash-page-title{
  font-size:1rem;
  font-weight:600;
  color:var(--muted);
  padding:8px 0 4px;
}

/* =========================
   Mode badge (top-right) – expects #modeIndicatorBanner element
   ========================= */
#modeIndicatorBanner{
  position:fixed;
  right:18px;
  top:64px;
  padding:8px 12px;
  border-radius:999px;
  font-weight:700;
  font-size:.86rem;
  color:#000;
  background:var(--accent);
  box-shadow:0 6px 18px rgba(0,212,255,0.12);
  border:1px solid rgba(255,255,255,0.06);
  z-index:1300;
}
#modeIndicatorBanner.live{ background: var(--danger); color:#fff; box-shadow:0 8px 22px rgba(255,92,102,0.12) }
#modeIndicatorBanner.paper{ background: var(--accent); color:#000; }

/* =========================
   Content container grid
   ========================= */
main{ padding:22px 28px; margin-top:6px; max-width:1400px; margin-left:auto; margin-right:auto; }
.container{
  display:grid;
  grid-template-columns: 360px 1fr;
  gap:20px;
  align-items:start;
}

/* single-column fallback */
@media (max-width:1000px){
  .container{ grid-template-columns: 1fr; padding:18px; }
  #modeIndicatorBanner{ top:84px; right:12px; }
}

/* =========================
   Card
   ========================= */
.card{
  background: linear-gradient(180deg, rgba(255,255,255,0.01), rgba(255,255,255,0.00));
  border-radius:var(--radius);
  padding:16px;
  border:1px solid var(--border);
  box-shadow:var(--shadow);
  transition: transform .14s ease, box-shadow .14s ease;
}
.card:hover{ transform:translateY(-6px); box-shadow: 0 18px 40px rgba(2,8,20,0.6); }
.card h3{ margin:0 0 12px 0; font-size:1.05rem; color:var(--accent); }

/* small utility */
.mt-6{ margin-top:18px; }

/* =========================
   Left column: Controls + Logs
   ========================= */
.status{ display:flex; gap:8px; align-items:center; flex-wrap:wrap; margin:8px 0; }
.status span{ color:var(--muted); font-weight:600; }
.indicator{ width:12px; height:12px; border-radius:50%; display:inline-block; box-shadow:0 3px 8px rgba(0,0,0,0.6);}
.indicator.running{ background:var(--accent-2); box-shadow:0 0 10px rgba(123,228,149,0.12) }
.indicator.stopped{ background:var(--danger); box-shadow:0 0 10px rgba(255,92,102,0.12) }

.control-buttons{ display:flex; gap:8px; flex-wrap:wrap; margin-top:12px; }
button{
  cursor:pointer;
  padding:9px 12px;
  border-radius:10px;
  border:none;
  font-weight:700;
  color:#061016;
  background:linear-gradient(180deg,var(--accent) 0%, #00b8e6 100%);
  transition:transform .12s ease, box-shadow .12s ease;
  box-shadow: 0 8px 20px rgba(0,212,255,0.06);
}
button.stop-btn{ background:linear-gradient(180deg,var(--danger), #d33); color:#fff; box-shadow:0 8px 20px rgba(255,92,102,0.06);}
button.toggle-btn{ background: linear-gradient(180deg,#ffd54f, #ffcc00); color:#000; }
button.test-btn{ background:linear-gradient(180deg,#0bd,#079); color:#fff; }

/* manual trade inputs */
.manual-trade input, .manual-trade select{
  width:100%;
  padding:9px 10px;
  border-radius:8px;
  background:transparent;
  border:1px solid rgba(255,255,255,0.03);
  color:#e6eef3;
  margin-top:6px;
}

/* logs */
#logContainer{
  height:52vh;
  overflow:auto;
  font-family:var(--mono);
  font-size:13px;
  background: linear-gradient(180deg, rgba(255,255,255,0.01), transparent);
  border-radius:10px;
  padding:12px;
  border:1px solid var(--border);
}
#logContainer div{ padding:4px 0; line-height:1.35; white-space:pre-wrap; }
#logContainer .buy{ color: var(--accent-2); }
#logContainer .sell{ color: var(--danger); }
#logContainer .warn{ color: #ffb86b; }
#logContainer .error{ color:#ff6b6b; }

/* last updated text */
#lastUpdated{ text-align:right; color:var(--muted); font-size:12px; margin-top:8px; }

/* =========================
   Right column: summary, trends, charts
   ========================= */
.decision-summary-section{ width:100%; margin-top:18px; display:grid; grid-template-columns: 1fr 380px; gap:18px; }
@media (max-width:1100px){ .decision-summary-section{ grid-template-columns:1fr; } }

.last-decision-card{ padding:18px; }
.last-decision-grid{ display:grid; gap:12px; grid-template-columns: repeat(2,1fr); }
.last-decision-item{ background:var(--panel); padding:12px; border-radius:10px; border:1px solid var(--border); color:#d8eef7; }
.last-decision-item strong{ color:var(--accent); display:block; margin-bottom:6px; font-weight:700; }

/* trading summary grid */
.trading-summary-grid{ display:grid; grid-template-columns: repeat(auto-fit,minmax(140px,1fr)); gap:12px; margin-top:16px; }
.trading-summary-card .summary-item{ padding:12px; background:var(--panel); border-radius:10px; border:1px solid var(--border); text-align:center; color:#dbeff5; }
.trading-summary-card .summary-item b{ color:var(--muted); display:block; margin-bottom:6px; }
.trading-summary-card .summary-item span{ color:var(--accent); font-weight:800; font-size:1.05rem; }

/* charts */
/* .trade-chart-container, .trading-summary-chart{ background:linear-gradient(180deg, rgba(0,0,0,0.2), transparent); padding:12px; border-radius:10px; border:1px solid var(--border); } */

/*
.trade-chart-container {
    background: linear-gradient(180deg, rgba(0,0,0,0.2), transparent);
    padding: 12px;
    border-radius: 10px;
    border: 1px solid var(--border);
    height: 550px !important;        
    min-height: 450px !important;
}
*/

.trade-chart-container {
  height: 400px !important;   /* adjust as you want: 400 / 450 / 500 */
  min-height: 450px !important;
  padding: 12px;
  border-radius: 10px;
  border: 1px solid var(--border);
}



.trading-summary-chart {
    background: linear-gradient(180deg, rgba(0,0,0,0.2), transparent);
    padding: 12px;
    border-radius: 10px;
    border: 1px solid var(--border);
    
}

#tradeChart {
  width: 100% !important;
  height: 100% !important;   /* this is the key */
}


/*
canvas {
  display: block;
  width: 100% !important;
  height: 100% !important;   
}
*/

/* confidence table */
#confidenceTable{ width:100%; border-collapse:collapse; font-size:13px; color:#dbeff5; }
#confidenceTable th{ text-align:left; padding:10px; background:transparent; color:var(--accent); border-bottom:1px solid var(--border); font-weight:700; }
#confidenceTable td{ padding:8px 10px; border-bottom:1px solid rgba(255,255,255,0.02); color:#cfeff4; }

/* trend table */
#trendTable{ width:100%; border-collapse:collapse; font-size:13px; color:#dbeff5; }
#trendTable thead th{ padding:10px; background:transparent; color:var(--accent); text-transform:uppercase; font-size:12px; border-bottom:1px solid var(--border); }
#trendTable td{ padding:10px 8px; border-bottom:1px solid rgba(255,255,255,0.02); }
#trendTable tbody tr:hover{ background: rgba(0,212,255,0.02); }

/* trade table */
.trade-table{ width:100%; border-collapse:collapse; font-size:13px; color:#dbeff5; }
.trade-table thead th{ padding:10px; border-bottom:1px solid var(--border); color:var(--accent); font-weight:700; text-align:left; font-size:12px; }
.trade-table td{ padding:10px 8px; border-bottom:1px solid rgba(255,255,255,0.02); }

/* small helper elements */
.pill{ background:var(--glass); padding:6px 8px; border-radius:999px; font-weight:700; color:var(--muted); font-size:12px; border:1px solid rgba(255,255,255,0.02); }
.muted{ color:var(--muted); }

/* =========================
   Footer — Redesigned
   ========================= */
footer{
  margin-top:40px;
  padding:20px 28px;
  border-top:1px solid rgba(0,212,255,0.06);
  background: linear-gradient(180deg, transparent, rgba(0,0,0,0.2));
}
.footer-content{
  display:flex;
  align-items:center;
  justify-content:space-between;
  max-width:1400px;
  margin:0 auto;
  flex-wrap:wrap;
  gap:12px;
}
.footer-brand{
  display:flex;
  align-items:center;
  gap:6px;
}
.footer-logo{
  font-size:1rem;
  filter: drop-shadow(0 0 4px rgba(0,212,255,0.3));
}
.footer-name{
  font-weight:700;
  font-size:0.85rem;
  background: linear-gradient(135deg, var(--accent), #7be495);
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
  background-clip:text;
}
.footer-meta{
  display:flex;
  align-items:center;
  gap:8px;
  color:var(--muted);
  font-size:0.78rem;
}
.footer-meta strong{ color:var(--accent); }
.footer-dot{ opacity:0.3; }
@media (max-width:600px){
  .footer-content{ justify-content:center; text-align:center; flex-direction:column; gap:6px; }
}

/* =========================
   Tiny responsiveness tweaks
   ========================= */
@media (max-width:760px){
  .container{ gap:12px; padding:12px; }
  #logContainer{ height:40vh; }
  canvas{ height:190px !important; }
}

/* end of dashboard_theme.css */

/* Improve Card Elevation (Soft Glow + Subtle Border + Smooth Hover) */

.card {
  background: linear-gradient(180deg, #0d0d0d, #0b0b0b);
  border: 1px solid rgba(0, 255, 255, 0.07);
  border-radius: 14px;
  padding: 24px;
  box-shadow: 
      0 2px 4px rgba(0,0,0,0.5),
      inset 0 0 8px rgba(255,255,255,0.03);
  transition: all 0.25s ease-in-out;
}

.card:hover {
  transform: translateY(-3px);
  box-shadow: 
      0 4px 14px rgba(0, 255, 255, 0.12),
      inset 0 0 12px rgba(255,255,255,0.04);
  border-color: rgba(0,255,255,0.18);
}

/* Modern Text Box Inputs (Rounded, Soft Border, Glow on Focus) */

input, select {
  width: 100%;
  padding: 10px 12px;
  background: #0e0e0e;
  border: 1px solid rgba(0,255,255,0.10);
  border-radius: 10px;
  color: #e0e0e0;
  font-size: 0.95rem;
  transition: all 0.3s ease;
}

input:focus, select:focus {
  border-color: #00eaff;
  box-shadow: 0 0 10px rgba(0,234,255,0.25);
  background: #111;
  outline: none;
}

/* Reduce Chart Height (Trade Chart + Win/Loss Chart) */

.trade-chart-container {
  height: 160px !important;
}

.trade-chart-container canvas {
  height: 130px !important;
}

.trading-summary-chart {
  padding: 10px 14px;
  max-height: 220px;
}

#dashProfitChart {
  max-height: 180px !important;
}

/* Improve Section Spacing (More Minimal, Less Padding)
🔧 Add this CSS */

.decision-summary-section,
.trading-summary-card,
.trend-insights-card,
.confidence-card,
.trade-visual-card {
  margin-top: 22px !important;
  padding: 20px 24px !important;
}

/* Make Buttons More Modern (Rounded + Glow) */
button {
  border-radius: 10px !important;
  font-weight: 600;
  letter-spacing: 0.3px;
  box-shadow: 0 0 8px rgba(0,255,255,0.25);
}

button:hover {
  box-shadow: 0 0 14px rgba(0,255,255,0.35);
}

/* My Additional UI/UX Expert Suggestions */
body {
  background: radial-gradient(circle at top center, #0c0c0c, #050505 80%);
}


/* ------ decision-summary-section cards are displayed in only cone row ------ */

/* === Full-width wrapper like other dashboard cards === */
.decision-summary-section {
    width: 100%;
    max-width: 1300px;
    margin: 30px auto;
    padding: 0 20px; /* match other components spacing */
}

/* === Full-width card === */
.last-decision-card {
    width: 100%;
    background: #151515;
    border: 1px solid #222;
    border-radius: 14px;
    padding: 20px 22px;
    box-shadow: 0 0 12px rgba(0,0,0,0.45);
}

/* Title */
.last-decision-title {
    margin-bottom: 20px;
    font-size: 1.35rem;
    color: #00eaff;
    display: flex;
    align-items: center;
    gap: 10px;
}

/* === PERFECT ROW ALIGNMENT: 4 equal columns === */
.last-decision-grid {
    display: grid !important;
    grid-template-columns: repeat(4, minmax(240px, 1fr)) !important;
    gap: 20px !important;
    width: 100%;
}

/* Item styling */
.last-decision-item {
    background: #111;
    border: 1px solid #2a2a2a;
    border-radius: 12px;
    padding: 16px 18px;
    min-height: 110px;
    color: #ddd;
    font-size: 1rem;
    box-shadow: inset 0 0 6px rgba(255,255,255,0.03);
    transition: all 0.25s ease;
}

.last-decision-item:hover {
    background: #1a1a1a;
    border-color: #00eaff;
    transform: translateY(-2px);
}

/* Tablet (2 per row) */
@media (max-width: 1024px) {
    .last-decision-grid {
        grid-template-columns: repeat(2, 1fr) !important;
    }
}

/* Mobile (1 per row) */
@media (max-width: 600px) {
    .last-decision-grid {
        grid-template-columns: 1fr !important;
    }
}


/* Row wrapper for chart + summary side by side */
.dash-row {
    display: flex;
    gap: 20px;
    width: 100%;
    margin-top: 20px;
}

/* Each column */
.dash-col {
    flex: 1;                  /* equal width */
    display: flex;
    flex-direction: column;
}

/* Make cards full width inside columns */
.dash-col .card {
    width: 100%;
}


/* Place two cards in a row */
.two-card-row {
  display: flex;
  gap: 20px;
  align-items: flex-start;
  justify-content: space-between;
  width: 100%;
  margin-top: 30px;
  margin-bottom: 30px;
}

/* Ensure equal width & responsiveness */
.two-card-row .card {
  flex: 1;
  min-width: 350px;
}


/* Premium textbox styling */
.card input,
.card select {
  width: 100%;
  padding: 10px 12px;
  margin-top: 6px;
  margin-bottom: 12px;

  background: rgba(255, 255, 255, 0.05);
  border: 1px solid rgba(0, 255, 255, 0.3);
  border-radius: 8px;

  color: #e0e0e0;
  font-size: 14px;

  transition: all 0.25s ease;
}

/* Focus effect */
.card input:focus,
.card select:focus {
  outline: none;
  border-color: #00eaff;
  box-shadow: 0 0 10px rgba(0, 255, 255, 0.4);
  background: rgba(255, 255, 255, 0.08);
}

/* Improve label spacing */
.card label {
  margin-top: 10px;
  display: block;
  font-size: 14px;
  font-weight: 600;
  color: #a5f3ff;
}



/* Two-row info grid for Bot Controls */
.bot-info-grid {
  display: grid;
  grid-template-columns: repeat(1, 1fr);
  gap: 10px 20px;
  margin: 12px 0 16px 0;
}

.bot-info-item {
  background: rgba(255, 255, 255, 0.02);
  border: 1px solid rgba(255, 255, 255, 0.05);
  border-radius: 8px;
  padding: 8px 10px;
  font-size: 0.9rem;
  color: #cfeff4;
}

/* Highlight labels slightly */
.bot-info-item b {
  color: var(--accent);
  display: inline-block;
  width: 90px;
}

/* Responsive: 2 columns for tablets, 1 column for mobile */
@media (max-width: 900px) {
  .bot-info-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 600px) {
  .bot-info-grid {
    grid-template-columns: 1fr;
  }
}

/* === Refined Bot Card Layout === */

.bot-card {
  padding-top: 20px; /* 🆕 extra top padding */
}

/* Header: status on left, buttons on right */
.bot-card-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 20px;
  gap: 20px;
}

/* Status Pill: larger, more prominent, left-aligned */
.status-pill {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 16px;
  border-radius: 999px;
  background: rgba(255,255,255,0.05);
  border: 1px solid rgba(255,255,255,0.1);
  font-weight: 700;
  font-size: 1rem; /* increased font size */
  color: var(--muted);
  box-shadow: 0 0 10px rgba(0,255,255,0.08);
  min-width: 160px;
}

/* Animated indicator glow */
.status-pill .indicator {
  width: 14px;
  height: 14px;
  border-radius: 50%;
  background: var(--danger);
  box-shadow: 0 0 8px var(--danger);
  animation: blink 1.5s infinite;
}
.status-pill.running .indicator {
  background: #00ff88;
  box-shadow: 0 0 12px #00ff88;
}

/* Running / Stopped visual difference */
.status-pill.running {
  background: rgba(0,255,120,0.08);
  border-color: rgba(0,255,120,0.25);
  color: #00ff88;
}

.status-pill.stopped {
  background: rgba(255,80,80,0.08);
  border-color: rgba(255,80,80,0.25);
  color: #ff6666;
}

/* Button group aligned to right */
.control-buttons {
  display: flex;
  justify-content: flex-end;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}

.control-buttons button {
  min-width: 120px;
  font-size: 0.9rem;
  font-weight: 600;
  letter-spacing: 0.2px;
  box-shadow: 0 0 8px rgba(0,255,255,0.25);
  transition: all 0.2s ease-in-out;
}

.control-buttons button:hover {
  transform: translateY(-2px);
  box-shadow: 0 0 12px rgba(0,255,255,0.4);
}

/* Mobile-friendly: stack buttons below status */
@media (max-width: 700px) {
  .bot-card-header {
    flex-direction: column;
    align-items: stretch;
  }

  .control-buttons {
    justify-content: flex-start;
  }
}



/* === Enhanced "Last Decision Summary" Card === */

.last-decision-card {
  background: radial-gradient(circle at 40% 30%, rgba(0,255,255,0.06), #0a0a0a 80%);
  border: 1px solid rgba(0,255,255,0.15);
  border-radius: 14px;
  box-shadow: 0 0 25px rgba(0,255,255,0.08);
  padding: 26px;
  position: relative;
  overflow: hidden;
  transition: all 0.3s ease;
}

.last-decision-card:hover {
  box-shadow: 0 0 35px rgba(0,255,255,0.15);
  transform: translateY(-2px);
}

/* Decorative glow gradient overlay */
.last-decision-card::before {
  content: "";
  position: absolute;
  top: -40%;
  left: -30%;
  width: 160%;
  height: 160%;
  background: radial-gradient(circle, rgba(0,255,255,0.05) 0%, transparent 70%);
  pointer-events: none;
  opacity: 0.5;
}

.last-decision-title {
  color: var(--accent);
  font-size: 1.25rem;
  font-weight: 700;
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 18px;
  letter-spacing: 0.3px;
  border-bottom: 1px solid rgba(255,255,255,0.08);
  padding-bottom: 10px;
}

/* Grid layout */
.last-decision-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(100px, 1fr));
  gap: 18px 22px;
  margin-top: 20px;
}

/* Individual grid tile */
.last-decision-item {
  background: rgba(255,255,255,0.03);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 12px;
  padding: 14px 16px;
  text-align: center;
  box-shadow: inset 0 0 8px rgba(0,255,255,0.05);
  transition: all 0.25s ease-in-out;
}

.last-decision-item:hover {
  border-color: rgba(0,255,255,0.25);
  box-shadow: 0 0 15px rgba(0,255,255,0.25);
  transform: translateY(-2px);
}

/* Label text */
.last-decision-item strong {
  display: block;
  color: var(--accent);
  margin-bottom: 6px;
  font-weight: 700;
  font-size: 0.95rem;
  letter-spacing: 0.3px;
}

/* Value text */
.last-decision-item span {
  font-weight: 700;
  font-size: 1.05rem;
  color: #e6fdfd;
}

/* Highlighted box for key metric (Last Signal) */
.highlight-box {
  background: rgba(0,255,255,0.04);
  border: 1px solid rgba(0,255,255,0.25);
  box-shadow: 0 0 12px rgba(0,255,255,0.12);
}

/* Signal glow animation */
#lastSignal {
  font-size: 1.1rem;
  font-weight: 800;
  letter-spacing: 0.4px;
  text-transform: uppercase;
  color: #00ff88;
  animation: pulse-glow 2.2s infinite ease-in-out;
}

@keyframes pulse-glow {
  0%, 100% { text-shadow: 0 0 6px rgba(0,255,136,0.4); }
  50% { text-shadow: 0 0 14px rgba(0,255,136,0.9); }
}

/* Summary box wider and left-aligned */
.decision-summary-box {
  grid-column: span 2;
  text-align: left;
  background: rgba(0,255,255,0.03);
  border-left: 3px solid var(--accent);
  padding: 16px 20px;
  line-height: 1.5;
}

/* Responsive: tablet and mobile */
@media (max-width: 1100px) {
  .last-decision-grid {
    grid-template-columns: repeat(2, 1fr);
  }
  .decision-summary-box {
    grid-column: span 2;
  }
}

@media (max-width: 600px) {
  .last-decision-grid {
    grid-template-columns: 1fr;
  }
  .decision-summary-box {
    grid-column: span 1;
  }
}





/* Last Decision Summary Enhancement */
.last-decision-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 14px;
}

.summary-meta {
  display: flex;
  gap: 8px;
  align-items: center;
  flex-wrap: wrap;
}

.signal-row {
  display: flex;
  gap: 10px;
  align-items: center;
  justify-content: flex-start;
}

.small-muted {
  color: var(--muted);
  font-size: 12px;
  display: block;
  margin-top: 4px;
}

/* Pulse glow for BUY/SELL/HOLD */
.signal-buy {
  color: #00ff88 !important;
  text-shadow: 0 0 10px rgba(0, 255, 136, 0.8);
  animation: pulseGreen 1.6s infinite alternate;
}
.signal-sell {
  color: #ff6b6b !important;
  text-shadow: 0 0 10px rgba(255, 107, 107, 0.8);
  animation: pulseRed 1.6s infinite alternate;
}
.signal-hold {
  color: #ffaa00 !important;
  text-shadow: 0 0 10px rgba(255, 170, 0, 0.8);
  animation: pulseAmber 1.6s infinite alternate;
}

@keyframes pulseGreen {
  from { text-shadow: 0 0 4px rgba(0,255,120,0.4); }
  to { text-shadow: 0 0 14px rgba(0,255,120,1); }
}
@keyframes pulseRed {
  from { text-shadow: 0 0 4px rgba(255,107,107,0.4); }
  to { text-shadow: 0 0 14px rgba(255,107,107,1); }
}
@keyframes pulseAmber {
  from { text-shadow: 0 0 4px rgba(255,170,0,0.4); }
  to { text-shadow: 0 0 14px rgba(255,170,0,1); }
}

/* Sparkline Styling */
#miniSpark {
  background: linear-gradient(180deg, rgba(255,255,255,0.02), transparent);
  border-radius: 6px;
  border: 1px solid rgba(255,255,255,0.03);
  padding: 4px;
}

/* Responsive grid tweaks */
@media (max-width: 1100px) {
  .last-decision-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 600px) {
  .last-decision-grid { grid-template-columns: 1fr; }
}


.mini-summary-text {
  font-size: 13px;
  color: #bbb;
  margin-top: 6px;
  font-family: "JetBrains Mono", monospace;
}
