/* ============================================================
   Sindh WAT — redesign design system
   Shared tokens + page styles (login first; dashboard/bulletin to follow)
   ============================================================ */
:root{
  --blue-900:#16284a; --blue-700:#1f3864; --blue-500:#2e75b6;
  --blue-100:#e8f0fb; --blue-050:#f4f8fd;
  --ink-900:#0f172a; --ink-700:#334155; --ink-500:#516074;
  --line:#e2e8f0; --line-strong:#cbd5e1; --canvas:#f6f8fb; --surface:#ffffff;
  --ok:#0f7a4d; --ok-bg:#e6f4ec; --warn:#9a6700; --warn-bg:#fbf3d8;
  --bad:#b42318; --bad-bg:#fbeae8;
  --r:10px; --r-sm:7px;
  --shadow:0 1px 2px rgba(15,23,42,.04),0 4px 16px rgba(15,23,42,.06);
}

/* ===== Login ===== */
.login-page{font-family:'Inter',system-ui,sans-serif;color:var(--ink-700);
  -webkit-font-smoothing:antialiased;margin:0}
.login-page *{box-sizing:border-box}
.login-page :focus-visible{outline:3px solid var(--blue-500);outline-offset:2px;border-radius:4px}
.login-wrap{min-height:100vh;display:grid;grid-template-columns:1.1fr .9fr}
.login-brandside{
  background:
    radial-gradient(120% 90% at 80% 10%,rgba(46,117,182,.35),transparent 55%),
    linear-gradient(160deg,var(--blue-900),var(--blue-700));
  color:#fff;padding:48px;display:flex;flex-direction:column;justify-content:space-between}
.login-brandside .drop{width:46px;height:46px;border-radius:12px;background:rgba(255,255,255,.12);
  display:grid;place-items:center;font-size:22px}
.login-brandside h1{font-size:34px;font-weight:700;letter-spacing:-.5px;line-height:1.15;margin-top:24px}
.login-brandside p{color:rgba(255,255,255,.78);max-width:32ch;margin-top:12px;font-size:15px}
.login-stats{display:flex;gap:32px}
.login-stats .v{font-size:24px;font-weight:700}
.login-stats .l{font-size:12px;color:rgba(255,255,255,.65);text-transform:uppercase;letter-spacing:.6px}
.login-formside{background:var(--surface);display:grid;place-items:center;padding:24px}
.login-card{width:min(360px,100%)}
.login-card .eyebrow{font-size:12px;font-weight:600;letter-spacing:.8px;text-transform:uppercase;color:var(--blue-500)}
.login-card h2{font-size:26px;color:var(--ink-900);font-weight:700;margin:8px 0 24px;letter-spacing:-.3px}
.field{margin-bottom:16px}
.field label{display:block;font-size:13px;font-weight:600;color:var(--ink-700);margin-bottom:6px}
.input{width:100%;height:46px;border:1.5px solid var(--line-strong);border-radius:var(--r-sm);
  padding:0 14px;font-size:15px;color:var(--ink-900);background:#fff;font-family:inherit;
  transition:border-color .15s,box-shadow .15s}
.input:focus{border-color:var(--blue-500);box-shadow:0 0 0 3px rgba(46,117,182,.15);outline:none}
.btn{height:46px;border-radius:var(--r-sm);font-weight:600;font-size:15px;font-family:inherit;cursor:pointer;
  border:none;display:inline-flex;align-items:center;justify-content:center;gap:8px;transition:background .15s}
.btn-primary{background:var(--blue-700);color:#fff;width:100%}
.btn-primary:hover{background:var(--blue-900)}
.login-error{background:var(--bad-bg);color:var(--bad);border:1px solid #f0b3ad;border-radius:var(--r-sm);
  padding:10px 14px;font-size:14px;font-weight:500;margin-bottom:16px}
.login-foot{margin-top:24px;font-size:12.5px;color:var(--ink-500);text-align:center}
@media(max-width:780px){
  .login-wrap{grid-template-columns:1fr}
  .login-brandside{display:none}
}

/* ============================================================
   AUTHENTICATED APP SHELL  (sidebar + topbar)
   Applied via <body class="app-shell"> in base.html.
   Bootstrap (Reboot) stays loaded for inner page content.
   ============================================================ */
body.app-shell{
  margin:0;font-family:'Inter',system-ui,sans-serif;background:var(--canvas);
  color:var(--ink-700);font-size:15px;line-height:1.5;-webkit-font-smoothing:antialiased;
}
.app-shell .mono,.app-shell .num{font-family:'Roboto Mono',monospace;font-variant-numeric:tabular-nums}
.app-shell :focus-visible{outline:3px solid var(--blue-500);outline-offset:2px;border-radius:4px}

.app{display:grid;grid-template-columns:248px 1fr;min-height:100vh}

/* Sidebar */
.side{background:var(--surface);border-right:1px solid var(--line);
  display:flex;flex-direction:column;position:sticky;top:0;height:100vh}
.side-brand{display:flex;align-items:center;gap:10px;padding:18px 24px;border-bottom:1px solid var(--line)}
.side-brand .drop{width:34px;height:34px;border-radius:9px;background:var(--blue-700);color:#fff;
  display:grid;place-items:center;font-size:17px}
.side-brand .t{font-weight:700;color:var(--ink-900);font-size:15px;letter-spacing:-.2px;display:block}
.side-brand .s{font-size:11px;color:var(--ink-500);display:block}
.side-nav{padding:16px 12px;overflow-y:auto;flex:1}
.nav-group{font-size:11px;font-weight:600;letter-spacing:.7px;text-transform:uppercase;
  color:var(--ink-500);padding:16px 12px 6px}
.nav-group:first-child{padding-top:0}
.side-nav .nav-item{display:flex;align-items:center;gap:11px;padding:9px 12px;border-radius:var(--r-sm);
  color:var(--ink-700);font-size:14px;font-weight:500;margin:1px 0;text-decoration:none;
  transition:background .12s,color .12s}
.side-nav .nav-item .ic{width:18px;text-align:center;opacity:.85;font-size:15px}
.side-nav .nav-item:hover{background:var(--blue-050);color:var(--blue-700)}
.side-nav .nav-item.active{background:var(--blue-700);color:#fff;font-weight:600}
.side-nav .nav-item.active .ic{opacity:1}
.side-user{border-top:1px solid var(--line);padding:14px 18px;display:flex;align-items:center;gap:11px}
.side-user .avatar{width:34px;height:34px;border-radius:50%;background:var(--blue-100);color:var(--blue-700);
  display:grid;place-items:center;font-weight:700;font-size:14px;flex:none}
.side-user .su-meta{min-width:0;flex:1}
.side-user .n{font-size:13.5px;font-weight:600;color:var(--ink-900);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.side-user .r{font-size:11.5px;color:var(--ink-500)}
.side-user .su-actions{display:flex;align-items:center;gap:4px}
.side-user .su-actions form{margin:0}
.su-btn{display:grid;place-items:center;width:30px;height:30px;border-radius:7px;border:none;background:none;
  color:var(--ink-500);font-size:15px;cursor:pointer;text-decoration:none;transition:background .12s,color .12s}
.su-btn:hover{background:var(--blue-050);color:var(--blue-700)}

/* Main + topbar */
.main{min-width:0;display:flex;flex-direction:column}
.topbar{background:rgba(246,248,251,.85);backdrop-filter:blur(8px);position:sticky;top:0;z-index:5;
  border-bottom:1px solid var(--line);padding:14px 32px;
  display:flex;align-items:center;justify-content:space-between;gap:16px}
.topbar .crumb{font-size:12.5px;color:var(--ink-500)}
.topbar h1{font-size:21px;color:var(--ink-900);font-weight:700;letter-spacing:-.4px;margin:1px 0 0}
.topbar-actions{display:flex;align-items:center;gap:12px;flex-wrap:wrap;justify-content:flex-end}
.date-ctl{display:flex;align-items:center;gap:8px;background:#fff;border:1.5px solid var(--line-strong);
  border-radius:var(--r-sm);padding:5px 12px;font-size:13.5px;color:var(--ink-700);font-weight:500}
.date-ctl input{border:none;font-family:'Roboto Mono',monospace;font-size:13.5px;color:var(--ink-900);background:none;padding:2px}
.date-ctl input:focus{outline:none}
.btn-ghost{border:1.5px solid var(--line-strong);background:#fff;color:var(--ink-700);
  height:38px;padding:0 14px;border-radius:var(--r-sm);font-weight:600;font-size:13.5px;
  display:inline-flex;align-items:center;gap:7px;text-decoration:none;cursor:pointer}
.btn-ghost:hover{border-color:var(--blue-500);color:var(--blue-700)}
.tb-chip{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:600;
  padding:4px 10px;border-radius:999px;background:var(--blue-050);color:var(--blue-700)}
.content{padding:28px 32px;max-width:1340px;width:100%}

/* ===== KPI strip (3 decision numbers) ===== */
.kpis{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:8px}
.kpi{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);padding:22px 24px;
  box-shadow:var(--shadow);position:relative;overflow:hidden}
.kpi .accent{position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--blue-500)}
.kpi .k-label{font-size:12.5px;font-weight:600;color:var(--ink-500);display:flex;align-items:center;gap:7px}
.kpi .k-value{font-size:38px;font-weight:700;color:var(--ink-900);letter-spacing:-1.5px;margin-top:10px;line-height:1;
  font-family:'Roboto Mono',monospace;font-variant-numeric:tabular-nums}
.kpi .k-unit{font-size:15px;font-weight:600;color:var(--ink-500);margin-left:6px;letter-spacing:0;font-family:'Inter',sans-serif}
.kpi .k-sub{font-size:12.5px;color:var(--ink-500);margin-top:10px}
.kpi.is-bad .accent{background:var(--bad)} .kpi.is-bad .k-value{color:var(--bad)}
.kpi.is-warn .accent{background:var(--warn)}
.kpi.is-ok .accent{background:var(--ok)}
.kpi.is-info .accent{background:var(--blue-500)}
.pill{display:inline-flex;align-items:center;gap:5px;font-size:12px;font-weight:600;
  padding:3px 9px;border-radius:999px;margin-top:12px}
.pill.bad{background:var(--bad-bg);color:var(--bad)}
.pill.warn{background:var(--warn-bg);color:var(--warn)}
.pill.ok{background:var(--ok-bg);color:var(--ok)}
.pill.info{background:var(--blue-100);color:var(--blue-700)}

/* ============================================================
   THEME OVERRIDES — let existing Bootstrap dashboard markup
   adopt the redesign palette without rewriting data wiring.
   ============================================================ */
.app-shell .card{border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--shadow);overflow:hidden}
.app-shell .card-header-gov{
  background:linear-gradient(135deg,var(--blue-900),var(--blue-700));
  color:#fff;font-weight:700;font-size:.84rem;letter-spacing:.2px;border:none;padding:.6rem .9rem}
.app-shell .barrage-header,
.app-shell .reg-header{
  background:linear-gradient(135deg,var(--blue-900),var(--blue-700));border:none}
.app-shell .sindh-total-bar,
.app-shell .fc-key-bar{background:linear-gradient(135deg,var(--blue-900),var(--blue-700));border-radius:var(--r-sm)}
.app-shell .maf-section{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--shadow);padding:16px 18px}
.app-shell .maf-section-title{color:var(--blue-700)}
.app-shell .chart-card-title{background:var(--blue-050);color:var(--blue-700);border-bottom:1px solid var(--line)}
.app-shell table{font-variant-numeric:tabular-nums}
.app-shell .table>:not(caption)>*>*{padding-top:.45rem;padding-bottom:.45rem}
/* legacy KPI cards (if any remain) */
.app-shell .kpi-card{border:1px solid var(--line);border-left:4px solid var(--blue-500);border-radius:var(--r);box-shadow:var(--shadow)}

/* ===== Responsive: stack the shell on narrow screens ===== */
@media(max-width:980px){
  .app{grid-template-columns:1fr}
  .side{position:static;height:auto;border-right:none;border-bottom:1px solid var(--line)}
  .side-nav{display:flex;flex-wrap:wrap;gap:4px;padding:10px 12px}
  .side-nav .nav-group{width:100%;padding:6px 8px 2px}
  .side-nav .nav-item{margin:0}
  .topbar{padding:12px 16px;flex-wrap:wrap}
  .content{padding:18px 16px}
  .kpis{grid-template-columns:1fr}
}
