/* ============================================================
   NORTHCREST — Admin Console styles
   Dark "back-office" theme with the Northcrest magenta/indigo/gold accents.
   ============================================================ */
:root{
  --bg:#0c0a1b; --panel:#15122b; --panel-2:#1c1838; --line:#2a2550;
  --text:#ede9ff; --muted:#9a93c4; --dim:#6f6a93;
  --magenta:#ff3d9a; --indigo:#7c6bff; --gold:#e7b54f;
  --green:#2fd27a; --red:#ff5d75; --amber:#f0b429; --blue:#43a7ff;
  --display:'Sora',system-ui,sans-serif; --body:'Plus Jakarta Sans',system-ui,sans-serif;
  --radius:16px; --radius-sm:11px;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:var(--body); color:var(--text); background:var(--bg);
  background-image:
    radial-gradient(900px 520px at 88% -8%, rgba(124,107,255,.18), transparent 60%),
    radial-gradient(760px 480px at -6% 8%, rgba(255,61,154,.14), transparent 55%);
  background-attachment:fixed; min-height:100vh; -webkit-font-smoothing:antialiased;
}
h1,h2,h3,h4{font-family:var(--display);margin:0;letter-spacing:-.01em}
.tnum{font-variant-numeric:tabular-nums;font-feature-settings:"tnum"}
button{font-family:inherit;cursor:pointer}
a{color:inherit;text-decoration:none}

/* ---------- LOGIN ---------- */
.login-wrap{min-height:100vh;display:grid;place-items:center;padding:24px}
.login-card{
  width:100%;max-width:400px;background:linear-gradient(180deg,var(--panel),var(--panel-2));
  border:1px solid var(--line);border-radius:var(--radius);padding:38px 32px;
  box-shadow:0 40px 90px -40px rgba(0,0,0,.8);position:relative;overflow:hidden;
}
.login-card::before{content:"";position:absolute;inset:0 0 auto 0;height:3px;
  background:linear-gradient(90deg,var(--magenta),var(--indigo),var(--gold))}
.brand{display:flex;align-items:center;gap:12px;margin-bottom:24px}
.brand .logo{width:42px;height:42px;border-radius:12px;display:grid;place-items:center;
  font-family:var(--display);font-weight:800;font-size:20px;color:#fff;
  background:linear-gradient(135deg,var(--magenta),var(--indigo))}
