/* ============================================================
   EduTrust.lk — Portal UI (admin / student / university)
   Self-contained: brand tokens included.
   ============================================================ */
:root{
  --teal:#1EA8A0;--teal-700:#178982;--teal-50:#e9f7f6;--teal-100:#d3f0ee;
  --orange:#FF7A18;--orange-600:#ef6a05;--orange-50:#fff3e9;
  --navy:#0F172A;--navy-700:#1e293b;--slate:#475569;--slate-400:#94a3b8;
  --line:#e6ebf1;--light:#F8FAFC;--white:#fff;--purple:#7c5cff;
  --font-display:'Poppins',system-ui,sans-serif;
  --font-body:'Inter',system-ui,sans-serif;
  --shadow-sm:0 1px 2px rgba(15,23,42,.06),0 1px 3px rgba(15,23,42,.04);
  --shadow:0 8px 24px rgba(15,23,42,.08);
  --shadow-lg:0 24px 60px rgba(15,23,42,.14);
}
*{box-sizing:border-box}
body{margin:0;font-family:var(--font-body);color:var(--navy);background:var(--light);-webkit-font-smoothing:antialiased}
a{text-decoration:none;color:inherit}
h1,h2,h3,h4,h5{font-family:var(--font-display);margin:0;font-weight:700;letter-spacing:-.01em}

/* ---------------- shell ---------------- */
.pshell{display:grid;grid-template-columns:258px 1fr;min-height:100vh}

