:root{
  --bg:#f5f6fb;
  --card:#ffffff;
  --muted:#8b95a7;
  --border:#e8ebf2;
  --primary:#2563eb;
}

 body {
            background: var(--bg);
            min-height: 100vh;
            display: grid; 
            font-family: system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
        }

.login-card {
            width: 100%;
            max-width: 420px;
            background: #fff;
            border: 1px solid var(--border);
            border-radius: 14px;
            box-shadow: 0 16px 34px rgba(18, 25, 38, .10);
            padding: 22px;
        }

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


.submenu a.active{
  background: rgba(59,130,246,.10);
  border-radius: 10px;
}
.collapse-icon.rotated{
  transform: rotate(180deg);
}


/* ===== Sidebar ===== */
.sidebar{
  width:280px;
  background:#fff;
  border-right:1px solid var(--border);
  padding:18px 14px;
  transition:width .2s ease, transform .2s ease, padding .2s ease;
}
.sidebar-logo{
  height:64px;
  margin:6px 6px 14px;
  border-radius:12px;
  border:1px dashed var(--border);
  background:#fafbff;
  display:flex;
  align-items:center;
  justify-content:center;
}
.logo-placeholder{
  width:120px; height:28px; border-radius:8px; background:#eef1ff;
}
.logo-img{ max-height:42px; max-width:160px; object-fit:contain; }

.nav-section{
  font-size:11px;
  font-weight:700;
  letter-spacing:.08em;
  color:#b0b8c7;
  text-transform:uppercase;
  margin:14px 10px 8px;
}