.brand .nm{font-family:var(--display);font-weight:800;font-size:19px}
.brand .nm b{color:var(--magenta)}
.brand .tag{font-size:11px;letter-spacing:.18em;color:var(--gold);text-transform:uppercase;margin-top:2px}
.login-card h2{font-size:22px;margin-bottom:6px}
.login-card .sub{color:var(--muted);font-size:14px;margin-bottom:22px}
.field{margin-bottom:16px}
.field label{display:block;font-size:12.5px;color:var(--muted);margin-bottom:7px;font-weight:600;letter-spacing:.02em}
.input{width:100%;padding:13px 15px;border-radius:var(--radius-sm);border:1px solid var(--line);
  background:#0f0d22;color:var(--text);font-size:15px;outline:none;transition:.15s}
.input:focus{border-color:var(--indigo);box-shadow:0 0 0 3px rgba(124,107,255,.18)}
.login-err{background:rgba(255,93,117,.12);border:1px solid rgba(255,93,117,.4);color:#ffb3bf;
  padding:11px 14px;border-radius:var(--radius-sm);font-size:13.5px;margin-bottom:16px;display:none}
.login-err.show{display:block}
.login-hint{margin-top:18px;font-size:12.5px;color:var(--dim);text-align:center}

/* ---------- BUTTONS ---------- */
.btn{border:1px solid var(--line);background:var(--panel-2);color:var(--text);
  padding:10px 16px;border-radius:10px;font-weight:600;font-size:14px;transition:.15s;
  display:inline-flex;align-items:center;gap:8px;white-space:nowrap}
.btn:hover{border-color:var(--indigo);transform:translateY(-1px)}
.btn:disabled{opacity:.5;cursor:not-allowed;transform:none}
.btn-block{width:100%;justify-content:center;padding:13px}
.btn-primary{background:linear-gradient(135deg,var(--magenta),var(--indigo));border:none;color:#fff}
.btn-primary:hover{filter:brightness(1.08)}
.btn-green{background:rgba(47,210,122,.14);border-color:rgba(47,210,122,.45);color:#8af2bd}
.btn-green:hover{background:rgba(47,210,122,.22)}
.btn-red{background:rgba(255,93,117,.13);border-color:rgba(255,93,117,.42);color:#ffb3bf}
.btn-red:hover{background:rgba(255,93,117,.2)}
.btn-sm{padding:7px 12px;font-size:13px}

/* ---------- APP SHELL ---------- */
.app{display:none;min-height:100vh}
.app.show{display:grid;grid-template-columns:248px 1fr}
.side{background:rgba(13,11,30,.7);backdrop-filter:blur(8px);border-right:1px solid var(--line);
  padding:24px 16px;display:flex;flex-direction:column;gap:6px;position:sticky;top:0;height:100vh}
.side .brand{margin-bottom:26px;padding:0 8px}
.nav-item{display:flex;align-items:center;gap:12px;padding:12px 14px;border-radius:11px;
  color:var(--muted);font-weight:600;font-size:14.5px;transition:.14s;border:1px solid transparent}
.nav-item svg{width:19px;height:19px;flex:none}
.nav-item:hover{background:var(--panel);color:var(--text)}
.nav-item.active{background:linear-gradient(135deg,rgba(255,61,154,.18),rgba(124,107,255,.18));
  color:#fff;border-color:var(--line)}
.nav-item .badge{margin-left:auto;background:var(--magenta);color:#fff;font-size:11px;font-weight:700;
  min-width:20px;height:20px;border-radius:10px;display:grid;place-items:center;padding:0 6px}
.nav-spacer{flex:1}

.main{min-width:0;padding:0 0 50px}
.topbar{position:sticky;top:0;z-index:5;display:flex;align-items:center;justify-content:space-between;
  padding:18px 30px;background:rgba(12,10,27,.82);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.topbar h1{font-size:20px}
.topbar .who{display:flex;align-items:center;gap:12px;color:var(--muted);font-size:14px}
.topbar .who .av{width:36px;height:36px;border-radius:10px;display:grid;place-items:center;color:#fff;
  font-weight:700;background:linear-gradient(135deg,var(--indigo),var(--magenta))}
.content{padding:26px 30px;max-width:1180px}
.view{display:none}
.view.show{display:block;animation:fade .25s ease}
@keyframes fade{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}

/* ---------- STAT TILES ---------- */
.stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px;margin-bottom:8px}
.stat{background:linear-gradient(170deg,var(--panel),var(--panel-2));border:1px solid var(--line);
  border-radius:var(--radius);padding:20px 22px;position:relative;overflow:hidden}
.stat .k{color:var(--muted);font-size:13px;font-weight:600;margin-bottom:10px}
.stat .v{font-family:var(--display);font-weight:800;font-size:28px;letter-spacing:-.02em}
.stat .v.pink{color:var(--magenta)} .stat .v.gold{color:var(--gold)}
.stat .v.green{color:var(--green)} .stat .v.amber{color:var(--amber)}
.stat::after{content:"";position:absolute;right:-20px;bottom:-20px;width:80px;height:80px;border-radius:50%;
  background:radial-gradient(circle,rgba(124,107,255,.22),transparent 70%)}

/* ---------- PANELS / TABLES ---------- */
.panel{background:linear-gradient(180deg,var(--panel),var(--panel-2));border:1px solid var(--line);
  border-radius:var(--radius);padding:22px;margin-top:22px}
.panel-head{display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap;margin-bottom:16px}
.panel-head h2{font-size:18px}
.seg{display:inline-flex;background:#0f0d22;border:1px solid var(--line);border-radius:10px;padding:3px}
.seg button{background:none;border:none;color:var(--muted);padding:7px 14px;border-radius:8px;font-size:13.5px;font-weight:600}
.seg button.on{background:var(--panel-2);color:#fff}
.search{padding:9px 13px;border-radius:10px;border:1px solid var(--line);background:#0f0d22;color:var(--text);font-size:14px;outline:none;min-width:180px}
.search:focus{border-color:var(--indigo)}

.table-wrap{overflow:auto;border-radius:12px;border:1px solid var(--line)}
table{width:100%;border-collapse:collapse;font-size:14px;min-width:560px}
thead th{background:#0f0d22;text-align:left;padding:13px 16px;font-size:12px;letter-spacing:.04em;
  text-transform:uppercase;color:var(--dim);font-weight:700;white-space:nowrap}
tbody td{padding:14px 16px;border-top:1px solid var(--line);vertical-align:middle}
tbody tr:hover{background:rgba(124,107,255,.06)}
td .u-name{font-weight:600}
td .u-sub{color:var(--dim);font-size:12.5px}
.right{text-align:right}
.empty{text-align:center;color:var(--dim);padding:34px}
.amt{font-weight:700}
.amt.credit{color:var(--green)} .amt.debit{color:#ff96a6}

/* ---------- PILLS ---------- */
.pill{display:inline-flex;align-items:center;gap:5px;padding:4px 11px;border-radius:999px;font-size:12px;font-weight:700}
.pill::before{content:"";width:6px;height:6px;border-radius:50%;background:currentColor}
.pill.pending{background:rgba(240,180,41,.14);color:var(--amber)}
.pill.transit{background:rgba(240,180,41,.14);color:var(--amber)}
.pill.approved,.pill.completed,.pill.active{background:rgba(47,210,122,.14);color:var(--green)}
.pill.rejected,.pill.frozen{background:rgba(255,93,117,.14);color:var(--red)}
.pill.unset{background:rgba(154,147,196,.16);color:var(--muted)}
.pill-stack{display:flex;flex-direction:column;gap:6px;align-items:flex-start}
.row-actions{display:flex;gap:8px;flex-wrap:wrap}

/* ---------- MODAL ---------- */
.modal-bg{position:fixed;inset:0;background:rgba(6,5,16,.72);backdrop-filter:blur(4px);
  display:none;place-items:center;z-index:50;padding:20px}
.modal-bg.show{display:grid}
.modal{width:100%;max-width:460px;background:linear-gradient(180deg,var(--panel),var(--panel-2));
  border:1px solid var(--line);border-radius:var(--radius);padding:26px;box-shadow:0 40px 90px -40px #000;
  max-height:88vh;overflow:auto}
.modal h3{font-size:19px;margin-bottom:6px}
.modal .sub{color:var(--muted);font-size:14px;margin-bottom:18px}
.kv{display:flex;justify-content:space-between;gap:14px;padding:9px 0;border-bottom:1px solid var(--line);font-size:14px}
.kv span:first-child{color:var(--muted)}
.kv span:last-child{font-weight:600;text-align:right}
.seg-tabs{display:flex;gap:8px;margin-bottom:14px}

/* ---------- TOASTS ---------- */
.toast-wrap{position:fixed;right:18px;bottom:18px;display:flex;flex-direction:column;gap:10px;z-index:99}
.toast{background:var(--panel-2);border:1px solid var(--line);border-left:3px solid var(--green);
  color:var(--text);padding:13px 18px;border-radius:11px;font-size:14px;min-width:240px;
  box-shadow:0 20px 40px -20px #000;transition:opacity .3s}
.toast.err{border-left-color:var(--red)}

/* ---------- RESPONSIVE ---------- */
@media (max-width:880px){
  .app.show{grid-template-columns:1fr}
  .side{position:fixed;left:0;top:0;z-index:40;transform:translateX(-100%);transition:.25s;width:248px}
  .side.open{transform:none}
  .menu-btn{display:inline-flex!important}
  .content{padding:20px 16px}
  .topbar{padding:16px}
}
.menu-btn{display:none;background:var(--panel-2);border:1px solid var(--line);color:var(--text);
  width:40px;height:40px;border-radius:10px;align-items:center;justify-content:center}