/* sidebar */
.pside{background:var(--navy);color:#cbd5e1;display:flex;flex-direction:column;padding:18px 14px;position:sticky;top:0;height:100vh;overflow-y:auto}
.pside::-webkit-scrollbar{width:6px}
.pside::-webkit-scrollbar-thumb{background:rgba(255,255,255,.12);border-radius:99px}
.pbrand{display:flex;align-items:center;gap:11px;padding:6px 8px 16px}
.pbrand .mk{width:40px;height:40px;border-radius:11px;background:linear-gradient(135deg,var(--teal),var(--teal-700));display:grid;place-items:center;flex:none}
.pbrand .mk svg{width:22px;height:22px;color:#fff}
.pbrand .nm{font-family:var(--font-display);font-weight:700;font-size:18px;color:#fff;line-height:1}
.pbrand .nm span{color:var(--orange)}
.pbrand .tag{font-size:10.5px;color:#64748b;margin-top:3px;letter-spacing:.02em}
.pgroup{font-size:10.5px;letter-spacing:.13em;text-transform:uppercase;color:#5b6b85;margin:16px 10px 8px;font-weight:600}
.pnav{display:flex;flex-direction:column;gap:2px}
.pnav a{display:flex;align-items:center;gap:11px;padding:10px 12px;border-radius:10px;font-size:14px;color:#cbd5e1;font-weight:500;transition:background .15s,color .15s}
.pnav a svg{width:18px;height:18px;opacity:.82;flex:none}
.pnav a .badge{margin-left:auto;background:var(--orange);color:#fff;font-size:10px;font-weight:700;min-width:18px;height:18px;border-radius:9px;display:grid;place-items:center;padding:0 5px}
.pnav a:hover{background:rgba(255,255,255,.06);color:#fff}
.pnav a.active{background:var(--teal);color:#fff}
.pnav a.active svg{opacity:1}
.pside-foot{margin-top:auto;padding-top:14px}
.pside-user{display:flex;align-items:center;gap:10px;background:rgba(255,255,255,.05);border-radius:12px;padding:10px}
.pside-user .av{width:36px;height:36px;border-radius:50%;display:grid;place-items:center;color:#fff;font-family:var(--font-display);font-weight:700;font-size:14px;flex:none}
.pside-user .nm{font-family:var(--font-display);font-size:13px;color:#fff;line-height:1.2}
.pside-user .rl{font-size:11px;color:#94a3b8;text-transform:capitalize}
.pside-user a.out{margin-left:auto;color:#94a3b8;display:grid;place-items:center;width:30px;height:30px;border-radius:8px}
.pside-user a.out:hover{background:rgba(255,255,255,.08);color:#fff}
.pside-user a.out svg{width:16px;height:16px}

/* main */
.pmain{min-width:0;display:flex;flex-direction:column}
.ptop{height:68px;background:#fff;border-bottom:1px solid var(--line);display:flex;align-items:center;gap:18px;padding:0 28px;position:sticky;top:0;z-index:20}
.ptop .pt-label{font-family:var(--font-display);font-weight:600;font-size:13px;color:var(--slate)}
.ptop .pt-label b{color:var(--navy)}
.ptop .psearch{flex:1;max-width:380px;position:relative}
.ptop .psearch input{width:100%;border:1px solid var(--line);background:var(--light);border-radius:10px;padding:10px 14px 10px 38px;font-family:inherit;font-size:13.5px}
.ptop .psearch svg{position:absolute;left:12px;top:50%;transform:translateY(-50%);width:16px;height:16px;color:var(--slate-400)}
.ptop .pt-right{margin-left:auto;display:flex;align-items:center;gap:12px}
.ptop .icbtn{width:40px;height:40px;border-radius:11px;background:#fff;border:1px solid var(--line);display:grid;place-items:center;color:var(--slate);position:relative}
.ptop .icbtn svg{width:18px;height:18px}
.ptop .icbtn .dot{position:absolute;top:9px;right:10px;width:7px;height:7px;border-radius:50%;background:var(--orange)}
.pbody{padding:28px;flex:1}

/* page head */
.phead{margin-bottom:24px}
.phead h1{font-size:25px}
.phead h1 .wave{color:var(--orange)}
.phead p{color:var(--slate);margin-top:5px;font-size:14.5px}

/* KPI cards */
.pkpis{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-bottom:24px}
.pkpi{background:#fff;border:1px solid var(--line);border-radius:16px;padding:20px;box-shadow:var(--shadow-sm)}
.pkpi .row{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}
.pkpi .ic{width:44px;height:44px;border-radius:12px;display:grid;place-items:center;color:#fff}
.pkpi .ic svg{width:21px;height:21px}
.pkpi .delta{font-size:12px;font-weight:700;padding:3px 9px;border-radius:999px;background:#dcfce7;color:#16a34a}
.pkpi .n{font-family:var(--font-display);font-weight:700;font-size:30px;line-height:1}
.pkpi .l{font-size:13px;color:var(--slate);margin-top:4px}

/* generic card */
.pcard{background:#fff;border:1px solid var(--line);border-radius:16px;box-shadow:var(--shadow-sm)}
.pcard-h{display:flex;align-items:center;justify-content:space-between;padding:18px 20px;border-bottom:1px solid var(--line)}
.pcard-h h3{font-size:16px}
.pcard-h a{font-size:13px;color:var(--teal);font-weight:600}
.pcard-b{padding:20px}

.pgrid{display:grid;grid-template-columns:1.6fr 1fr;gap:22px}

/* "module coming soon" placeholder */
.soon{background:#fff;border:1px solid var(--line);border-radius:18px;box-shadow:var(--shadow-sm);padding:56px 40px;text-align:center;max-width:620px;margin:30px auto}
.soon .ic{width:70px;height:70px;border-radius:18px;background:var(--teal-50);color:var(--teal);display:grid;place-items:center;margin:0 auto 18px}
.soon .ic svg{width:34px;height:34px}
.soon h2{font-size:22px;margin-bottom:8px}
.soon p{color:var(--slate);font-size:14.5px;max-width:420px;margin:0 auto 18px}
.soon .pill{display:inline-block;background:var(--orange-50);color:var(--orange-600);font-family:var(--font-display);font-weight:600;font-size:13px;padding:7px 16px;border-radius:999px}

/* status note banner */
.pnote{display:flex;align-items:center;gap:12px;background:var(--teal-50);border:1px solid var(--teal-100);color:var(--teal-700);border-radius:12px;padding:13px 16px;font-size:13.5px;margin-bottom:24px}
.pnote svg{width:18px;height:18px;flex:none}

/* ---------------- login ---------------- */
.login-wrap{min-height:100vh;display:grid;grid-template-columns:1.05fr .95fr}
.login-aside{background:radial-gradient(800px 460px at 80% -10%,#1b8f88,transparent 62%),linear-gradient(160deg,#0e5f5a,#0b4f4a 55%,#0F172A);color:#fff;padding:54px;display:flex;flex-direction:column;justify-content:space-between;position:relative;overflow:hidden}
.login-aside .orb{position:absolute;width:240px;height:240px;border-radius:50%;background:rgba(255,122,24,.16);right:-50px;top:-50px}
.login-aside .lb{position:relative;z-index:2}
.login-aside .pbrand .nm{font-size:22px}
.login-aside h2{color:#fff;font-size:32px;line-height:1.12;margin-top:40px;max-width:420px}
.login-aside h2 .hl{color:var(--orange)}
.login-aside .sub{color:#bfe9e6;margin-top:16px;max-width:380px;font-size:15px}
.login-feats{position:relative;z-index:2;display:flex;flex-direction:column;gap:14px;margin-top:30px}
.login-feats div{display:flex;align-items:center;gap:11px;color:#eafffd;font-size:14.5px}
.login-feats .ck{width:24px;height:24px;border-radius:50%;background:rgba(255,255,255,.14);display:grid;place-items:center;flex:none}
.login-feats .ck svg{width:13px;height:13px;color:#7df0e6}
.login-main{display:grid;place-items:center;padding:40px}
.login-card{width:100%;max-width:400px}
.login-card h1{font-size:26px;margin-bottom:6px}
.login-card .muted{color:var(--slate);font-size:14.5px;margin-bottom:26px}
.field{margin-bottom:16px}
.field label{display:block;font-size:13px;font-weight:600;color:var(--navy);margin-bottom:7px}
.field input{width:100%;border:1.5px solid var(--line);border-radius:10px;padding:13px 14px;font-family:inherit;font-size:14.5px}
.field input:focus{outline:none;border-color:var(--teal);box-shadow:0 0 0 4px color-mix(in srgb,var(--teal) 26%,transparent)}
.login-btn{width:100%;border:none;background:var(--teal);color:#fff;font-family:var(--font-display);font-weight:600;font-size:15px;padding:14px;border-radius:10px;cursor:pointer;transition:background .15s,box-shadow .15s,transform .15s;box-shadow:0 8px 20px rgba(30,168,160,.28)}
.login-btn:hover{background:var(--teal-700);transform:translateY(-1px)}
.login-err{background:#fef2f2;border:1px solid #fecaca;color:#b91c1c;border-radius:10px;padding:12px 14px;font-size:13.5px;margin-bottom:18px}
.login-demo{margin-top:22px;border-top:1px solid var(--line);padding-top:18px;font-size:12.5px;color:var(--slate)}
.login-demo b{color:var(--navy);font-family:var(--font-display)}
.login-demo .chips{display:flex;flex-wrap:wrap;gap:7px;margin-top:9px}
.login-demo .chips button{border:1px solid var(--line);background:#fff;border-radius:8px;padding:6px 11px;font-family:inherit;font-size:12px;color:var(--navy-700);cursor:pointer}
.login-demo .chips button:hover{border-color:var(--teal);color:var(--teal)}

@media (max-width:1024px){.login-wrap{grid-template-columns:1fr}.login-aside{display:none}.pkpis{grid-template-columns:1fr 1fr}.pgrid{grid-template-columns:1fr}}
@media (max-width:820px){.pshell{grid-template-columns:1fr}.pside{display:none}}
@media (max-width:560px){.pkpis{grid-template-columns:1fr}.pbody{padding:18px}.ptop{padding:0 16px}}

/* ============================================================
   Phase 1 — toolbar, tables, forms, buttons (admin modules)
   ============================================================ */
.ptoolbar{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:20px;flex-wrap:wrap}
.ptoolbar .tl h1{font-size:23px}
.ptoolbar .tl p{color:var(--slate);font-size:14px;margin-top:4px}

.pbtn{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-display);font-weight:600;font-size:14px;border:none;border-radius:10px;padding:11px 18px;cursor:pointer;transition:background .15s,box-shadow .15s,transform .15s,border-color .15s;text-decoration:none;white-space:nowrap}
.pbtn svg{width:17px;height:17px}
.pbtn-primary{background:var(--teal);color:#fff;box-shadow:0 8px 18px rgba(30,168,160,.26)}
.pbtn-primary:hover{background:var(--teal-700);transform:translateY(-1px)}
.pbtn-orange{background:var(--orange);color:#fff;box-shadow:0 8px 18px rgba(255,122,24,.28)}
.pbtn-orange:hover{background:var(--orange-600);transform:translateY(-1px)}
.pbtn-ghost{background:#fff;color:var(--navy);border:1.5px solid var(--line)}
.pbtn-ghost:hover{border-color:var(--teal);color:var(--teal)}
.pbtn-sm{padding:7px 13px;font-size:13px;border-radius:8px}
.pbtn-danger{background:#fff;color:#dc2626;border:1.5px solid #fee2e2}
.pbtn-danger:hover{background:#fef2f2;border-color:#fecaca}

.flash{display:flex;align-items:center;gap:10px;background:#ecfdf5;border:1px solid #a7f3d0;color:#047857;border-radius:12px;padding:12px 16px;font-size:13.5px;margin-bottom:20px;font-weight:500}
.flash svg{width:18px;height:18px;flex:none}

/* table */
.ptable-wrap{background:#fff;border:1px solid var(--line);border-radius:16px;box-shadow:var(--shadow-sm);overflow:hidden}
.ptable{width:100%;border-collapse:collapse}
.ptable th{text-align:left;font-size:11.5px;letter-spacing:.05em;text-transform:uppercase;color:var(--slate);font-weight:600;padding:14px 18px;background:var(--light);border-bottom:1px solid var(--line)}
.ptable td{padding:14px 18px;border-bottom:1px solid var(--light);font-size:14px;vertical-align:middle}
.ptable tr:last-child td{border-bottom:none}
.ptable tr:hover td{background:#fbfdfd}
.cell-uni{display:flex;align-items:center;gap:12px}
.cell-uni .mk{width:40px;height:40px;border-radius:11px;display:grid;place-items:center;color:#fff;font-family:var(--font-display);font-weight:700;font-size:14px;flex:none}
.cell-uni b{font-family:var(--font-display);font-size:14.5px;display:block}
.cell-uni span{font-size:12.5px;color:var(--slate)}
.sb{font-size:11.5px;font-weight:700;padding:4px 11px;border-radius:999px}
.sb-active{background:#dcfce7;color:#16a34a}
.sb-inactive{background:#f1f5f9;color:#64748b}
.ptag{font-size:12px;font-weight:600;background:var(--teal-50);color:var(--teal-700);padding:4px 10px;border-radius:999px;white-space:nowrap}
.ptag-orange{background:var(--orange-50);color:var(--orange-600)}
.row-actions{display:flex;gap:8px;justify-content:flex-end}
.feat-star{color:var(--orange)}
.empty{padding:50px 24px;text-align:center;color:var(--slate)}
.empty svg{width:40px;height:40px;color:var(--slate-400);margin-bottom:10px}

/* form */
.pform{background:#fff;border:1px solid var(--line);border-radius:16px;box-shadow:var(--shadow-sm);padding:26px;max-width:760px}
.pform .grid2{display:grid;grid-template-columns:1fr 1fr;gap:16px 20px}
.pform .full{grid-column:1/-1}
.pform .fld{display:flex;flex-direction:column;gap:7px;margin-bottom:4px}
.pform label{font-size:13px;font-weight:600;color:var(--navy)}
.pform input,.pform select,.pform textarea{border:1.5px solid var(--line);border-radius:10px;padding:11px 13px;font-family:inherit;font-size:14px;color:var(--navy);background:#fff;width:100%}
.pform textarea{min-height:84px;resize:vertical}
.pform input:focus,.pform select:focus,.pform textarea:focus{outline:none;border-color:var(--teal);box-shadow:0 0 0 4px color-mix(in srgb,var(--teal) 24%,transparent)}
.pform .hint{font-size:12px;color:var(--slate-400)}
.pform .check{flex-direction:row;align-items:center;gap:10px}
.pform .check input{width:18px;height:18px}
.pform-actions{display:flex;gap:12px;margin-top:22px;padding-top:20px;border-top:1px solid var(--light)}
.color-row{display:flex;align-items:center;gap:10px}
.color-row input[type=color]{width:46px;height:42px;padding:3px;cursor:pointer}
@media (max-width:600px){.pform .grid2{grid-template-columns:1fr}}
