/* Internova Compliance Portal - styles */
:root{
  --navy:#0f2b46; --navy-2:#16395c; --ink:#1f2933; --muted:#64748b; --line:#e3e8ef;
  --bg:#f5f7fa; --card:#ffffff; --brand:#1f6feb; --brand-700:#1858c2;
  --green:#0f9d58; --green-bg:#e7f6ee; --amber:#b9770e; --amber-bg:#fdf3e2;
  --red:#c0392b; --red-bg:#fbeae8; --blue:#1f6feb; --blue-bg:#e8f0fe;
  --radius:12px; --shadow:0 1px 2px rgba(16,33,57,.06),0 4px 16px rgba(16,33,57,.06);
}
*{box-sizing:border-box}
body{margin:0;font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  color:var(--ink);background:var(--bg);line-height:1.55;font-size:15px}
a{color:var(--brand);text-decoration:none}
a:hover{text-decoration:underline}
h1,h2,h3{color:var(--navy);line-height:1.25}
.container{max-width:1180px;margin:24px auto;padding:0 20px}

/* top bar */
.topbar{display:flex;align-items:center;gap:18px;background:var(--navy);color:#fff;padding:0 20px;height:60px;position:sticky;top:0;z-index:50}
.brand{display:flex;align-items:center;gap:10px;color:#fff;font-weight:600}
.brand:hover{text-decoration:none}
.brand-mark{display:grid;place-items:center;width:34px;height:34px;border-radius:9px;background:var(--brand);font-weight:800}
.brand-text small{display:block;font-size:11px;font-weight:500;opacity:.7;letter-spacing:.04em;text-transform:uppercase}
.topsearch{flex:1;max-width:440px}
.topsearch input{width:100%;height:38px;border:0;border-radius:9px;padding:0 14px;background:rgba(255,255,255,.12);color:#fff;font-size:14px}
.topsearch input::placeholder{color:rgba(255,255,255,.65)}
.topsearch input:focus{outline:2px solid var(--brand);background:rgba(255,255,255,.18)}
.topnav{display:flex;align-items:center;gap:6px;margin-left:auto}
.topnav>a{color:rgba(255,255,255,.85);padding:8px 12px;border-radius:8px;font-size:14px;font-weight:500}
.topnav>a:hover{background:rgba(255,255,255,.1);text-decoration:none;color:#fff}
.usermenu{position:relative;margin-left:6px}
.avatar{display:grid;place-items:center;width:34px;height:34px;border-radius:50%;background:var(--brand);font-weight:700;cursor:pointer}
.usermenu-pop{position:absolute;right:0;top:44px;background:#fff;color:var(--ink);border:1px solid var(--line);border-radius:10px;
  box-shadow:var(--shadow);padding:12px;min-width:190px;display:none}
.usermenu:hover .usermenu-pop{display:block}
.um-name{font-weight:600}.um-role{color:var(--muted);font-size:13px;margin-bottom:8px}
.link{background:none;border:0;color:var(--brand);cursor:pointer;padding:0;font-size:14px}

/* flash */
.flash{max-width:1180px;margin:14px auto 0;padding:11px 16px;border-radius:10px;font-size:14px}
.flash-success{background:var(--green-bg);color:#0a6b3c;border:1px solid #bfe6cf}
.flash-error{background:var(--red-bg);color:#a12d1f;border:1px solid #f0ccc6}
.flash-info{background:var(--blue-bg);color:#11418f;border:1px solid #c6dafc}

/* layout helpers */
.page-head{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;margin-bottom:18px;flex-wrap:wrap}
.page-head h1{margin:0 0 2px}
.subtle{color:var(--muted)}
.grid{display:grid;gap:16px}
.cols-2{grid-template-columns:1fr 1fr}
.cols-3{grid-template-columns:repeat(3,1fr)}
.layout{display:grid;grid-template-columns:240px 1fr;gap:22px;align-items:start}
@media(max-width:860px){.layout{grid-template-columns:1fr}.cols-2,.cols-3{grid-template-columns:1fr}.topsearch{display:none}}

/* cards */
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow)}
.card.pad{padding:18px}
.stat{display:flex;flex-direction:column;gap:2px}
.stat .num{font-size:30px;font-weight:800;color:var(--navy)}
.stat .lbl{color:var(--muted);font-size:13px}

/* badges */
.badge{display:inline-block;font-size:11.5px;font-weight:600;padding:2px 9px;border-radius:999px;border:1px solid transparent;white-space:nowrap}
.badge-green{background:var(--green-bg);color:#0a6b3c}
.badge-amber{background:var(--amber-bg);color:var(--amber)}
.badge-red{background:var(--red-bg);color:var(--red)}
.badge-blue{background:var(--blue-bg);color:#11418f}
.tag{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:600;padding:3px 10px;border-radius:8px;background:#eef2f7;color:#41506b}
.tag .ic{font-size:13px}
.type-policy{background:#eaf0ff;color:#2a48b5}.type-sop{background:#e9f7f1;color:#0a7d52}
.type-form{background:#fef1e7;color:#b5651d}.type-reg{background:#eef2f7;color:#41506b}
.type-rpt{background:#f1ecfb;color:#6b3bb0}.type-tor{background:#fdeef5;color:#a8377a}
.type-dash{background:#e7f6fb;color:#0a6a87}.type-gov{background:#fff7e6;color:#9a6a00}
.type-qual{background:#e9f7ee;color:#0a6b3c}.type-strat{background:#eef2f7;color:#324a6d}
.type-other{background:#eef2f7;color:#41506b}

/* document list */
.doclist{display:flex;flex-direction:column;gap:10px}
.docrow{display:flex;align-items:flex-start;gap:14px;padding:15px 16px}
.docrow:hover{border-color:#cdd7e5}
.docrow .ic-box{flex:none;width:42px;height:42px;border-radius:10px;display:grid;place-items:center;font-size:18px}
.docrow .meta{flex:1;min-width:0}
.docrow .code{font-size:12px;font-weight:700;color:var(--muted);letter-spacing:.02em}
.docrow .ttl{font-weight:600;color:var(--navy);margin:1px 0 4px;display:block}
.docrow .ex{color:var(--muted);font-size:13px;margin:0}
.docrow .right{flex:none;display:flex;flex-direction:column;align-items:flex-end;gap:6px}

/* facets sidebar */
.facets{position:sticky;top:80px}
.facets h3{font-size:12px;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);margin:0 0 8px}
.facets .group{margin-bottom:20px}
.facets a{display:flex;justify-content:space-between;padding:6px 10px;border-radius:8px;color:var(--ink);font-size:14px}
.facets a:hover{background:#eef2f7;text-decoration:none}
.facets a.active{background:var(--brand);color:#fff;font-weight:600}
.facets a .c{color:var(--muted);font-size:12px}
.facets a.active .c{color:rgba(255,255,255,.8)}

/* document reader */
.reader{display:grid;grid-template-columns:1fr 300px;gap:26px;align-items:start}
@media(max-width:900px){.reader{grid-template-columns:1fr}}
.doc-main{background:#fff;border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:34px 40px}
.doc-body{max-width:74ch}
.doc-body h1{font-size:26px;margin:.2em 0 .5em}
.doc-body h2{font-size:19px;margin:1.4em 0 .4em;padding-bottom:.2em;border-bottom:1px solid var(--line)}
.doc-body h3{font-size:16px;margin:1.1em 0 .3em}
.doc-body p{margin:.5em 0}
.doc-body ul,.doc-body ol{margin:.5em 0 .8em 1.3em}
.doc-body li{margin:.2em 0}
.doc-body table{border-collapse:collapse;width:100%;margin:1em 0;font-size:14px}
.doc-body td,.doc-body th{border:1px solid var(--line);padding:7px 10px;text-align:left;vertical-align:top}
.doc-body tr:nth-child(even){background:#fafbfc}
.doc-aside{position:sticky;top:80px;display:flex;flex-direction:column;gap:16px}
.metalist{list-style:none;margin:0;padding:0;font-size:13.5px}
.metalist li{display:flex;justify-content:space-between;gap:12px;padding:7px 0;border-bottom:1px solid var(--line)}
.metalist li:last-child{border-bottom:0}
.metalist .k{color:var(--muted)}.metalist .v{font-weight:600;text-align:right}
.ack-banner{padding:16px;border-radius:var(--radius);border:1px solid #c6dafc;background:var(--blue-bg)}
.ack-banner.done{border-color:#bfe6cf;background:var(--green-bg)}
.ack-banner h3{margin:0 0 6px;font-size:15px}
.ack-banner p{margin:0 0 12px;font-size:13.5px;color:#33414f}

/* buttons */
.btn{display:inline-block;background:var(--brand);color:#fff;border:0;border-radius:9px;padding:10px 16px;font-size:14px;font-weight:600;cursor:pointer}
.btn:hover{background:var(--brand-700);text-decoration:none;color:#fff}
.btn.block{width:100%}
.btn.ghost{background:#fff;color:var(--navy);border:1px solid var(--line)}
.btn.ghost:hover{background:#f3f6fa}
.btn.sm{padding:7px 12px;font-size:13px}
.btn-row{display:flex;gap:10px;flex-wrap:wrap}

/* tables (admin) */
table.data{width:100%;border-collapse:collapse;background:#fff;font-size:14px}
table.data th,table.data td{padding:10px 12px;border-bottom:1px solid var(--line);text-align:left}
table.data th{color:var(--muted);font-size:12px;text-transform:uppercase;letter-spacing:.04em}
.progress{height:8px;border-radius:6px;background:#eef2f7;overflow:hidden;min-width:120px}
.progress > i{display:block;height:100%;background:var(--green)}

/* breadcrumb */
.crumb{font-size:13px;color:var(--muted);margin-bottom:12px}
.crumb a{color:var(--muted)}

/* login */
.login-wrap{min-height:100vh;display:grid;place-items:center;background:linear-gradient(135deg,#0f2b46,#16395c)}
.login-card{background:#fff;border-radius:16px;box-shadow:0 18px 50px rgba(0,0,0,.25);padding:36px;width:380px;max-width:92vw}
.login-card .lbrand{display:flex;align-items:center;gap:10px;margin-bottom:6px}
.login-card h1{font-size:20px;margin:14px 0 2px}
.field{margin:14px 0}
.field label{display:block;font-size:13px;font-weight:600;color:var(--muted);margin-bottom:6px}
.field input{width:100%;height:42px;border:1px solid var(--line);border-radius:10px;padding:0 12px;font-size:15px}
.field input:focus{outline:2px solid var(--brand);border-color:transparent}
.footer{max-width:1180px;margin:30px auto;padding:18px 20px 0;border-top:1px solid var(--line);color:var(--muted);font-size:13px;text-align:center}
.empty{padding:40px;text-align:center;color:var(--muted)}
.pill-row{display:flex;gap:8px;flex-wrap:wrap;margin-top:6px}

/* ====== organisation chart ====== */
.org-tree{--c-line:#c7d2e0}
.org-directors{display:flex;flex-direction:column;align-items:center}
.org-card{background:var(--navy);color:#fff;border-radius:12px;padding:13px 26px;text-align:center;min-width:320px;
  box-shadow:var(--shadow);display:flex;flex-direction:column;align-items:center;position:relative}
.org-card:hover{background:var(--navy-2);text-decoration:none;color:#fff}
.org-card .t{font-weight:700;letter-spacing:.02em;font-size:15px}
.org-card .s{font-size:11.5px;opacity:.82}
.org-vline{width:0;border-left:2px solid var(--c-line);height:20px}
.org-rail{height:0;border-top:2px solid var(--c-line);margin:0 12.5%;}
.org-cols{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-top:0;position:relative}
.org-div{position:relative;padding-top:18px}
.org-div::before{content:"";position:absolute;top:0;left:50%;height:18px;border-left:2px solid var(--c-line)}
.org-head{display:flex;align-items:center;gap:10px;padding:12px 14px;border-radius:11px 11px 0 0;color:#fff;position:relative}
.org-head:hover{text-decoration:none;color:#fff;filter:brightness(1.06)}
.org-head .org-ic{font-size:20px;line-height:1}
.org-head .t{font-weight:700;font-size:13.5px;display:block;line-height:1.2}
.org-head .s{font-size:11px;opacity:.85;display:block}
.org-units{border:1px solid var(--line);border-top:0;border-radius:0 0 11px 11px;background:#fff;padding:10px;display:flex;flex-direction:column;gap:10px}
.org-unit{border:1px solid var(--line);border-left:3px solid var(--accent,#cbd5e1);border-radius:9px;overflow:hidden}
.org-unit-h{display:flex;justify-content:space-between;align-items:center;gap:8px;padding:9px 11px;background:#f8fafc;color:var(--navy);font-weight:600;font-size:13px}
.org-unit-h:hover{text-decoration:none;background:#eef2f7}
.org-roles{display:flex;flex-direction:column}
.org-role{display:flex;justify-content:space-between;align-items:center;gap:8px;padding:8px 11px;font-size:12.5px;color:#41506b;border-top:1px dashed var(--line)}
.org-role:hover{text-decoration:none;background:#f5f8fc;color:var(--navy)}
.org-cnt{flex:none;background:#eef2f7;color:#41506b;border-radius:999px;font-size:11px;font-weight:700;padding:1px 8px;min-width:20px;text-align:center}
.org-head .org-cnt{background:rgba(255,255,255,.22);color:#fff}
.org-soon{flex:none;font-size:10px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:rgba(255,255,255,.78);
  border:1px solid rgba(255,255,255,.4);border-radius:999px;padding:1px 7px}
/* division colours (match Orgchart.png) */
.org-academic .org-head{background:#15695f}.org-academic{--accent:#15695f}
.org-student  .org-head{background:#3c7a3f}.org-student {--accent:#3c7a3f}
.org-quality  .org-head{background:#5a2d82}.org-quality {--accent:#5a2d82}
.org-corporate .org-head{background:#c2671c}.org-corporate{--accent:#c2671c}
@media(max-width:900px){
  .org-cols{grid-template-columns:1fr 1fr}
}
@media(max-width:560px){
  .org-cols{grid-template-columns:1fr}
  .org-rail,.org-div::before{display:none}
  .org-card{min-width:0;width:100%}
}

/* ====== systems / registers ====== */
.mono{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:12.5px}
.sys-tile{display:flex;flex-direction:column;gap:6px;position:relative;text-decoration:none;color:inherit}
.sys-tile:hover{text-decoration:none;border-color:#cdd7e5}
.sys-tile h3{margin:4px 0 0;font-size:15px;color:var(--navy)}
.sys-tile .badge{align-self:flex-start;margin-top:auto}
.sys-tile.disabled{opacity:.7}
.sys-ic{width:42px;height:42px;border-radius:11px;display:grid;place-items:center;font-size:20px}

/* lifecycle flow strip */
.flow{display:flex;align-items:stretch;gap:4px;min-width:max-content}
.flow-step{flex:1;min-width:96px;background:#f5f8fc;border:1px solid var(--line);border-radius:10px;padding:10px 12px;
  text-align:center;text-decoration:none;color:var(--ink);transition:.12s}
.flow-step:hover{text-decoration:none;border-color:var(--brand);background:#eef4ff}
.flow-step.on{background:var(--brand);border-color:var(--brand);color:#fff}
.flow-n{display:block;font-size:22px;font-weight:800;color:var(--navy);line-height:1}
.flow-step.on .flow-n{color:#fff}
.flow-l{display:block;font-size:11px;margin-top:3px;color:var(--muted)}
.flow-step.on .flow-l{color:rgba(255,255,255,.85)}
.flow-arrow{align-self:center;color:#c7d2e0;font-weight:700}

/* filter bar */
.filterbar{display:flex;gap:10px;flex-wrap:wrap;align-items:center;margin-bottom:14px}
.filterbar input[type=search]{flex:1;min-width:200px;height:38px;border:1px solid var(--line);border-radius:9px;padding:0 12px}
.filterbar select{height:38px;border:1px solid var(--line);border-radius:9px;padding:0 10px;background:#fff}

/* data table */
.sys-table tbody tr:hover{background:#f5f8fc}
.mini-bar{display:inline-block;width:70px;height:7px;border-radius:5px;background:#eef2f7;overflow:hidden;vertical-align:middle}
.mini-bar>i{display:block;height:100%;background:var(--green)}

/* stage badges */
.stage-badge{display:inline-block;font-size:11.5px;font-weight:600;padding:2px 9px;border-radius:999px;color:#fff}
.stage-lead{background:#7a8aa0}.stage-applied{background:#5b76b7}.stage-screening{background:#4f86c6}
.stage-interview{background:#3f9ec6}.stage-admitted{background:#2bb1a8}.stage-enrolled{background:#2aa37a}
.stage-training{background:#3c9a52}.stage-readiness{background:#c2862a}.stage-deployed{background:#2f8a3e}

/* stepper (student detail) */
.stepper{display:flex;flex-wrap:wrap;gap:4px}
.step{flex:1;min-width:70px;text-align:center;position:relative;padding-top:30px}
.step .dot{position:absolute;top:0;left:50%;transform:translateX(-50%);width:24px;height:24px;border-radius:50%;
  display:grid;place-items:center;font-size:12px;font-weight:700;background:#e3e8ef;color:#8a97a8;z-index:1}
.step::before{content:"";position:absolute;top:11px;left:0;right:50%;height:2px;background:#e3e8ef}
.step::after{content:"";position:absolute;top:11px;left:50%;right:0;height:2px;background:#e3e8ef}
.step:first-child::before,.step:last-child::after{display:none}
.step.done .dot{background:var(--green);color:#fff}
.step.done::before,.step.done::after,.step.active::before{background:var(--green)}
.step.active .dot{background:var(--brand);color:#fff;box-shadow:0 0 0 4px rgba(31,111,235,.18)}
.step .lbl{font-size:10.5px;color:var(--muted);display:block;line-height:1.2}
.step.active .lbl{color:var(--navy);font-weight:600}

/* key-value profile */
.kv{list-style:none;margin:0;padding:0;display:grid;grid-template-columns:1fr 1fr;gap:0 24px}
.kv li{display:flex;justify-content:space-between;gap:10px;padding:8px 0;border-bottom:1px solid var(--line);font-size:13.5px}
.kv .k{color:var(--muted)}.kv .v{font-weight:600;text-align:right}
@media(max-width:600px){.kv{grid-template-columns:1fr}}

/* timeline */
.timeline{position:relative;padding-left:6px}
.tl-item{display:flex;gap:12px;padding:0 0 14px;position:relative}
.tl-dot{flex:none;width:11px;height:11px;border-radius:50%;background:var(--brand);margin-top:4px;position:relative}
.tl-item:not(:last-child) .tl-dot::after{content:"";position:absolute;left:50%;top:11px;transform:translateX(-50%);width:2px;height:calc(100% + 8px);background:var(--line)}
.tl-head{font-size:14px}.tl-meta{font-size:12px}

/* form grid */
.form-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:0 18px}
.form-grid select{width:100%;height:42px;border:1px solid var(--line);border-radius:10px;padding:0 10px;background:#fff}
@media(max-width:760px){.form-grid{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.form-grid{grid-template-columns:1fr}}

/* charts */
.bars{display:flex;flex-direction:column;gap:9px}
.bar-row{display:grid;grid-template-columns:150px 1fr 34px;align-items:center;gap:10px;font-size:13px}
.bar-l{color:#41506b;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.bar-track{background:#eef2f7;border-radius:6px;height:14px;overflow:hidden}
.bar-track>i{display:block;height:100%;border-radius:6px;background:var(--brand)}
.bar-v{font-weight:700;color:var(--navy);text-align:right}
.fill-blue{background:#1f6feb}.fill-teal{background:#16998a}.fill-purple{background:#6b3bb0}.fill-amber{background:#c2862a}
.funnel{display:flex;flex-direction:column;gap:8px}
.fn-row{display:grid;grid-template-columns:150px 1fr;align-items:center;gap:12px}
.fn-l{font-size:13px;color:#41506b;text-align:right}
.fn-track{background:#f3f6fa;border-radius:7px;height:26px;overflow:hidden}
.fn-track>i{display:flex;align-items:center;justify-content:flex-end;height:100%;color:#fff;font-weight:700;font-size:12px;padding-right:8px;border-radius:7px;min-width:18px}
.stage-fill.stage-lead{background:#7a8aa0}.stage-fill.stage-applied{background:#5b76b7}.stage-fill.stage-screening{background:#4f86c6}
.stage-fill.stage-interview{background:#3f9ec6}.stage-fill.stage-admitted{background:#2bb1a8}.stage-fill.stage-enrolled{background:#2aa37a}
.stage-fill.stage-training{background:#3c9a52}.stage-fill.stage-readiness{background:#c2862a}.stage-fill.stage-deployed{background:#2f8a3e}
@media(max-width:600px){.bar-row{grid-template-columns:110px 1fr 30px}.fn-row{grid-template-columns:100px 1fr}}
