.wrap { width: 100%; padding: 22px 28px 48px; }

/* Topbar */
.topbar {
  position: sticky; top: 0; z-index: 10;
  background: var(--topbar-bg);
  backdrop-filter: blur(16px);
  border-bottom: 1px solid var(--line);
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.05);
  transition: background-color 0.3s ease, border-color 0.3s ease;
}
.topbar-inner {
  width: 100%; padding: 14px 28px;
  display: flex; gap: 14px; align-items: center; justify-content: space-between;
}
.brand { display: flex; align-items: center; gap: 12px; font-weight: 800; letter-spacing: -0.5px; }
.brand .mark {
  width: 38px; height: 38px; border-radius: 10px;
  background: var(--primary);
  display: flex; align-items: center; justify-content: center;
  color: white;
  box-shadow: 0 4px 15px var(--primary-glow);
}
.brand .name { font-size: 16px; line-height: 1; color: var(--text); }
.top-actions { display: flex; gap: 10px; align-items: center; flex-wrap: wrap; justify-content: flex-end; }

/* Main grid */
.grid {
  display: grid;
  grid-template-columns: 1.2fr 1fr;
  gap: 16px;
  transition: all 0.3s ease;
}
.grid[data-layout="transactions"] { grid-template-columns: 1fr; }
.grid[data-layout="transactions"] #accountsPanel { display: none !important; }
.grid[data-layout="accounts"] { grid-template-columns: 1fr; }
.grid[data-layout="accounts"] #transactionsPanel { display: none !important; }

/* Panel */
.panel {
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  overflow: hidden;
  margin-bottom: 16px;
  transition: background-color 0.3s ease, border-color 0.3s ease;
}
.panel-h {
  padding: 18px 20px 14px;
  display: flex; align-items: center; justify-content: space-between; gap: 12px;
  border-bottom: 1px solid var(--line);
  background: var(--panel-h-bg);
}
.panel-title { display: flex; flex-direction: column; gap: 4px; }
.panel-title h2 { margin: 0; font-size: 16px; font-weight: 700; color: var(--text); letter-spacing: -0.3px; }
.panel-title p  { margin: 0; font-size: 12px; color: var(--muted); font-weight: 500; }
.panel-b { padding: 24px; }

/* KPIs */
.kpis {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 16px;
}
.kpi {
  border-radius: var(--radius2);
  border: 1px solid var(--line);
  background: var(--panel-h-bg);
  position: relative; overflow: hidden;
  box-shadow: var(--shadow);
  display: flex; flex-direction: column;
  cursor: default;
  transition: transform 0.3s cubic-bezier(0.34, 1.56, 0.64, 1), box-shadow 0.3s ease, border-color 0.3s ease;
}
.kpi-bar {
  height: 3px; width: 100%; flex-shrink: 0;
}
.kpi-body {
  padding: 22px 22px 20px;
  display: flex; flex-direction: column; gap: 6px;
  position: relative; z-index: 1; flex: 1;
}
.kpi-meta {
  display: flex; align-items: center; justify-content: space-between; margin-bottom: 4px;
}
.kpi-label {
  font-size: 13px; font-weight: 600; text-transform: none;
  letter-spacing: 0; color: var(--muted);
}
.kpi-icon {
  width: 30px; height: 30px; border-radius: 8px;
  display: flex; align-items: center; justify-content: center;
  font-size: 13px;
  transition: transform 0.4s cubic-bezier(0.34, 1.56, 0.64, 1);
}
.kpi .kpi-value {
  font-size: 42px; font-weight: 700; letter-spacing: -0.03em; line-height: 1;
}
.kpi-sub {
  font-size: 13px; color: var(--muted); font-weight: 400; margin-top: 6px;
}
.kpi-bg-icon {
  position: absolute; bottom: -10px; right: -6px;
  font-size: 80px; opacity: 0.055; pointer-events: none;
  transition: opacity 0.3s ease, transform 0.4s ease;
}
/* Hover */
.kpi:hover { transform: translateY(-5px) scale(1.015); }
.kpi:hover .kpi-bg-icon { opacity: 0.1; transform: scale(1.08) rotate(-6deg); }
.kpi:hover .kpi-icon    { transform: rotate(14deg) scale(1.15); }
/* Bar gradients */
.kpi.red    .kpi-bar { background: linear-gradient(90deg, var(--danger),  #ff6b6b); }
.kpi.green  .kpi-bar { background: linear-gradient(90deg, var(--success), #34d399); }
.kpi.blue   .kpi-bar { background: linear-gradient(90deg, var(--info),    #38bdf8); }
.kpi.orange .kpi-bar { background: linear-gradient(90deg, var(--warning), #fbbf24); }
/* Icon badges */
.kpi.red    .kpi-icon { background: var(--danger-bg);             color: var(--danger);  }
.kpi.green  .kpi-icon { background: var(--success-bg);            color: var(--success); }
.kpi.blue   .kpi-icon { background: rgba(14, 165, 233, 0.15);     color: var(--info);    }
.kpi.orange .kpi-icon { background: var(--warning-bg);            color: var(--warning); }
/* Value colors */
.kpi.red    .kpi-value { color: var(--danger-text,  var(--danger));  }
.kpi.green  .kpi-value { color: var(--success-text, var(--success)); }
.kpi.blue   .kpi-value { color: var(--info);    }
.kpi.orange .kpi-value { color: var(--warning); }
/* Hover glow by color */
.kpi.red:hover    { border-color: var(--danger);  box-shadow: 0 20px 40px -8px rgba(239,  68,  68, 0.22), var(--shadow); }
.kpi.green:hover  { border-color: var(--success); box-shadow: 0 20px 40px -8px rgba( 16, 185, 129, 0.22), var(--shadow); }
.kpi.blue:hover   { border-color: var(--info);    box-shadow: 0 20px 40px -8px rgba( 14, 165, 233, 0.22), var(--shadow); }
.kpi.orange:hover { border-color: var(--warning); box-shadow: 0 20px 40px -8px rgba(245, 158,  11, 0.22), var(--shadow); }

/* Charts */
.widgets {
  margin-top: 16px;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
  align-items: stretch;
}
.chart-box { height: 300px; }
.chart-box canvas { width: 100% !important; height: 100% !important; }

/* Responsive */
@media (max-width: 1200px) {
  .grid    { grid-template-columns: 1fr; }
  .widgets { grid-template-columns: 1fr; }
}
@media (max-width: 860px) {
  .kpis         { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .topbar-inner { flex-direction: column; align-items: stretch; }
  .top-actions  { justify-content: space-between; }
}
