/* ============================================================
   Alberta Talent Connect — Demo design system
   Palette mirrors the production app (navy #003366 / gold #C9A227)
   ============================================================ */
:root{
  --navy:#003366; --navy-700:#012a52; --navy-900:#001b35;
  --gold:#C9A227; --gold-soft:#f3ead0;
  --success:#22863A; --warning:#B45309; --error:#B91C1C; --info:#1D4ED8;
  --ink:#0f172a; --muted:#64748b; --line:#e2e8f0; --line-2:#eef2f7;
  --bg:#f1f5f9; --panel:#ffffff; --shadow:0 1px 3px rgba(15,23,42,.08),0 1px 2px rgba(15,23,42,.04);
  --shadow-lg:0 12px 32px rgba(15,23,42,.16);
  --radius:14px; --radius-sm:9px; --pill:999px;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{font-family:'Segoe UI',system-ui,-apple-system,Roboto,Helvetica,Arial,sans-serif;background:var(--bg);color:var(--ink);font-size:14px;line-height:1.5}
a{color:var(--info);text-decoration:none}
button{font-family:inherit;cursor:pointer}
h1,h2,h3,h4{margin:0;line-height:1.25}
.muted{color:var(--muted)}
.small{font-size:12px}
.tiny{font-size:11px}
.center{text-align:center}
.mono{font-family:ui-monospace,SFMono-Regular,Menlo,monospace}
.hide{display:none !important}

/* ---------- layout shell ---------- */
.shell{display:flex;min-height:100vh}
.sidebar{width:248px;background:linear-gradient(180deg,var(--navy) 0%,var(--navy-900) 100%);color:#fff;flex-shrink:0;display:flex;flex-direction:column;position:sticky;top:0;height:100vh;overflow-y:auto}
.sidebar .brand{display:flex;align-items:center;gap:10px;padding:18px 18px 14px;border-bottom:1px solid rgba(255,255,255,.1)}
.sidebar .brand .logo{width:34px;height:34px;border-radius:9px;background:var(--gold);color:var(--navy-900);display:flex;align-items:center;justify-content:center;font-weight:800;font-size:16px}
.sidebar .brand b{font-size:13px;font-weight:700;line-height:1.2}
.sidebar .brand span{font-size:10.5px;opacity:.7}
.nav-group{padding:10px 10px 2px}
.nav-group .nav-label{font-size:10px;text-transform:uppercase;letter-spacing:.08em;opacity:.55;padding:8px 10px 4px}
.nav-item{display:flex;align-items:center;gap:10px;padding:9px 11px;border-radius:9px;color:#dbe4ee;font-weight:500;font-size:13px;cursor:pointer;border:none;background:none;width:100%;text-align:left}
.nav-item:hover{background:rgba(255,255,255,.08);color:#fff}
.nav-item.active{background:rgba(201,162,39,.18);color:#fff;box-shadow:inset 3px 0 0 var(--gold)}
.nav-item .ic{width:18px;text-align:center;opacity:.9}
.nav-badge{margin-left:auto;background:var(--gold);color:var(--navy-900);font-size:10px;font-weight:800;border-radius:var(--pill);padding:1px 7px}
.sidebar-foot{margin-top:auto;padding:12px;font-size:10.5px;opacity:.55;border-top:1px solid rgba(255,255,255,.08)}

.main{flex:1;min-width:0;display:flex;flex-direction:column}
.topbar{height:60px;background:var(--panel);border-bottom:1px solid var(--line);display:flex;align-items:center;gap:14px;padding:0 22px;position:sticky;top:0;z-index:40}
.topbar .crumb{font-weight:700;font-size:15px}
.topbar .crumb small{display:block;font-weight:500;color:var(--muted);font-size:11px}
.topbar .spacer{flex:1}
.content{padding:24px;max-width:1280px;width:100%;margin:0 auto}

/* role switcher */
.rolepick{display:flex;align-items:center;gap:9px;border:1px solid var(--line);border-radius:var(--pill);padding:4px 10px 4px 5px;background:#fff;cursor:pointer}
.rolepick:hover{border-color:var(--navy)}
.avatar{width:32px;height:32px;border-radius:50%;background:var(--navy);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:12px;flex-shrink:0}
.avatar.lg{width:44px;height:44px;font-size:15px}
.rolepick .who{line-height:1.15}
.rolepick .who b{font-size:12.5px}
.rolepick .who span{font-size:10.5px;color:var(--muted);display:block}

/* bell */
.iconbtn{position:relative;width:38px;height:38px;border-radius:10px;border:1px solid var(--line);background:#fff;display:flex;align-items:center;justify-content:center;font-size:17px}
.iconbtn:hover{background:var(--line-2)}
.iconbtn .dot{position:absolute;top:-5px;right:-5px;background:var(--error);color:#fff;font-size:10px;font-weight:800;border-radius:var(--pill);min-width:17px;height:17px;display:flex;align-items:center;justify-content:center;padding:0 4px;border:2px solid #fff}

/* dropdown panel */
.panel-pop{position:absolute;top:52px;right:22px;width:380px;max-height:70vh;overflow:auto;background:#fff;border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-lg);z-index:60}
.panel-pop .ph{padding:12px 16px;border-bottom:1px solid var(--line);font-weight:700;display:flex;align-items:center;justify-content:between}
.notif{display:flex;gap:10px;padding:11px 16px;border-bottom:1px solid var(--line-2)}
.notif:hover{background:var(--line-2)}
.notif.unread{background:#f0f6ff}
.notif .ni{width:30px;height:30px;border-radius:8px;background:var(--gold-soft);color:var(--navy);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.notif .nb b{font-size:12.5px}
.notif .nb p{margin:2px 0 0;font-size:12px;color:var(--muted)}
.notif .nt{font-size:10.5px;color:var(--muted);margin-top:3px}

/* ---------- cards & sections ---------- */
.card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow)}
.card.pad{padding:18px}
.card-h{padding:14px 18px;border-bottom:1px solid var(--line);display:flex;align-items:center;gap:10px}
.card-h h3{font-size:14.5px;font-weight:700}
.card-h .spacer{flex:1}
.card-b{padding:18px}
.grid{display:grid;gap:16px}
.g2{grid-template-columns:repeat(2,1fr)}
.g3{grid-template-columns:repeat(3,1fr)}
.g4{grid-template-columns:repeat(4,1fr)}
@media(max-width:1100px){.g4{grid-template-columns:repeat(2,1fr)}.g3{grid-template-columns:repeat(2,1fr)}}
@media(max-width:720px){.g2,.g3,.g4{grid-template-columns:1fr}}
.row{display:flex;gap:12px;align-items:center}
.row.wrap{flex-wrap:wrap}
.between{justify-content:space-between}
.stack{display:flex;flex-direction:column;gap:14px}

.page-h{display:flex;align-items:flex-start;gap:14px;margin-bottom:20px}
.page-h h1{font-size:22px;font-weight:800}
.page-h p{color:var(--muted);margin:3px 0 0;font-size:13px}

/* KPI */
.kpi{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:16px;box-shadow:var(--shadow);cursor:default}
.kpi.click{cursor:pointer;transition:.12s}
.kpi.click:hover{border-color:var(--navy);transform:translateY(-2px);box-shadow:var(--shadow-lg)}
.kpi .kl{font-size:11.5px;color:var(--muted);font-weight:600;text-transform:uppercase;letter-spacing:.03em}
.kpi .kv{font-size:28px;font-weight:800;margin-top:6px;color:var(--navy)}
.kpi .kf{font-size:11.5px;margin-top:4px;color:var(--muted)}
.kpi .kf.up{color:var(--success)}
.kpi .ki{float:right;width:38px;height:38px;border-radius:10px;background:var(--gold-soft);color:var(--navy);display:flex;align-items:center;justify-content:center;font-size:18px}

/* ---------- buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:7px;border-radius:var(--pill);border:1px solid var(--line);background:#fff;color:var(--ink);padding:8px 15px;font-weight:600;font-size:13px;white-space:nowrap}
.btn:hover{background:var(--line-2)}
.btn.primary{background:var(--navy);border-color:var(--navy);color:#fff}
.btn.primary:hover{background:var(--navy-700)}
.btn.gold{background:var(--gold);border-color:var(--gold);color:var(--navy-900)}
.btn.gold:hover{filter:brightness(.96)}
.btn.danger{background:#fff;border-color:#f3c9c9;color:var(--error)}
.btn.danger:hover{background:#fdecec}
.btn.ghost{border-color:transparent;background:transparent}
.btn.sm{padding:5px 11px;font-size:12px}
.btn.block{width:100%;justify-content:center}
.btn:disabled{opacity:.5;cursor:not-allowed}

/* ---------- badges ---------- */
.badge{display:inline-flex;align-items:center;gap:5px;border-radius:var(--pill);padding:3px 10px;font-size:11.5px;font-weight:700;background:var(--line-2);color:var(--ink)}
.badge.navy{background:#e2ecf7;color:var(--navy)}
.badge.green{background:#e3f3e8;color:var(--success)}
.badge.amber{background:#fbeedd;color:var(--warning)}
.badge.red{background:#fbe3e3;color:var(--error)}
.badge.blue{background:#e4ecfd;color:var(--info)}
.badge.gold{background:var(--gold-soft);color:#8a6d12}
.badge.purple{background:#efe6fb;color:#6b21a8}
.badge.gray{background:#eef2f7;color:var(--muted)}
.dot-i{width:8px;height:8px;border-radius:50%;display:inline-block}

/* ---------- tables ---------- */
.table{width:100%;border-collapse:collapse;font-size:13px}
.table th{text-align:left;font-size:11px;text-transform:uppercase;letter-spacing:.04em;color:var(--muted);padding:10px 14px;border-bottom:1px solid var(--line);background:#fafbfd;font-weight:700}
.table td{padding:11px 14px;border-bottom:1px solid var(--line-2);vertical-align:middle}
.table tr:last-child td{border-bottom:none}
.table tr.click{cursor:pointer}
.table tr.click:hover td{background:#f6f9fd}
.table .nm{font-weight:600}

/* ---------- forms ---------- */
.field{margin-bottom:14px}
.field label{display:block;font-size:12.5px;font-weight:600;margin-bottom:5px}
.field label .req{color:var(--error);margin-left:2px}
.input,.select,.textarea{width:100%;border:1px solid var(--line);border-radius:var(--radius-sm);padding:9px 11px;font-size:13px;font-family:inherit;background:#fff;color:var(--ink)}
.input:focus,.select:focus,.textarea:focus{outline:none;border-color:var(--navy);box-shadow:0 0 0 3px rgba(0,51,102,.1)}
.textarea{min-height:90px;resize:vertical}
.input.err,.select.err,.textarea.err{border-color:var(--error);box-shadow:0 0 0 3px rgba(185,28,28,.1)}
.err-msg{color:var(--error);font-size:11.5px;margin-top:4px;font-weight:600}
.help{font-size:11.5px;color:var(--muted);margin-top:4px}
.checkrow{display:flex;align-items:center;gap:8px;font-size:13px;margin-bottom:7px}
.checkrow input{width:16px;height:16px;accent-color:var(--navy)}

/* wizard steps */
.steps{display:flex;gap:6px;margin-bottom:22px;flex-wrap:wrap}
.step{flex:1;min-width:120px;border-top:3px solid var(--line);padding-top:9px}
.step.done{border-color:var(--success)}
.step.active{border-color:var(--gold)}
.step .sn{font-size:10.5px;color:var(--muted);font-weight:700;text-transform:uppercase}
.step .st{font-size:12.5px;font-weight:600;margin-top:1px}

/* timeline / approval chain */
.chain{display:flex;flex-direction:column;gap:0}
.chain .node{display:flex;gap:12px;position:relative;padding-bottom:18px}
.chain .node:not(:last-child)::before{content:'';position:absolute;left:13px;top:28px;bottom:0;width:2px;background:var(--line)}
.chain .node .nc{width:28px;height:28px;border-radius:50%;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:800;background:var(--line-2);color:var(--muted);border:2px solid #fff;box-shadow:0 0 0 1px var(--line)}
.chain .node.done .nc{background:var(--success);color:#fff;box-shadow:none}
.chain .node.active .nc{background:var(--gold);color:var(--navy-900);box-shadow:none}
.chain .node .nb b{font-size:13px}
.chain .node .nb p{margin:1px 0 0;font-size:12px;color:var(--muted)}

/* activity feed */
.feed .fi{display:flex;gap:11px;padding:11px 0;border-bottom:1px solid var(--line-2)}
.feed .fi:last-child{border:none}
.feed .fi .fd{width:30px;height:30px;border-radius:8px;background:var(--gold-soft);color:var(--navy);display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:14px}
.feed .fi .fb b{font-size:12.5px}
.feed .fi .fb p{margin:2px 0 0;font-size:12px;color:var(--muted)}

/* tabs */
.tabs{display:flex;gap:4px;border-bottom:1px solid var(--line);margin-bottom:18px;flex-wrap:wrap}
.tab{padding:9px 15px;font-weight:600;font-size:13px;color:var(--muted);border:none;background:none;border-bottom:2px solid transparent;margin-bottom:-1px}
.tab:hover{color:var(--ink)}
.tab.active{color:var(--navy);border-color:var(--gold)}

/* modal */
.modal-bg{position:fixed;inset:0;background:rgba(15,23,42,.5);display:flex;align-items:center;justify-content:center;z-index:80;padding:20px}
.modal{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow-lg);width:100%;max-width:560px;max-height:88vh;overflow:auto}
.modal.lg{max-width:760px}
.modal.sm{max-width:420px}
.modal-h{padding:16px 20px;border-bottom:1px solid var(--line);display:flex;align-items:center;gap:10px}
.modal-h h3{font-size:16px;font-weight:700}
.modal-h .x{margin-left:auto;border:none;background:none;font-size:20px;color:var(--muted);line-height:1}
.modal-b{padding:20px}
.modal-f{padding:14px 20px;border-top:1px solid var(--line);display:flex;gap:10px;justify-content:flex-end}

/* toast */
.toast-layer{position:fixed;top:18px;right:18px;z-index:120;display:flex;flex-direction:column;gap:10px}
.toast{background:#fff;border:1px solid var(--line);border-left:4px solid var(--navy);border-radius:10px;box-shadow:var(--shadow-lg);padding:12px 16px;min-width:280px;max-width:380px;display:flex;gap:10px;animation:slidein .2s ease}
.toast.success{border-left-color:var(--success)}
.toast.error{border-left-color:var(--error)}
.toast.warning{border-left-color:var(--warning)}
.toast b{font-size:13px}
.toast p{margin:2px 0 0;font-size:12px;color:var(--muted)}
@keyframes slidein{from{transform:translateX(20px);opacity:0}to{transform:none;opacity:1}}

/* banners */
.banner{border-radius:var(--radius-sm);padding:12px 15px;font-size:13px;display:flex;gap:10px;align-items:flex-start}
.banner.info{background:#eef4fd;color:#1e40af;border:1px solid #d3e1fb}
.banner.success{background:#eaf6ee;color:#166534;border:1px solid #cce9d5}
.banner.warning{background:#fdf3e7;color:#92400e;border:1px solid #f6e0c0}
.banner.error{background:#fdecec;color:#991b1b;border:1px solid #f6cccc}
.banner.gold{background:var(--gold-soft);color:#7a5e0e;border:1px solid #e7d39a}

/* misc */
.divider{height:1px;background:var(--line);margin:16px 0}
.pill-tabs{display:inline-flex;background:var(--line-2);border-radius:var(--pill);padding:3px}
.pill-tabs button{border:none;background:none;padding:6px 14px;border-radius:var(--pill);font-weight:600;font-size:12.5px;color:var(--muted)}
.pill-tabs button.active{background:#fff;color:var(--navy);box-shadow:var(--shadow)}
.kv-list{display:grid;grid-template-columns:auto 1fr;gap:8px 18px;font-size:13px}
.kv-list dt{color:var(--muted);font-weight:600}
.kv-list dd{margin:0;font-weight:600}
.attach{display:flex;align-items:center;gap:10px;border:1px solid var(--line);border-radius:var(--radius-sm);padding:9px 12px;margin-bottom:8px}
.attach .fic{width:30px;height:30px;border-radius:7px;background:#fbe3e3;color:var(--error);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:800}
.rating{display:inline-flex;gap:3px;font-size:20px;color:var(--gold);cursor:pointer}
.rating .star{color:var(--line);transition:.1s}
.rating .star.on{color:var(--gold)}
.progress{height:8px;background:var(--line-2);border-radius:var(--pill);overflow:hidden}
.progress > i{display:block;height:100%;background:var(--gold);border-radius:var(--pill)}

/* bar chart (reports) */
.bars{display:flex;align-items:flex-end;gap:14px;height:180px;padding-top:10px}
.bars .bar{flex:1;display:flex;flex-direction:column;align-items:center;gap:6px;justify-content:flex-end;height:100%}
.bars .bar > i{width:60%;max-width:46px;background:var(--navy);border-radius:6px 6px 0 0;display:block}
.bars .bar.alt > i{background:var(--gold)}
.bars .bar small{font-size:10.5px;color:var(--muted);text-align:center}

/* TC guide overlay */
.guide-fab{position:fixed;bottom:20px;right:20px;z-index:100;background:var(--gold);color:var(--navy-900);border:none;border-radius:var(--pill);padding:11px 18px;font-weight:800;box-shadow:var(--shadow-lg);display:flex;align-items:center;gap:8px}
.guide-panel{position:fixed;bottom:74px;right:20px;width:360px;max-height:64vh;background:#fff;border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-lg);z-index:100;display:flex;flex-direction:column;overflow:hidden}
.guide-panel .gh{background:var(--navy);color:#fff;padding:12px 16px;font-weight:700;display:flex;align-items:center}
.guide-panel .gb{overflow:auto;padding:6px}
.guide-sec{font-size:10.5px;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);font-weight:800;padding:10px 10px 4px}
.guide-tc{padding:9px 11px;border-radius:9px;cursor:pointer;font-size:12.5px;display:flex;gap:8px;align-items:flex-start}
.guide-tc:hover{background:var(--line-2)}
.guide-tc b{color:var(--navy);flex-shrink:0}
.guide-tc.done{opacity:.55}

/* login */
.login-wrap{min-height:100vh;background:linear-gradient(135deg,#001b35,#012a52 55%,#1e2a52);display:flex;flex-direction:column;color:#fff}
.login-head{display:flex;align-items:center;gap:12px;padding:22px 32px;border-bottom:1px solid rgba(255,255,255,.08)}
.login-head .logo{width:40px;height:40px;border-radius:10px;background:var(--gold);color:var(--navy-900);display:flex;align-items:center;justify-content:center;font-weight:800;font-size:18px}
.login-body{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:30px}
.login-body h1{font-size:30px;font-weight:800;text-align:center}
.login-body .sub{opacity:.7;text-align:center;margin:8px 0 26px;max-width:620px}
.role-grid{display:grid;grid-template-columns:repeat(3,minmax(200px,1fr));gap:12px;max-width:880px;width:100%}
@media(max-width:760px){.role-grid{grid-template-columns:1fr}}
.role-card{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);border-radius:var(--radius);padding:14px;text-align:left;color:#fff;transition:.12s}
.role-card:hover{background:rgba(255,255,255,.12);border-color:var(--gold);transform:translateY(-2px)}
.role-card .rc-h{display:flex;align-items:center;gap:10px}
.role-card .rc-h .avatar{background:var(--gold);color:var(--navy-900)}
.role-card b{font-size:13.5px}
.role-card .rl{font-size:11px;opacity:.75}
.role-card p{margin:9px 0 0;font-size:11.5px;opacity:.7;line-height:1.4}
.login-foot{padding:16px;text-align:center;font-size:11px;opacity:.5}
.entra{max-width:420px;width:100%;background:#fff;color:var(--ink);border-radius:var(--radius);padding:30px;text-align:center}
.entra .ms{display:flex;gap:6px;justify-content:center;margin-bottom:16px}
.entra .ms i{width:14px;height:14px;display:block}
.spin{width:44px;height:44px;border:4px solid var(--line);border-top-color:var(--navy);border-radius:50%;margin:18px auto;animation:sp 1s linear infinite}
@keyframes sp{to{transform:rotate(360deg)}}

/* careers public portal */
.careers-top{background:var(--navy);color:#fff;padding:0}
.careers-nav{display:flex;align-items:center;gap:12px;padding:14px 28px;max-width:1180px;margin:0 auto}
.careers-hero{background:linear-gradient(135deg,var(--navy),#012a52);color:#fff;padding:46px 28px}
.careers-hero .in{max-width:1180px;margin:0 auto}
.careers-hero h1{font-size:32px;font-weight:800}
.careers-hero p{opacity:.85;margin-top:8px;font-size:15px}
.search-bar{display:flex;gap:10px;margin-top:22px;background:#fff;padding:8px;border-radius:var(--radius);max-width:680px}
.search-bar input{flex:1;border:none;padding:10px 12px;font-size:14px;border-radius:8px}
.search-bar input:focus{outline:none}
.careers-body{max-width:1180px;margin:0 auto;padding:26px 28px}
.job-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:18px;box-shadow:var(--shadow);transition:.12s;cursor:pointer}
.job-card:hover{border-color:var(--navy);box-shadow:var(--shadow-lg);transform:translateY(-2px)}
.job-card h3{font-size:16px;color:var(--navy)}
.job-card .meta{display:flex;gap:14px;flex-wrap:wrap;color:var(--muted);font-size:12.5px;margin-top:8px}
.tagrow{display:flex;gap:6px;flex-wrap:wrap;margin-top:10px}
