:root{
  --bg:#f3f6ff;
  --muted:#5b6472;
  --text:#111827;

  --accent:#5b5df7;
  --accent2:#22c55e;
  --danger:#ff3b30;

  --shadow: 0 14px 34px rgba(17, 24, 39, .12);
  --radius:22px;

  --g1: linear-gradient(135deg, #5b5df7 0%, #3b82f6 55%, #22c55e 120%);
  --g2: linear-gradient(135deg, #ff4d8d 0%, #ff8a00 55%, #ffd166 120%);
  --g3: linear-gradient(135deg, #06b6d4 0%, #3b82f6 55%, #8b5cf6 120%);
  --g4: linear-gradient(135deg, #22c55e 0%, #10b981 55%, #3b82f6 120%);
  --g5: linear-gradient(135deg, #f43f5e 0%, #fb7185 55%, #f59e0b 120%);

  --glass: rgba(255,255,255,.86);
}

*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family:"Hind Siliguri", system-ui, -apple-system, Segoe UI, Roboto, sans-serif;
  background:
    radial-gradient(1200px 600px at 10% -10%, rgba(91,93,247,.25), transparent 55%),
    radial-gradient(900px 500px at 110% 10%, rgba(255,77,141,.18), transparent 60%),
    radial-gradient(900px 500px at 40% 110%, rgba(34,197,94,.16), transparent 60%),
    var(--bg);
  color:var(--text);
}
a{color:inherit;text-decoration:none}
.hidden{display:none !important}

.app{display:flex;min-height:100vh}

/* =========================
   Desktop Sidebar
   ========================= */
.sidebar{width:290px;padding:18px;display:none}
.sideCard{
  background: var(--glass);
  border:1px solid rgba(0,0,0,.06);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  padding:16px;
  position:sticky; top:16px;
  backdrop-filter: blur(14px);
}
.brand{display:flex;align-items:center;gap:10px;margin-bottom:14px}
.logo{
  width:44px;height:44px;border-radius:16px;
  background: rgba(91,93,247,.12);
  border:1px solid rgba(0,0,0,.06);
  display:grid;place-items:center;
  font-weight:900;
  color: var(--accent);
}
.brand h1{font-size:18px;margin:0}
.brand p{margin:0;color:var(--muted);font-size:13px}

.nav{margin-top:10px;display:grid;gap:10px}
.navbtn{
  padding:12px 12px;border-radius:18px;
  border:1px solid rgba(0,0,0,.08);
  background: rgba(255,255,255,.70);
  color:var(--text);
  display:flex;align-items:center;gap:10px;
  cursor:pointer;
  transition:.18s;
  user-select:none;
}
.navbtn:hover{transform:translateY(-1px);background:rgba(255,255,255,.95)}
.navbtn.active{
  border-color: rgba(91,93,247,.35);
  box-shadow:0 0 0 4px rgba(91,93,247,.10) inset;
  background: rgba(91,93,247,.09);
}
.navIcon{width:22px;height:22px;opacity:.95}

/* =========================
   Main (Center aligned app)
   ========================= */
.main{
  flex:1;
  padding:16px 14px 110px;
  max-width:1100px;
  margin:0 auto;
  width:100%;

  display:flex;
  flex-direction:column;
  align-items:center; /* center sections */
}

/* Header (Mobile only; hidden on desktop) */
.header{
  width:100%;
  max-width:980px;
  margin:0 auto;
  background: var(--glass);
  border:1px solid rgba(0,0,0,.06);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  padding:14px;
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:12px;
  position:sticky;
  top:12px;
  z-index:10;
  backdrop-filter: blur(14px);
  text-align:center;
}
.profileMini{display:flex;align-items:center;gap:12px;cursor:pointer;min-width:0}
.avatar{
  width:46px;height:46px;border-radius:16px;
  background: rgba(0,0,0,.03);
  border:1px solid rgba(0,0,0,.08);
  overflow:hidden;
  flex:0 0 auto;
  display:grid;place-items:center;
}
.avatar img{width:100%;height:100%;object-fit:cover}
.pmeta{min-width:0}
.pname{font-weight:900;font-size:16px;line-height:1.1;margin:0}
.pdate{margin:3px 0 0;color:var(--muted);font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.logoutBtn{
  width:44px;height:44px;border-radius:16px;
  border:1px solid rgba(0,0,0,.08);
  background: rgba(255,255,255,.6);
  display:grid;place-items:center;
  cursor:pointer;
  transition:.18s;
}
.logoutBtn:hover{transform:translateY(-1px);background:rgba(255,255,255,.95)}
.icon{width:22px;height:22px;fill:none;stroke:currentColor;stroke-width:2}

/* =========================
   Cards & layout (center)
   ========================= */
.grid{display:grid; gap:12px; margin-top:12px; width:100%; max-width:980px}
.grid2{display:grid; gap:12px; width:100%}
.card{
  background: var(--glass);
  border:1px solid rgba(0,0,0,.06);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  padding:16px;
  backdrop-filter: blur(14px);
  text-align:center;
}
.card h2{margin:0 0 8px;font-size:18px}
.muted{color:var(--muted)}
.row{display:flex;gap:10px;flex-wrap:wrap;align-items:center;justify-content:center}

.badge{
  display:inline-flex;align-items:center;gap:6px;
  font-size:12px;padding:6px 10px;border-radius:999px;
  border:1px solid rgba(0,0,0,.08);
  background: rgba(255,255,255,.7);
  color:var(--muted);
  justify-content:center;
}

.btn{
  border:none;border-radius:18px;
  padding:12px 16px;
  background: var(--g1);
  color: white;font-weight:900;
  cursor:pointer;transition:.18s;
}
.btn:hover{transform:translateY(-1px); filter:saturate(1.08);}
.btn.secondary{
  background: rgba(255,255,255,.90);
  border:1px solid rgba(0,0,0,.10);
  color: var(--text);
  font-weight:800;
}
.btn.danger{
  background: rgba(255,59,48,.12);
  border:1px solid rgba(255,59,48,.30);
  color: #b42318;
}
.btn.small{padding:8px 10px;border-radius:14px;font-weight:800}
.btn:disabled{opacity:.55;cursor:not-allowed;transform:none}

label{
  display:block;
  margin:10px 0 6px;
  color:var(--muted);
  font-size:13px;
  text-align:center;
}
.input{
  width:100%;
  padding:12px 12px;
  border-radius:16px;
  border:1px solid rgba(0,0,0,.12);
  background: rgba(255,255,255,.90);
  color:var(--text);
  outline:none;
  font-size:15px;
  text-align:center;
}
.input:focus{
  box-shadow:0 0 0 4px rgba(91,93,247,.18);
  border-color: rgba(91,93,247,.45);
}

/* =========================
   Entry layout
   ========================= */
.split{display:grid;grid-template-columns:1fr;gap:12px}
.incomeGrid3{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap:10px;
}
.fieldCompact label{margin-top:0}
.fieldCompact .input{padding:11px 10px}

/* =========================
   Transaction List (keep readable)
   ========================= */
.list{display:grid;gap:10px;margin-top:10px}
.item{
  border-radius:18px;
  background: rgba(255,255,255,.86);
  border:1px solid rgba(0,0,0,.06);
  padding:12px;
  display:flex;justify-content:space-between;gap:10px;
  text-align:left; /* keep left for details */
}
.item .left{min-width:0}
.item .title{font-weight:950}
.item .sub{color:var(--muted);font-size:13px;margin-top:2px}
.item .amt{font-weight:1000;font-size:16px;text-align:right;white-space:nowrap}
.pill{
  font-size:12px;padding:4px 10px;border-radius:999px;
  border:1px solid rgba(0,0,0,.10);
  background: rgba(255,255,255,.85);
  color: var(--muted);
  display:inline-flex;gap:6px;align-items:center;
  margin-top:6px;
}
.pill.income{border-color:rgba(91,93,247,.25); color:rgba(91,93,247,.95);}
.pill.expense{border-color:rgba(255,59,48,.25); color:rgba(255,59,48,.95);}

/* =========================
   REPORT KPI — BIG + colorful (dashboard-style)
   ========================= */
.reportKpiGrid{
  display:grid;
  grid-template-columns: repeat(2, 1fr);
  gap:14px;
}
@media (min-width: 980px){
  .reportKpiGrid{grid-template-columns: repeat(4, 1fr);}
}

#reportKpis .kpiPill{
  border:0 !important;
  border-radius: 26px !important;
  box-shadow: 0 18px 44px rgba(0,0,0,.14) !important;
  min-height: 150px !important;
  padding: 18px 14px !important;
  display:flex !important;
  flex-direction:column !important;
  justify-content:center !important;
  align-items:center !important;
  text-align:center !important;
  color:#fff !important;
  position:relative;
  overflow:hidden;
}
#reportKpis .kpiPill::after{
  content:"";
  position:absolute; inset:0;
  background: rgba(0,0,0,.10);
  mix-blend-mode: overlay;
}
#reportKpis .kpiPill .k,
#reportKpis .kpiPill .v{
  position:relative;
  z-index:1;
  text-align:center !important;
}
#reportKpis .kpiPill .k{font-size:13px !important; font-weight:800 !important; opacity:.95}
#reportKpis .kpiPill .v{font-size:28px !important; font-weight:1000 !important; margin-top:10px !important; letter-spacing:.2px}

#reportKpis .kpiPill:nth-child(1){background: var(--g3) !important;} /* ব্যালেন্স */
#reportKpis .kpiPill:nth-child(2){background: var(--g4) !important;} /* আয় */
#reportKpis .kpiPill:nth-child(3){background: var(--g5) !important;} /* ব্যয় */
#reportKpis .kpiPill:nth-child(4){background: var(--g2) !important;} /* প্রফিট */

@media (min-width:980px){
  #reportKpis .kpiPill{min-height: 170px !important;}
  #reportKpis .kpiPill .v{font-size:30px !important;}
}

/* =========================
   Simple Bottom Nav (no card/border on icons)
   ========================= */
.bottomNav{
  position:fixed;left:0;right:0;bottom:0;
  padding:12px 14px 16px;
  z-index:30;
}
.dock{
  max-width:540px;
  margin:0 auto;
  background: rgba(255,255,255,.92);
  border:1px solid rgba(0,0,0,.08);
  box-shadow: 0 14px 40px rgba(0,0,0,.14);
  border-radius: 28px;
  padding:10px 10px;
  display:flex;
  gap:6px;
  justify-content:space-between;
  backdrop-filter: blur(18px);
}
.tabBtn{
  flex:1;
  border:none !important;
  background: transparent !important;
  box-shadow:none !important;
  color: var(--muted);
  padding:8px 6px;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  cursor:pointer;
  transition:.18s;
  user-select:none;
}
.tabBtn svg{width:22px;height:22px;stroke-width:2}
.tabBtn span{font-size:12px;margin-top:4px;font-weight:800}
.tabBtn.active{
  color: var(--accent);
  transform: translateY(-2px);
}
#bottomNav .tabBtn *{box-shadow:none !important}

/* =========================
   Modal / Toast / Login
   ========================= */
.modalWrap{
  position:fixed;inset:0;
  background: rgba(0,0,0,.38);
  display:none;
  align-items:center;justify-content:center;
  z-index:50;
  padding:16px;
}
.modal{
  width:min(520px, 100%);
  background: rgba(255,255,255,.94);
  border:1px solid rgba(0,0,0,.10);
  border-radius: 26px;
  box-shadow: var(--shadow);
  padding:16px;
  backdrop-filter: blur(14px);
  text-align:center;
}
.modal h3{margin:0 0 8px}
.modal .actions{display:flex;gap:10px;justify-content:flex-end;margin-top:14px}

.toast{
  position:fixed;
  left:50%;
  transform:translateX(-50%);
  bottom:120px;
  background: rgba(255,255,255,.92);
  border:1px solid rgba(0,0,0,.10);
  border-radius: 999px;
  padding:10px 14px;
  box-shadow: var(--shadow);
  display:none;
  gap:10px;
  align-items:center;
  z-index:60;
  max-width: calc(100% - 20px);
  color: var(--text);
}
.tick{
  width:22px;height:22px;border-radius:999px;
  background: rgba(34,197,94,.16);
  border:1px solid rgba(34,197,94,.40);
  display:grid;place-items:center;
  animation: pop .25s ease-out;
  color: rgba(20,110,55,1);
  font-weight:900;
}
@keyframes pop{from{transform:scale(.8);opacity:.5}to{transform:scale(1);opacity:1}}

.loginWrap{min-height:100vh;display:grid;place-items:center;padding:16px}
.loginCard{
  width:min(420px, 100%);
  border-radius: 28px;
  box-shadow: var(--shadow);
  border:1px solid rgba(0,0,0,.10);
  background: rgba(255,255,255,.92);
  padding:18px;
  backdrop-filter: blur(16px);
  text-align:center;
}
.loginCard h1{margin:0 0 6px;font-size:20px}
.loginCard p{margin:0 0 10px;color:var(--muted)}
.hint{
  margin-top:10px;
  color:var(--muted);
  font-size:13px;
  border:1px dashed rgba(0,0,0,.14);
  border-radius:18px;
  padding:10px 12px;
  background: rgba(255,255,255,.55);
}

/* Responsive */
@media (min-width: 980px){
  .sidebar{display:block}
  .main{padding:16px 14px 20px}
  .bottomNav{display:none}
  .split{grid-template-columns: 1.15fr .85fr}
  .header{display:none;}
}


/* =========================================================
   Report UI tweaks (User request)
   - Hide report title and range text (functionality unchanged)
   - Make summary KPI cards WIDE (full-width) & bigger on mobile
   ========================================================= */
#reportTitle,
#reportRangeText{
  display:none !important;
}

/* KPI grid: Mobile => 1 card per row (wide), Tablet => 2, Desktop => 4 */
#reportKpis .reportKpiGrid{
  grid-template-columns: 1fr !important;
  gap:14px !important;
}

@media (min-width: 520px){
  #reportKpis .reportKpiGrid{
    grid-template-columns: repeat(2, 1fr) !important;
  }
}

/* Bigger KPI cards */
#reportKpis .kpiPill{
  min-height: 150px !important;
  padding: 0px 0px !important;
  border-radius: 26px !important;
  width: 100% !important;
  display:flex !important;
  flex-direction:column !important;
  justify-content:center !important;
  align-items:center !important;
  text-align:center !important;
}

#reportKpis .kpiPill .k{
  font-size: 14px !important;
  font-weight: 800 !important;
  opacity: .9 !important;
}

#reportKpis .kpiPill .v{
  font-size: 32px !important;
  font-weight: 1000 !important;
  margin-top: 10px !important;
  line-height: 1.08 !important;
}

/* Desktop: keep 4 in a row */
@media (min-width: 980px){
  #reportKpis .reportKpiGrid{
    grid-template-columns: repeat(4, 1fr) !important;
    gap:16px !important;
  }
  #reportKpis .kpiPill{
    min-height: 170px !important;
    padding: 24px 16px !important;
  }
  #reportKpis .kpiPill .v{
    font-size: 34px !important;
  }
}