.side-link{
  display:flex;
  align-items:center;
  gap:10px;
  padding:10px 12px;
  margin:4px 6px;
  border-radius:10px;
  color:#64748b;
  text-decoration:none;
  border:1px solid transparent;
}
.side-link:hover{ background:#f6f7ff; color:#3b4a66; }
.side-link.active{
  background:#eef2ff;
  color:#3949ff;
  border-color:#dcdcff;
  font-weight:600;
}
.side-link .icon{ width:24px; display:grid; place-items:center; opacity:.9; }
.chev{ margin-left:auto; opacity:.6; }

.submenu{ margin-left:44px; padding-left:0; list-style:none; }
.submenu a{
  display:block;
  padding:8px 10px;
  margin:4px 0;
  border-radius:10px;
  color:#74839b;
  text-decoration:none;
  font-size:14px;
}
.submenu a:hover{ background:#f3f5ff; color:#44536b; }

/* Expand icon rotate */
.collapse-icon{ transition: transform .2s ease; }
.side-link[aria-expanded="true"] .collapse-icon{ transform: rotate(180deg); }

/* Desktop collapsed sidebar */
.sidebar.is-collapsed{ width:86px; padding:18px 10px; }
.sidebar.is-collapsed .menu-text{ display:none; }
.sidebar.is-collapsed .nav-section{ margin:14px 0 8px; text-align:center; }
.sidebar.is-collapsed .side-link{ justify-content:center; margin:6px 8px; }
.sidebar.is-collapsed .chev{ display:none; }
.sidebar.is-collapsed .submenu{ display:none; }
.sidebar.is-collapsed .sidebar-logo{ height:54px; margin:6px 8px 12px; }
.sidebar.is-collapsed .logo-placeholder{ width:34px; height:34px; border-radius:10px; }
.sidebar.is-collapsed .logo-img{ max-width:34px; max-height:34px; }

/* Mobile overlay sidebar */
@media (max-width: 767.98px){
  .sidebar{
    position:fixed;
    z-index: 1040;
    height:100%;
    left:0;
    top:0;
    transform: translateX(-110%);
    box-shadow: 0 18px 60px rgba(0,0,0,.18);
    border-right: 0;
  }
  .sidebar.is-open{ transform: translateX(0); }

  .sidebar-backdrop{
    position:fixed;
    inset:0;
    background: rgba(0,0,0,.35);
    z-index:1035;
    opacity:0;
    pointer-events:none;
    transition: opacity .2s ease;
  }
  .sidebar-backdrop.is-open{
    opacity:1;
    pointer-events:auto;
  }
}

/* ===== Main ===== */
.main{ flex:1; padding:22px 18px 30px; }
.content-wrap{ max-width:980px; margin:0 auto; }

.top-card{
  background:var(--card);
  border:1px solid var(--border);
  border-radius:12px;
  padding:14px 18px;
  box-shadow:0 10px 26px rgba(18, 25, 38, .06);
}

.brand{
  font-size:12px;
  letter-spacing:.06em;
  color:#7aa3d6;
  text-transform:uppercase;
  margin:0;
}

.header-actions{ display:flex; align-items:center; gap:14px; }
.action{ position:relative; color:#7686a2; font-size:22px; text-decoration:none; }
.badge-dot{ position:absolute; top:-6px; right:-8px; font-size:11px; }
.avatar{
  width:34px; height:34px; border-radius:50%;
  display:inline-grid; place-items:center;
  background:#f1f4ff; border:1px solid var(--border);
  color:#415a77; font-weight:700;
}

.date-input-lg{
  width: 220px;
  padding: 10px 12px !important;
  border-radius: 12px;
  border: 1px solid var(--border);
  background: #fff;
  box-shadow: 0 10px 26px rgba(18, 25, 38, .06);
}

/* Mobile top bar */
.mobile-topbar{
  position: sticky;
  top: 0;
  z-index: 1030;
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 10px 12px;
  display:flex;
  align-items:center;
  gap:10px;
  box-shadow:0 10px 26px rgba(18, 25, 38, .06);
}
.mobile-brand{
  font-size:12px;
  letter-spacing:.06em;
  color:#7aa3d6;
  text-transform:uppercase;
  font-weight:700;
}
.mobile-spacer{ flex:1; }

/* Alert */
.soft-alert{
  border-radius:12px;
  border: 1px solid #ffd1cc;
  background:#ffe2df;
  color:#d94c3a;
  padding:14px 16px;
  font-size:13px;
}

/* ===== KPI Cards (match screenshot) ===== */
.kpi-card{
  background: #fff;
  border: 1px solid var(--border);
  border-radius: 14px;
  padding: 18px 18px 14px;
  box-shadow: 0 10px 26px rgba(18, 25, 38, .06);
  transition: transform .15s ease, box-shadow .15s ease;
}
.kpi-card:hover{
  transform: translateY(-1px);
  box-shadow: 0 16px 34px rgba(18, 25, 38, .10);
}

.kpi-top{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap: 14px;
}

.kpi-value{
  font-size: 28px;
  line-height: 1;
  font-weight: 500;
  color: #0f172a;
  letter-spacing: -0.02em;
}

.kpi-title{
  margin-top: 10px;
  font-size: 16px;
  font-weight: 700;
  color: #1f2a44;
}

.kpi-trend{
  margin-top: 6px;
  font-size: 13px;
  color: #7b879c;
  display:flex;
  align-items:center;
  gap: 8px;
}

.kpi-dot{
  width: 18px;
  height: 18px;
  border-radius: 999px;
  display:grid;
  place-items:center;
  font-size: 12px;
}

/* trend colors */
.kpi-up .kpi-dot{ background: rgba(34,197,94,.14); color:#16a34a; }
.kpi-down .kpi-dot{ background: rgba(239,68,68,.14); color:#dc2626; }
.kpi-flat .kpi-dot{ background: rgba(148,163,184,.22); color:#475569; }

.kpi-icon{
  width: 42px;
  height: 42px;
  border-radius: 999px;
  display:grid;
  place-items:center;
  background: #eef2ff;
  color: #2f49ff;
  font-size: 20px;
}


 /* pagination  */

 /* Template pagination (like screenshot) */
.template-pagination .page-link{
  border: 1px solid #e5e7eb;
  background: #fff;
  color: #111827;
  border-radius: 10px;
  padding: 6px 13px;
  font-weight: 500;
  box-shadow: none;
}

.template-pagination .page-item{
  margin: 0 6px;
}

.template-pagination .page-item.active .page-link{
  background: #fc9f0b;
  border-color: #d78808;
  color: #fff;
  font-weight: 700;
}

.template-pagination .page-item.disabled .page-link{
  color: #9ca3af;
  background: #fff;
}

.template-pagination .page-link:hover{
  background: #f9fafb;
  text-decoration: none;
}

.template-pagination .page-link:focus{
  box-shadow: none;
}

.template-pagination .tp-icon{
  font-size: 22px;
  line-height: 0;
  position: relative;
  top: 2px;
  margin: 0 6px;
}