*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{--navy:#0E204A;--navy-light:#152759;--navy-lighter:#1a3068;--navy-dark:#0a1736;--gold:#B28B5D;--gold-light:#c9a87e;--gold-dim:rgba(178,139,93,0.15);--gold-border:rgba(178,139,93,0.25);--blue:#004681;--blue-light:#0a5a9e;--white:#FFF;--text-light:#E8E4DD;--text-mid:#a8b0c4;--text-muted:#7a839e;--text-faint:#515a76;--border:rgba(255,255,255,0.08);--surface:rgba(255,255,255,0.04);--surface-hover:rgba(255,255,255,0.06);--green:#4ade80;--yellow:#fbbf24;--orange:#fb923c;--red:#f87171}
html{overflow-x:hidden;overscroll-behavior:none}
body{background:var(--navy-dark);color:var(--text-light);font-family:'DM Sans','Calibri','Segoe UI',system-ui,sans-serif;min-height:100vh;line-height:1.5;overflow-x:hidden;padding-top:72px;transition:background .2s ease}
body.modal-scroll-lock{overflow:hidden}
body.light-mode{background:linear-gradient(180deg,#f8f7f4 0,#f3f5f8 46%,#e9edf4 100%);color:var(--navy)}
body.server-offline,body.light-mode.server-offline,body.apply-mode.server-offline{background:#b91c1c;color:var(--navy)}
.header{background:var(--navy);border-bottom:1px solid var(--border);display:flex;flex-direction:column;position:fixed;top:0;left:0;right:0;z-index:1000;box-shadow:0 8px 24px rgba(10,23,54,.16)}
.header-top{width:100%;min-height:72px;padding:0 32px;display:flex;align-items:center;justify-content:space-between;gap:18px;min-width:0}
.header-left{display:flex;align-items:center;gap:20px;min-width:0;flex:0 1 auto}
.header-logo{height:40px}
.header-divider{width:1px;height:32px;background:rgba(255,255,255,0.12)}
.header-title{font-size:16px;font-weight:600;color:var(--white)}
.header-sub{font-size:11px;color:var(--gold);font-weight:500;letter-spacing:.5px}
.btn{padding:12px 28px;border:none;border-radius:12px;font-size:14px;font-weight:700;cursor:pointer;transition:all .2s;font-family:inherit}
.btn-gold{background:var(--gold);color:var(--navy-dark)}.btn-gold:hover{background:var(--gold-light)}.btn-gold:disabled{background:var(--text-faint);color:var(--navy);cursor:not-allowed;opacity:.5}
.btn-blue{background:var(--blue);color:var(--white);box-shadow:0 10px 24px rgba(0,70,129,.18);border:1px solid rgba(255,255,255,.08)}.btn-blue:hover{background:var(--blue-light);transform:translateY(-1px);box-shadow:0 14px 30px rgba(0,70,129,.22)}.btn-blue:active{transform:translateY(0) scale(.98)}.btn-blue:disabled{background:#4b5563;color:#cbd5e1;cursor:not-allowed;opacity:.72;box-shadow:none;transform:none}
.btn.btn-blue.btn-sm,.btn.btn-danger.btn-sm{padding:10px 18px}
.btn-outline{padding:10px 20px;background:transparent;color:var(--text-mid);border:1px solid var(--border);border-radius:8px;font-size:13px;font-weight:500;cursor:pointer;font-family:inherit;transition:all .2s}.btn-outline:hover{border-color:var(--gold-border);color:var(--gold-light)}
.btn-sm{padding:8px 16px;font-size:12px}
.document-actions{display:flex;gap:8px;flex:0 0 auto;flex-wrap:nowrap;align-items:center;justify-content:flex-end}.document-actions .btn-outline{white-space:nowrap}
.application-documents{margin-bottom:22px}
.document-list{display:grid;grid-template-columns:1fr;gap:8px}
.document-item{display:flex;justify-content:space-between;align-items:center;gap:14px;background:var(--navy-dark);border:1px solid var(--border);border-radius:10px;padding:14px 16px}
.document-item-main{min-width:0;flex:1 1 auto}
.document-item-title{font-size:13px;font-weight:600;color:var(--white);overflow-wrap:anywhere}
.document-item-meta{font-size:11px;color:var(--text-muted);margin-top:2px}
.audit-trail{margin-top:22px}
.audit-trail-head{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:12px}
.audit-list{display:flex;flex-direction:column;gap:8px}
.audit-item{border-left:2px solid var(--gold-border);padding:0 0 10px 12px}
.audit-item:nth-child(n+4){display:none}
.audit-trail.expanded .audit-list{max-height:230px;overflow-y:auto;padding-right:8px}
.audit-trail.expanded .audit-item{display:block}
.audit-title{font-size:13px;color:var(--text-light);font-weight:600}
.audit-meta{font-size:11px;color:var(--text-muted)}
.btn-danger,.btn-danger-solid{background:linear-gradient(135deg,#991b1b,#dc2626);border:1px solid #7f1d1d;border-radius:12px;box-shadow:0 12px 28px rgba(185,28,28,.24);color:#fff;font-weight:700}.btn-danger:hover,.btn-danger-solid:hover{background:linear-gradient(135deg,#7f1d1d,#b91c1c);border-color:#7f1d1d;color:#fff;transform:translateY(-1px);box-shadow:0 16px 34px rgba(185,28,28,.32)}.btn-danger:active,.btn-danger-solid:active{transform:translateY(0) scale(.98)}
.container{max-width:1120px;margin:0 auto;padding:42px 24px}
.hero{text-align:center;margin-bottom:48px}
.hero h1{font-family:'Cormorant Garamond','Georgia',serif;font-size:36px;font-weight:600;margin-bottom:12px;color:var(--white)}
.hero h1 span{color:var(--gold)}
.hero p{color:var(--text-muted);font-size:15px;max-width:520px;margin:0 auto;line-height:1.7}
.dashboard-shell{max-width:980px;margin:0 auto}
.dashboard-hero{display:grid;grid-template-columns:minmax(0,1.22fr) minmax(300px,.78fr);gap:0;align-items:stretch;margin-bottom:34px;background:#fff;border:1px solid rgba(14,32,74,.12);border-radius:14px;overflow:hidden;box-shadow:0 18px 55px rgba(14,32,74,.08)}
.dashboard-hero-copy{background:#fff;border:0;border-radius:0;padding:38px 34px;box-shadow:none}
.dashboard-hero-copy h1{font-family:'Cormorant Garamond','Garamond','Georgia',serif;font-size:42px;line-height:1.06;font-weight:600;margin-bottom:14px;color:var(--navy)}
.dashboard-hero-copy h1 span{color:var(--gold)}
.dashboard-hero-copy p{color:#526078;font-size:15px;max-width:620px;line-height:1.8}
.dashboard-visual{position:relative;overflow:hidden;border-left:1px solid rgba(14,32,74,.1);background:#eef2f7;min-height:260px}
.dashboard-visual img{width:100%;height:100%;min-height:260px;display:block;object-fit:cover;object-position:center;filter:saturate(.96) contrast(1.02)}
.dashboard-visual::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(255,255,255,.18),rgba(14,32,74,.02) 42%,rgba(14,32,74,.14));pointer-events:none}
.app-admin-hero .dashboard-visual img{object-position:center}
.eyebrow{font-size:11px;font-weight:800;letter-spacing:1.3px;text-transform:uppercase;color:var(--gold);margin-bottom:10px}
.vacancy-shell{max-width:1040px;margin:0 auto}
.vacancy-hero{display:grid;grid-template-columns:minmax(0,1.35fr) minmax(280px,.8fr);gap:26px;align-items:stretch;background:#fff;border:1px solid rgba(14,32,74,.12);border-radius:14px;padding:34px;box-shadow:0 18px 55px rgba(14,32,74,.08);margin-bottom:24px}
.vacancy-hero h1{font-family:'Cormorant Garamond','Garamond','Georgia',serif;font-size:38px;line-height:1.08;color:var(--navy);font-weight:600;margin-bottom:12px}
.vacancy-hero h1 span{color:var(--gold)}
.vacancy-hero p{font-size:15px;line-height:1.8;color:#526078;max-width:650px}
.vacancy-stat-panel{display:grid;grid-template-columns:1fr 1fr;grid-auto-rows:1fr;gap:12px;align-self:center}
.vacancy-stat-panel div,.vacancy-stat-panel button{border:1px solid rgba(14,32,74,.1);border-radius:10px;padding:16px;background:#f8fafc;min-height:104px;display:flex;flex-direction:column;justify-content:center;text-align:left;font-family:inherit;cursor:pointer;transition:transform .18s ease,box-shadow .18s ease,border-color .18s ease}
.vacancy-stat-panel button:hover{transform:translateY(-2px);box-shadow:0 12px 28px rgba(14,32,74,.1);border-color:rgba(0,70,129,.26)}
.vacancy-stat-panel button:active{transform:translateY(0) scale(.98)}
.vacancy-stat-panel button:focus-visible{outline:3px solid rgba(0,70,129,.22);outline-offset:3px}
.vacancy-stat-panel strong{display:block;font-size:24px;line-height:1;color:var(--blue);margin-bottom:6px}
.vacancy-stat-panel span{font-size:11px;color:#66738a;font-weight:800;letter-spacing:.7px;text-transform:uppercase}
.vacancy-foundation-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:16px;margin-bottom:24px}
.foundation-card{background:#fff;border:1px solid rgba(14,32,74,.12);border-radius:12px;padding:20px;box-shadow:0 12px 32px rgba(14,32,74,.06)}
.foundation-card .home-menu-graphic{margin-bottom:18px}
.foundation-card h2{font-size:16px;color:var(--navy);margin-bottom:8px}
.foundation-card p{font-size:13px;line-height:1.65;color:#66738a}
.foundation-card.policy-accent{border-color:rgba(0,70,129,.18);background:linear-gradient(180deg,#fff 0,#f6f9fc 100%)}
.future-area-shell{max-width:760px;margin:0 auto}
.future-area-card{display:flex;align-items:flex-start;gap:18px;padding:28px}
.future-area-card .home-menu-graphic{margin-bottom:0}
.future-area-card h2{font-family:'Cormorant Garamond','Garamond','Georgia',serif;font-size:34px;font-weight:600;line-height:1.05;color:var(--navy);margin-bottom:10px}
.future-area-card p{font-size:15px;line-height:1.75;color:#526078;margin-bottom:20px;max-width:560px}
.prompt-admin-shell{max-width:1180px;margin:0 auto}
.prompt-admin-hero{grid-template-columns:minmax(0,1.1fr) minmax(280px,.9fr);margin-bottom:22px}
.prompt-admin-hero-panel{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;align-self:stretch;padding:28px;background:#f8fafc;border-left:1px solid rgba(14,32,74,.1)}
.prompt-admin-hero-panel button{border:1px solid rgba(14,32,74,.1);border-radius:10px;background:#fff;text-align:left;padding:18px;font-family:inherit;cursor:pointer;transition:transform .18s ease,box-shadow .18s ease,border-color .18s ease}
.prompt-admin-hero-panel button:hover{transform:translateY(-2px);box-shadow:0 12px 28px rgba(14,32,74,.1);border-color:rgba(0,70,129,.24)}
.prompt-admin-hero-panel strong{display:block;color:var(--blue);font-size:28px;line-height:1;margin-bottom:8px}
.prompt-admin-hero-panel span{display:block;color:#66738a;font-size:11px;font-weight:900;letter-spacing:.7px;text-transform:uppercase}
.prompt-admin-layout{display:grid;grid-template-columns:360px minmax(0,1fr);gap:18px;align-items:stretch}
.prompt-admin-list-panel,.prompt-admin-detail-panel{background:#fff;border:1px solid rgba(14,32,74,.12);border-radius:14px;box-shadow:0 12px 32px rgba(14,32,74,.06)}
.prompt-admin-list-panel{padding:16px;position:sticky;top:92px;align-self:start;height:calc(100vh - 116px);min-height:760px;display:flex;flex-direction:column}
.prompt-admin-detail-panel{padding:22px}
.prompt-admin-filter{display:grid;gap:8px;margin-bottom:14px}
.prompt-admin-filter label{color:var(--gold);font-size:11px;font-weight:900;letter-spacing:.9px;text-transform:uppercase}
.prompt-admin-filter input,.prompt-admin-filter select{width:100%;min-height:42px;border-radius:10px!important;background:#f8fafc!important;border:1px solid rgba(14,32,74,.14)!important;color:var(--navy)!important}
.prompt-admin-list{display:flex;flex-direction:column;gap:8px;flex:1 1 auto;min-height:0;overflow-y:scroll;overflow-x:hidden;padding-right:8px;scrollbar-gutter:stable}
.prompt-admin-list::-webkit-scrollbar{width:10px}
.prompt-admin-list::-webkit-scrollbar-track{background:#eef2f7;border-radius:999px}
.prompt-admin-list::-webkit-scrollbar-thumb{background:#b8c3d4;border:2px solid #eef2f7;border-radius:999px}
.prompt-admin-list::-webkit-scrollbar-thumb:hover{background:#8fa0ba}
.prompt-group-row{appearance:none;border:1px solid rgba(14,32,74,.1);border-radius:10px;background:#fff;display:flex;align-items:flex-start;justify-content:space-between;gap:10px;padding:13px;text-align:left;font-family:inherit;cursor:pointer;transition:background .18s ease,border-color .18s ease,box-shadow .18s ease}
.prompt-group-row{flex:0 0 auto;min-height:86px}
.prompt-group-row:hover,.prompt-group-row.active{background:#eef5fb;border-color:rgba(0,70,129,.24);box-shadow:inset 4px 0 0 rgba(0,70,129,.72)}
.prompt-group-row strong{display:block;color:var(--navy);font-size:13px;line-height:1.3}
.prompt-group-row small{display:block;color:#66738a;font-size:11px;line-height:1.35;margin-top:3px}
.prompt-group-row em{flex:0 0 auto;color:var(--blue);font-style:normal;font-size:10px;font-weight:900;letter-spacing:.6px;text-transform:uppercase;background:#fff;border:1px solid rgba(0,70,129,.12);border-radius:999px;padding:5px 7px;white-space:nowrap}
.prompt-detail-head{display:flex;align-items:flex-start;justify-content:space-between;gap:18px;margin-bottom:16px;padding-bottom:16px;border-bottom:1px solid rgba(14,32,74,.1)}
.prompt-detail-head h2{font-family:'Cormorant Garamond','Garamond','Georgia',serif;font-size:34px;font-weight:600;line-height:1.05;color:var(--navy);margin-bottom:8px}
.prompt-detail-head p{color:#526078;font-size:14px;line-height:1.65;max-width:720px}
.prompt-version-chip{display:inline-flex;align-items:center;justify-content:center;min-width:54px;height:38px;border:1px solid rgba(178,139,93,.24);border-radius:999px;background:#fbf8f3;color:var(--gold);font-size:12px;font-weight:900;text-transform:uppercase}
.prompt-part-tabs{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:16px}
.prompt-part-tabs button{border:1px solid rgba(14,32,74,.13);border-radius:999px;background:#fff;color:#526078;font-family:inherit;font-size:12px;font-weight:900;padding:8px 12px;cursor:pointer}
.prompt-part-tabs button.active,.prompt-part-tabs button:hover{background:var(--blue);border-color:var(--blue);color:#fff}
.prompt-info-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:16px}
.prompt-info-grid section,.prompt-variable-panel,.prompt-editor-panel,.prompt-tune-panel{border:1px solid rgba(14,32,74,.1);border-radius:12px;background:#f8fafc;padding:16px}
.prompt-info-grid h3,.prompt-section-title h3{color:var(--navy);font-size:13px;font-weight:900;letter-spacing:.7px;text-transform:uppercase;margin:0}
.prompt-info-grid p,.prompt-variable-panel p{font-size:13px;line-height:1.58;color:#66738a;margin-top:8px}
.prompt-usage-list{display:flex;gap:7px;flex-wrap:wrap;margin-top:10px}
.prompt-usage-list span{background:#fff;border:1px solid rgba(14,32,74,.1);border-radius:999px;color:#526078;font-size:11px;font-weight:800;padding:5px 8px}
.prompt-section-title{display:flex;align-items:center;justify-content:space-between;gap:14px;margin-bottom:12px}
.prompt-section-title span{color:#66738a;font-size:11px;font-weight:900;letter-spacing:.7px;text-transform:uppercase;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.prompt-variable-panel{margin-bottom:16px}
.prompt-variable-grid{display:flex;flex-wrap:wrap;gap:8px}
.prompt-variable-grid button{appearance:none;background:#fff;border:1px solid rgba(0,70,129,.12);border-radius:8px;color:var(--blue);font-family:inherit;font-size:12px;font-weight:900;padding:7px 9px;cursor:pointer;transition:background .18s ease,border-color .18s ease,box-shadow .18s ease,transform .16s ease}
.prompt-variable-grid button:hover,.prompt-variable-grid button.active{background:#eef5fb;border-color:rgba(0,70,129,.32);box-shadow:0 8px 18px rgba(0,70,129,.09);transform:translateY(-1px)}
.prompt-variable-grid button.active{box-shadow:inset 0 0 0 2px rgba(0,70,129,.22)}
.prompt-variable-grid code{font:inherit;color:inherit}
.prompt-variable-example{margin-top:14px;background:#fff;border:1px solid rgba(14,32,74,.12);border-radius:10px;padding:14px}
.prompt-variable-example>div{display:flex;align-items:center;justify-content:space-between;gap:14px;margin-bottom:10px}
.prompt-variable-example span{color:#66738a;font-size:10px;font-weight:900;letter-spacing:.8px;text-transform:uppercase}
.prompt-variable-example strong{color:var(--blue);font-family:"SFMono-Regular",Consolas,"Liberation Mono",monospace;font-size:12px}
.prompt-variable-example pre{white-space:pre-wrap;word-break:break-word;max-height:260px;overflow:auto;background:#f8fafc;border:1px solid rgba(14,32,74,.1);border-radius:9px;color:#334155;font-size:12px;line-height:1.5;padding:12px}
.prompt-editor-panel{margin-bottom:16px}
.prompt-editor-panel textarea,.prompt-tune-panel textarea,.prompt-tune-result textarea{width:100%;min-height:260px;background:#fff!important;border:1px solid rgba(14,32,74,.16)!important;border-radius:10px!important;color:#22324f!important;font-family:"SFMono-Regular",Consolas,"Liberation Mono",monospace;font-size:12px;line-height:1.55;resize:vertical}
.prompt-tune-panel textarea#promptTuneInstruction{min-height:92px;font-family:inherit;font-size:14px;line-height:1.5}
.prompt-editor-actions{display:flex;justify-content:flex-end;gap:10px;flex-wrap:wrap;margin-top:12px}
.prompt-tune-result{margin-top:16px;border-top:1px solid rgba(14,32,74,.1);padding-top:16px}
.prompt-tune-result h4{color:var(--navy);font-size:15px;margin-bottom:8px}
.prompt-tune-result p{color:#526078;font-size:13px;line-height:1.55;margin-bottom:12px}
.prompt-tune-notes{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:12px}
.prompt-tune-notes div{background:#fff;border:1px solid rgba(14,32,74,.1);border-radius:10px;padding:12px}
.prompt-tune-notes strong{display:block;color:var(--gold);font-size:11px;font-weight:900;letter-spacing:.7px;text-transform:uppercase;margin-bottom:6px}
.prompt-tune-notes span{display:block;color:#66738a;font-size:12px;line-height:1.45;margin-top:5px}
.policy-foundation-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px;margin-bottom:24px}
.policy-card{background:#fff;border:1px solid rgba(14,32,74,.12);border-radius:12px;padding:20px;box-shadow:0 12px 32px rgba(14,32,74,.06)}
.policy-card h3{font-size:15px;color:var(--navy);margin-bottom:8px}
.policy-card p{font-size:13px;color:#66738a;line-height:1.62}
.policy-chip-row{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px}
.policy-chip{display:inline-flex;align-items:center;border:1px solid rgba(0,70,129,.12);border-radius:999px;background:#eef5fb;color:var(--blue);font-size:11px;font-weight:800;letter-spacing:.4px;text-transform:uppercase;padding:5px 9px}
.vacancy-list-panel{background:#fff;border:1px solid rgba(14,32,74,.12);border-radius:14px;padding:24px;box-shadow:0 12px 32px rgba(14,32,74,.06)}
.vacancy-list-head{display:flex;align-items:center;justify-content:space-between;gap:14px;margin-bottom:14px}
.vacancy-list-head h2{font-family:'Cormorant Garamond','Garamond','Georgia',serif;font-size:26px;font-weight:600;color:var(--navy)}
.vacancy-list-head span{font-size:12px;color:#66738a;font-weight:800;text-transform:uppercase;letter-spacing:.8px}
.vacancy-row{display:flex;justify-content:space-between;gap:18px;padding:16px 0;border-top:1px solid rgba(14,32,74,.1)}
.vacancy-row strong{font-size:15px;color:var(--navy)}
.vacancy-row p{font-size:12px;color:#66738a;margin-top:3px}
.vacancy-row-meta{display:flex;gap:8px;align-items:center;flex-wrap:wrap;justify-content:flex-end}
.vacancy-row-meta span{font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.6px;color:var(--blue);background:#eef5fb;border:1px solid rgba(0,70,129,.12);border-radius:999px;padding:5px 9px}
.empty-foundation-state{border:1px dashed rgba(14,32,74,.2);border-radius:12px;padding:26px;text-align:center;background:#fafbfd}
.empty-foundation-state strong{display:block;color:var(--navy);font-size:16px;margin-bottom:8px}
.empty-foundation-state p{font-size:13px;color:#66738a;line-height:1.6;max-width:560px;margin:0 auto}
.vacancy-admin-hero{margin-bottom:24px}
.vacancy-readiness{grid-template-columns:repeat(3,minmax(0,1fr))}
.vacancy-filter-secondary-row{grid-template-columns:repeat(4,minmax(170px,1fr))}
.vacancy-create-field .btn{height:44px;width:100%;padding:10px 18px}
.vacancy-register-panel .vacancy-list-head>div{width:100%}
.vacancy-card{--role-accent:#004681}
.vacancy-status-draft{--role-accent:#b5c2d2}
.vacancy-status-incomplete_draft{--role-accent:#dd8a46}
.vacancy-status-ready_for_approval{--role-accent:#dd8a46}
.vacancy-status-approved{--role-accent:#34a85d}
.vacancy-status-live{--role-accent:#2f6fa5}
.vacancy-status-paused{--role-accent:#8a77bd}
.vacancy-status-closing{--role-accent:#bf6d2c}
.vacancy-status-extended{--role-accent:#56ae94}
.vacancy-status-closed{--role-accent:#8091a6}
.vacancy-status-fulfilled{--role-accent:#15803d}
.vacancy-status-archived{--role-accent:#8a673f}
.vacancy-detail-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px;margin-bottom:16px}
.vacancy-detail-box{background:#f8fafc;border:1px solid rgba(14,32,74,.12);border-radius:12px;padding:18px}
.vacancy-wide-box{margin-bottom:16px}
.vacancy-info-line{display:flex;justify-content:space-between;gap:14px;padding:9px 0;border-bottom:1px solid rgba(14,32,74,.08)}
.vacancy-info-line:last-child{border-bottom:0}
.vacancy-info-line span{font-size:11px;color:#66738a;font-weight:900;letter-spacing:.7px;text-transform:uppercase}
.vacancy-info-line strong{font-size:13px;color:var(--navy);text-align:right}
.vacancy-muted{font-size:13px;color:#66738a;line-height:1.6}
.vacancy-mini-row{border:1px solid rgba(14,32,74,.1);border-radius:10px;background:#fff;padding:12px;margin-bottom:8px}
.vacancy-mini-row strong{display:block;color:var(--navy);font-size:13px;margin-bottom:3px}
.vacancy-mini-row span{display:block;color:#66738a;font-size:11px;font-weight:800;letter-spacing:.5px;text-transform:uppercase}
.vacancy-content-builder-modal{width:min(96vw,1280px);max-width:1280px;max-height:94vh;overflow:auto}
.vacancy-content-builder-page-mode .header{display:none}
.vacancy-content-builder-page-mode .container{padding-top:22px;max-width:none}
.vacancy-content-page-shell{max-width:1680px;margin:0 auto;padding:24px 32px 38px}
.vacancy-content-builder-head{display:flex;align-items:flex-start;justify-content:space-between;gap:18px;margin-bottom:20px}
.vacancy-content-builder-head h2{font-size:26px;color:var(--navy);margin:4px 0 6px}
.vacancy-content-builder-head p{color:#66738a;font-size:14px;line-height:1.45;margin:0;max-width:720px}
.vacancy-content-builder-actions{display:flex;gap:10px;flex-wrap:wrap;justify-content:flex-end}
.vacancy-content-builder-grid{display:grid;grid-template-columns:minmax(520px,.95fr) minmax(560px,1.05fr);gap:18px;align-items:start}
.vacancy-content-block-list{display:grid;gap:12px}
.vacancy-content-block-editor{background:#f8fafc;border:1px solid rgba(14,32,74,.12);border-radius:12px;padding:14px}
.vacancy-content-block-top{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:10px;color:#66738a;font-size:11px;font-weight:800;letter-spacing:.06em;text-transform:uppercase}
.vacancy-content-block-top label{display:flex;align-items:center;gap:7px;color:var(--navy);cursor:pointer}
.vacancy-content-block-editor input.vacancy-content-title{width:100%;background:#fff;border:1px solid rgba(14,32,74,.16);border-radius:10px;color:var(--navy);font-size:14px;font-weight:900;margin-bottom:10px;padding:11px 12px}
.vacancy-content-block-editor textarea{min-height:108px;background:#fff!important;border:1px solid rgba(14,32,74,.16)!important;border-radius:10px!important;color:#334155!important;line-height:1.5}
.vacancy-content-preview-panel{position:sticky;top:12px;background:#fff;border:1px solid rgba(14,32,74,.12);border-radius:12px;padding:18px;box-shadow:0 12px 32px rgba(14,32,74,.06)}
.job-vacancy-content-preview{border:1px solid rgba(14,32,74,.12);border-radius:8px;overflow:hidden;background:#fff;color:#334155}
.job-vacancy-content-preview header{background:#13224a;color:#fff;padding:28px 32px;border-bottom:4px solid #b28b5d}
.job-vacancy-content-preview header p{font-size:11px;font-weight:900;letter-spacing:.16em;text-transform:uppercase;color:#d8c7ad;margin:0 0 8px}
.job-vacancy-content-preview header h1{font-size:30px;line-height:1.1;color:#fff;margin:0 0 10px}
.job-vacancy-content-preview header span{color:#edf2f7;font-size:14px}
.job-vacancy-content-preview section{padding:22px 32px;border-bottom:1px solid rgba(14,32,74,.1)}
.job-vacancy-content-preview section:last-child{border-bottom:0}
.job-vacancy-content-preview h2{font-size:18px;color:#13224a;margin:0 0 10px;padding-bottom:7px;border-bottom:2px solid #b28b5d;display:inline-block}
.job-vacancy-content-preview p{font-size:14px;line-height:1.55;color:#334155;margin:0 0 8px}
.vacancy-timeline{display:grid;gap:10px;max-height:310px;overflow:auto;padding-right:4px}
.vacancy-timeline-item{position:relative;border-left:3px solid rgba(178,139,93,.42);padding:0 0 12px 14px}
.vacancy-timeline-item::before{content:"";position:absolute;left:-6px;top:3px;width:9px;height:9px;border-radius:999px;background:var(--gold)}
.vacancy-timeline-item strong{display:block;color:var(--navy);font-size:13px}
.vacancy-timeline-item span{display:block;color:#66738a;font-size:11px;margin-top:2px}
.vacancy-timeline-item p{color:#526078;font-size:12px;line-height:1.55;margin-top:5px}
.vacancy-action-toolbar{align-items:center}
.vacancy-lists-admin-form .admin-form-grid{align-items:start}
.vacancy-list-editor textarea{min-height:132px;line-height:1.5;font-size:14px;border-radius:10px;background:#f8fafc!important}
.vacancy-admin-subhead{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid rgba(14,32,74,.1)}
.vacancy-admin-subhead label{margin:0;color:var(--gold);font-size:14px;font-weight:900;letter-spacing:1.2px;text-transform:uppercase}
.vacancy-admin-subhead .btn{width:220px;min-width:220px;min-height:54px;border-radius:10px;font-size:14px;font-weight:800}
.vacancy-site-admin{margin-bottom:8px}
.vacancy-site-admin-grid{display:grid;gap:14px}
.vacancy-site-admin-row{position:relative;border:1px solid rgba(14,32,74,.12);border-radius:12px;background:#fff;padding:0;box-shadow:0 10px 26px rgba(14,32,74,.055);overflow:hidden}
.vacancy-site-admin-row::before{content:"";position:absolute;left:0;top:18px;bottom:18px;width:3px;border-radius:999px;background:var(--gold)}
.vacancy-site-summary{list-style:none;display:flex;align-items:center;justify-content:space-between;gap:14px;padding:16px 20px 16px 24px;cursor:pointer;border-bottom:1px solid rgba(14,32,74,.08)}
.vacancy-site-summary::-webkit-details-marker{display:none}
.vacancy-site-summary div{min-width:0}
.vacancy-site-summary strong{display:block;color:var(--navy);font-size:15px;font-weight:900;line-height:1.25;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.vacancy-site-summary span{display:block;color:#66738a;font-size:12px;font-weight:700;line-height:1.35;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.vacancy-site-summary small{flex:0 0 auto;color:#66738a;font-size:11px;font-weight:900;letter-spacing:.7px;text-transform:uppercase;padding-right:24px}
.vacancy-site-summary::after{content:"▾";position:absolute;right:18px;top:20px;color:#66738a;font-size:13px;transition:transform .2s}
.vacancy-site-admin-row:not([open]) .vacancy-site-summary{border-bottom:0}
.vacancy-site-admin-row:not([open]) .vacancy-site-summary::after{transform:rotate(-90deg)}
.vacancy-site-admin-panel-body{display:grid;grid-template-columns:1fr;gap:16px;padding:18px 20px 20px 24px}
.vacancy-site-details-grid{display:grid;grid-template-columns:minmax(180px,.9fr) minmax(300px,1.35fr) 140px;gap:14px;align-items:stretch}
.vacancy-site-admin-row label{display:block;margin-bottom:7px;color:#66738a;font-size:10px;font-weight:900;letter-spacing:.9px;text-transform:uppercase}
.vacancy-site-details-grid>div{min-width:0;display:flex;flex-direction:column;justify-content:flex-start}
.vacancy-site-admin-row input,.vacancy-site-admin-row textarea{width:100%;border-radius:10px!important;background:#f8fafc!important;border:1px solid rgba(14,32,74,.14)!important;color:var(--navy)!important;font-size:14px}
.vacancy-site-admin-row input[readonly]{background:#f1f5f9!important;color:#334155!important;cursor:default}
.vacancy-site-admin-row input{min-height:48px}
.vacancy-site-admin-row textarea{min-height:96px;line-height:1.48;resize:vertical}
.vacancy-site-admin-row input:focus,.vacancy-site-admin-row textarea:focus{border-color:rgba(178,139,93,.48)!important;box-shadow:0 0 0 3px rgba(178,139,93,.12)!important;outline:0}
.vacancy-site-description{grid-column:1/3}
.vacancy-site-remove{grid-column:3;grid-row:2;display:flex;justify-content:flex-end;align-self:stretch;padding-top:17px}
.vacancy-site-remove .btn{min-height:96px;height:100%;width:140px;max-width:140px;border-radius:10px}
.site-asset-repositories{display:grid;grid-template-columns:1fr;gap:14px;border-top:1px solid rgba(14,32,74,.09);padding-top:16px}
.site-asset-repository{border:1px solid rgba(14,32,74,.1);border-radius:10px;background:#f8fafc;padding:14px}
.site-asset-repository-head{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:12px}
.site-asset-repository h4{font-size:13px;font-weight:900;color:var(--navy);letter-spacing:.8px;text-transform:uppercase;margin:0 0 3px}
.site-asset-repository p{font-size:12px;color:#66738a;line-height:1.45;margin:0}
.site-asset-repository-head .site-asset-upload-btn{display:inline-flex;align-items:center;justify-content:center;width:200px;min-width:200px;min-height:54px;border-radius:10px;font-size:14px;font-weight:800;text-transform:none;letter-spacing:0}
.site-asset-repository-head label.site-asset-upload-btn,.site-asset-repository-head label.site-asset-upload-btn:hover,body.light-mode #app .site-asset-repository-head label.site-asset-upload-btn,body.light-mode #app .site-asset-repository-head label.site-asset-upload-btn:hover{color:#fff!important}
.site-asset-repository .btn.disabled{opacity:.55;cursor:not-allowed;pointer-events:none}
.site-asset-repository.drag-over{outline:2px solid rgba(0,70,129,.22);outline-offset:-5px}
.site-asset-repository.drag-valid{background:#f0fdf4;border-color:rgba(22,101,52,.3)}
.site-asset-repository.drag-invalid{background:#fff1f2;border-color:rgba(185,28,28,.3)}
.site-asset-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,calc((100% - 20px)/3)));gap:10px}
.site-asset-empty{border:1px dashed rgba(14,32,74,.16);border-radius:9px;background:#fff;color:#66738a;font-size:12px;padding:14px;text-align:center}
.site-asset-tile{position:relative;display:grid;grid-template-columns:74px minmax(0,1fr) 42px;gap:10px;align-items:center;border:1px solid rgba(14,32,74,.12);border-radius:10px;background:#fff;padding:10px}
.site-asset-tile[draggable=true]{cursor:grab}
.site-asset-tile.dragging{opacity:.78;cursor:grabbing}
.site-asset-tooltip{position:absolute;z-index:20;left:94px;right:52px;bottom:calc(100% - 4px);display:none;background:#fff;color:var(--navy);border:1px solid rgba(14,32,74,.16);border-radius:8px;box-shadow:0 14px 32px rgba(14,32,74,.16);padding:10px 12px;pointer-events:none}
.site-asset-tile:hover .site-asset-tooltip,.site-asset-tile:focus-within .site-asset-tooltip{display:block}
.site-asset-tile.dragging .site-asset-tooltip{display:none}
.site-asset-tooltip dl{display:grid;gap:8px;margin:0}
.site-asset-tooltip div{display:grid;gap:2px}
.site-asset-tooltip dt{color:#66738a;font-size:10px;font-weight:900;letter-spacing:.7px;line-height:1.2;text-transform:uppercase}
.site-asset-tooltip dd{color:var(--navy);font-size:12px;font-weight:800;line-height:1.35;margin:0;overflow-wrap:anywhere}
.site-asset-tooltip ul{display:grid;gap:2px;margin:0;padding:0;list-style:none}
.site-asset-tooltip li{overflow-wrap:anywhere}
.site-asset-tile.move-valid{background:#dcfce7!important;border-color:rgba(22,101,52,.42)!important;box-shadow:inset 5px 0 0 rgba(22,101,52,.72),0 10px 24px rgba(22,101,52,.1)!important}
.site-asset-tile.move-invalid{background:#fee2e2!important;border-color:rgba(185,28,28,.42)!important;box-shadow:inset 5px 0 0 rgba(185,28,28,.72),0 10px 24px rgba(185,28,28,.1)!important}
.site-asset-tile.in-use{background:#dbeafe;border-color:rgba(0,70,129,.42);box-shadow:inset 5px 0 0 rgba(0,70,129,.72),0 10px 24px rgba(0,70,129,.08)}
.site-asset-tile.in-use .site-asset-thumb{background:#fff;border-color:rgba(0,70,129,.18)}
.site-asset-thumb{width:74px;aspect-ratio:4/3;border:1px solid rgba(14,32,74,.1);border-radius:8px;background:#eef2f7;overflow:hidden;display:flex;align-items:center;justify-content:center;text-decoration:none;cursor:zoom-in}
.site-asset-thumb:hover{border-color:rgba(0,70,129,.34);box-shadow:0 0 0 3px rgba(0,70,129,.1)}
.site-asset-thumb img{width:100%;height:100%;object-fit:cover;display:block}
.site-asset-file-thumb{display:flex;align-items:center;justify-content:center;width:100%;height:100%;background:#f8fafc;color:#66738a;font-size:12px;font-weight:900;letter-spacing:.2px;line-height:1.2;text-align:center}
.site-asset-meta{min-width:0}
.site-asset-meta strong{display:block;color:var(--navy);font-size:13px;line-height:1.3;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.site-asset-name-btn{appearance:none;border:0;background:transparent;color:var(--navy);display:block;font:inherit;font-size:13px;font-weight:900;line-height:1.3;margin:0;padding:0;text-align:left;width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;cursor:text}
.site-asset-name-btn:hover,.site-asset-name-btn:focus{color:var(--blue);outline:0;text-decoration:underline;text-decoration-thickness:1px;text-underline-offset:2px}
.site-asset-meta span,.site-asset-meta small,.site-asset-meta em{display:block;color:#66738a;font-size:11px;line-height:1.35;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.site-asset-meta em{color:#0f6a3d;font-style:normal;font-weight:800;margin-top:2px}
.site-asset-status-stack{display:flex;flex-direction:column;gap:6px;align-items:flex-end;justify-self:end}
.site-asset-delete-icon{display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;border:1px solid rgba(185,28,28,.18);border-radius:10px;background:#fff;color:#b91c1c;cursor:pointer;box-shadow:0 8px 18px rgba(185,28,28,.08)}
.site-asset-delete-icon:hover{background:#fff5f5;border-color:rgba(185,28,28,.34);color:#991b1b;box-shadow:0 12px 24px rgba(185,28,28,.14);transform:translateY(-1px)}
.site-asset-delete-icon:active{transform:translateY(0) scale(.98)}
.site-asset-delete-icon .page-action-icon{width:17px;height:17px;flex-basis:17px}
.site-asset-replace-icon,.vacancy-site-admin-row .site-asset-replace-icon{display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;border:1px solid rgba(0,70,129,.24);border-radius:10px;background:#fff;color:var(--blue);cursor:pointer;box-shadow:0 8px 18px rgba(0,70,129,.1);margin:0;text-transform:none;letter-spacing:0;padding:0;line-height:1}
.site-asset-replace-icon:hover{background:#e8f2fb;border-color:rgba(0,70,129,.38);color:var(--blue-light);box-shadow:0 12px 24px rgba(0,70,129,.14);transform:translateY(-1px)}
.site-asset-replace-icon:active{transform:translateY(0) scale(.98)}
.site-asset-replace-icon .page-action-icon{width:17px;height:17px;flex-basis:17px}
.site-asset-source{display:inline-flex;align-items:center;justify-content:center;min-height:36px;border:1px solid rgba(178,139,93,.22);border-radius:999px;background:rgba(178,139,93,.08);color:var(--gold);font-size:11px;font-weight:900;letter-spacing:.6px;text-transform:uppercase;padding:0 10px}
.site-asset-source.in-use{border-color:rgba(15,106,61,.22);background:rgba(34,197,94,.1);color:#0f6a3d}
.message-fade-out{opacity:0;transform:translateY(-4px);transition:opacity .5s ease,transform .5s ease}
.vacancy-key-stage-admin{margin-top:8px}
.vacancy-key-stage-admin-grid{display:grid;gap:10px}
.vacancy-key-stage-admin-row{display:grid;grid-template-columns:minmax(150px,.8fr) minmax(260px,1.6fr) minmax(92px,.45fr) minmax(92px,.45fr);gap:12px;align-items:end;border:1px solid rgba(14,32,74,.12);border-radius:10px;background:#f8fafc;padding:14px}
.vacancy-key-stage-anchor{min-height:42px;display:flex;align-items:center;border-left:3px solid var(--gold);padding-left:12px}
.vacancy-key-stage-anchor span{display:block;color:var(--navy);font-size:14px;font-weight:800}
.vacancy-key-stage-admin-row label{display:block;margin-bottom:6px;color:#66738a;font-size:10px;font-weight:900;letter-spacing:.8px;text-transform:uppercase}
.vacancy-key-stage-admin-row input{width:100%;min-height:42px;border-radius:8px}
.vacancy-key-stage-age input{text-align:center}
.logging-editor-actions.vacancy-options-actions{display:flex;justify-content:flex-end;margin-top:18px}
.logging-editor-actions.vacancy-options-actions::before{content:none}
.logging-editor-actions.vacancy-options-actions .btn{width:min(100%,220px);min-width:220px}
.modal.vacancy-modal{width:min(96vw,1080px);max-width:1080px;height:min(98vh,1240px);max-height:98vh;display:flex;flex-direction:column;overflow:hidden;padding:24px 38px}
.vacancy-modal-head{border-bottom:1px solid rgba(14,32,74,.1);margin-bottom:18px;padding-bottom:16px}
.vacancy-modal-eyebrow,.vacancy-step-kicker{display:block;color:var(--gold);font-size:11px;font-weight:900;letter-spacing:1.1px;text-transform:uppercase;margin-bottom:6px}
.vacancy-modal-head h3{margin:0 0 8px}
.vacancy-modal-head p{color:#66738a;font-size:13px;line-height:1.55;margin:0;max-width:820px}
.vacancy-wizard-steps{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:10px;margin-bottom:18px}
.vacancy-wizard-steps button{border:1px solid rgba(14,32,74,.14);border-radius:10px;background:#f8fafc;color:#66738a;cursor:pointer;font-family:inherit;font-size:15px;font-weight:900;min-height:64px;padding:10px 12px;text-align:center;transition:background .18s,border-color .18s,color .18s,box-shadow .18s,transform .18s}
.vacancy-wizard-steps button span{display:block;font-size:11px;letter-spacing:.6px;line-height:1.22;margin-top:3px;text-transform:uppercase}
.vacancy-wizard-steps button.active{background:var(--blue);border-color:rgba(0,70,129,.72);color:#fff;box-shadow:0 12px 28px rgba(0,70,129,.22);transform:translateY(-1px)}
.vacancy-title-strip{border:1px solid rgba(14,32,74,.12);border-radius:12px;background:#f8fafc;margin:-4px 0 18px;padding:12px 16px}
.vacancy-title-strip span{display:block;color:#66738a;font-size:10px;font-weight:900;letter-spacing:.8px;text-transform:uppercase;margin-bottom:4px}
.vacancy-title-strip strong{display:block;color:var(--navy);font-size:17px;line-height:1.35}
.modal.vacancy-modal #vacancyForm{display:flex;flex:1;flex-direction:column;min-height:0}
.vacancy-wizard-panels{flex:1;min-height:0;overflow:auto;padding:0 4px 2px 0}
.vacancy-wizard-panel{display:none}
.vacancy-wizard-panel.active{display:block}
.vacancy-step-hero{border:1px solid rgba(14,32,74,.12);border-radius:12px;background:linear-gradient(135deg,#fff,#f8fbff);margin-bottom:14px;padding:18px;box-shadow:0 10px 24px rgba(14,32,74,.04)}
.vacancy-step-card{border:1px solid rgba(14,32,74,.12);border-radius:12px;background:#fff;padding:18px;box-shadow:0 10px 24px rgba(14,32,74,.04)}
.vacancy-step-card h4,.vacancy-step-hero h4{color:var(--navy);font-size:18px;margin:0 0 8px}
.vacancy-step-card p,.vacancy-step-hero p{color:#66738a;font-size:13px;line-height:1.55;margin:0}
.vacancy-role-picker{border:1px solid rgba(14,32,74,.12);border-radius:12px;background:#f8fafc;padding:14px}
.vacancy-role-summary{border:1px solid rgba(178,139,93,.22);border-radius:10px;background:#fff;margin-top:10px;padding:11px 12px}
.vacancy-role-summary strong{display:block;color:var(--navy);font-size:14px;margin-bottom:3px}
.vacancy-role-summary .vacancy-role-tag{width:max-content;margin-top:7px}
.vacancy-form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;margin-top:12px}
.vacancy-form-grid label,.vacancy-role-picker label{display:block;font-size:10px;font-weight:900;letter-spacing:.8px;text-transform:uppercase;color:#66738a;margin-bottom:7px}
.vacancy-help-icon{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;margin-left:5px;border-radius:999px;background:#eef5fb;border:1px solid rgba(0,70,129,.18);color:var(--blue);cursor:help;font-size:10px;font-weight:900;line-height:1;vertical-align:middle;text-transform:none}
.vacancy-help-icon:hover{background:#fff;border-color:rgba(178,139,93,.42);color:var(--gold);box-shadow:0 0 0 3px rgba(178,139,93,.1)}
.vacancy-form-grid input,.vacancy-form-grid select,.vacancy-form-grid textarea,.vacancy-role-picker select{width:100%}
.modal.vacancy-modal input:not([type="checkbox"]):not([type="range"]),
.modal.vacancy-modal select,
.modal.vacancy-modal textarea{
  box-sizing:border-box;
  width:100%;
  min-height:52px;
  padding:13px 16px;
  background:#f8fafc;
  border:1px solid rgba(14,32,74,.16);
  border-radius:10px;
  color:var(--navy);
  font-family:inherit;
  font-size:14px;
  line-height:1.35;
  outline:none;
  transition:border-color .2s,box-shadow .2s,background .2s;
}
.modal.vacancy-modal select{
  appearance:auto;
  cursor:pointer;
}
.modal.vacancy-modal textarea{
  min-height:132px;
  resize:vertical;
}
.modal.vacancy-modal input:not([type="checkbox"]):not([type="range"]):focus,
.modal.vacancy-modal select:focus,
.modal.vacancy-modal textarea:focus{
  background:#fff;
  border-color:rgba(178,139,93,.46);
  box-shadow:0 0 0 3px rgba(178,139,93,.12);
}
.modal.vacancy-modal input[type="date"]{
  color-scheme:light;
}
.modal.vacancy-modal input[readonly]{
  background:#eef5fb;
  border-color:rgba(0,70,129,.18);
  color:var(--navy);
  cursor:default;
}
.vacancy-input-suffix{position:relative}
.vacancy-input-suffix input{padding-right:48px!important}
.vacancy-input-suffix span{position:absolute;right:16px;top:50%;transform:translateY(-50%);color:#66738a;font-size:14px;font-weight:900;pointer-events:none}
.vacancy-form-section-wide{grid-column:1/-1}
.vacancy-form-section{border:1px solid rgba(14,32,74,.12);border-radius:12px;background:#f8fafc;padding:14px}
.vacancy-form-section textarea{min-height:120px}
.vacancy-field-help{color:#66738a;font-size:12px;line-height:1.55;margin:-2px 0 10px}
.vacancy-form-section-heading{color:var(--gold);font-size:11px;font-weight:900;letter-spacing:1px;margin:0 0 10px;text-transform:uppercase}
.vacancy-financial-extra-row{border-top:1px solid rgba(14,32,74,.1);display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin-top:14px;padding-top:14px}
.vacancy-remote-days-placeholder{visibility:hidden;pointer-events:none}
.vacancy-subject-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;max-height:170px;overflow:auto;padding-right:4px}
.vacancy-key-stage-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}
.vacancy-key-stage-grid label{display:flex!important;align-items:flex-start;gap:8px;border:1px solid rgba(14,32,74,.12);border-radius:10px;background:#fff;padding:10px 12px;margin:0!important;text-transform:none!important;letter-spacing:0!important;color:#334155!important;cursor:pointer}
.vacancy-key-stage-grid label:has(input:checked){background:#eef5fb;border-color:rgba(0,70,129,.28);box-shadow:0 0 0 3px rgba(0,70,129,.08)}
.vacancy-key-stage-grid strong{display:block;color:var(--navy);font-size:12px;line-height:1.3}
.vacancy-key-stage-grid small{display:block;color:#66738a;font-size:11px;line-height:1.35;margin-top:2px}
.vacancy-subject-grid label,.vacancy-toggle-box label{display:flex!important;align-items:center;gap:8px;margin:0!important;text-transform:none!important;letter-spacing:0!important;font-size:12px!important;color:#334155!important;font-weight:700!important}
.vacancy-subject-grid input,.vacancy-toggle-box input{width:auto}
.vacancy-key-stage-grid input{width:auto!important;margin-top:2px}
.vacancy-professional-qualification-editor{border:1px solid rgba(14,32,74,.12);border-radius:12px;background:#f8fafc;margin-top:8px;overflow:hidden}
.vacancy-professional-qualification-editor .person-spec-editor-requirements{padding:12px}
.vacancy-professional-qualification-row{grid-template-columns:34px 52px minmax(220px,1fr) 136px 92px}
.vacancy-modal .person-spec-requirement-text{background:#fff!important;border-color:rgba(14,32,74,.14)!important;color:var(--navy)!important;font-size:13px!important;line-height:1.45!important;margin:0!important;min-height:72px!important;height:72px;resize:vertical}
.vacancy-modal .person-spec-requirement-text:not(:focus){overflow:auto}
.vacancy-modal .person-spec-requirement-text:focus{overflow:auto}
.vacancy-modal .person-spec-importance-select{align-self:start;background:#fff!important;border-color:rgba(14,32,74,.14)!important;color:var(--navy)!important;font-size:12px!important;font-weight:800;height:72px!important;margin:0!important}
.vacancy-professional-qualification-row .person-spec-row-move-actions,.vacancy-professional-qualification-row::before,.vacancy-professional-qualification-row .btn-danger{align-self:center}
.vacancy-add-qualification-btn{margin:10px 0 0;min-height:38px;width:220px}
.vacancy-range-row{display:grid;grid-template-columns:1fr 1fr;gap:12px;align-items:center}
.vacancy-range-row input{accent-color:var(--blue)}
.vacancy-salary-row{grid-template-columns:1fr 1fr}
.vacancy-range-input-row{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin-top:12px}
.vacancy-range-input-row label{font-size:10px!important;margin-bottom:7px!important}
.vacancy-range-feedback{margin-top:8px;border:1px solid rgba(0,70,129,.14);border-radius:10px;background:#eef5fb;color:var(--blue);font-size:12px;font-weight:900;letter-spacing:.5px;text-transform:uppercase;padding:10px 12px;text-align:center}
.vacancy-date-message{color:#66738a;font-size:12px;font-weight:800;line-height:1.45;margin-top:0}
.vacancy-date-message.is-error{background:rgba(248,113,113,.08);border-color:rgba(248,113,113,.26);color:#b91c1c}
.vacancy-segmented-control{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}
.vacancy-segmented-control label{display:flex!important;align-items:center;justify-content:center;gap:8px;min-height:48px;border:1px solid rgba(14,32,74,.14);border-radius:10px;background:#fff;color:var(--navy)!important;font-size:13px!important;font-weight:900!important;letter-spacing:.4px!important;text-transform:none!important;margin:0!important;cursor:pointer}
.vacancy-segmented-control input{width:auto!important}
.vacancy-segmented-control label:has(input:checked){background:#eef5fb;border-color:rgba(0,70,129,.28);box-shadow:0 0 0 3px rgba(0,70,129,.08)}
.vacancy-review-summary{display:grid;gap:14px;margin-top:12px}
.vacancy-review-group{border:1px solid rgba(14,32,74,.12);border-radius:12px;background:#f8fafc;padding:14px}
.vacancy-review-group h5{color:var(--navy);font-size:14px;margin:0 0 12px}
.vacancy-review-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}
.vacancy-review-grid div{border:1px solid rgba(14,32,74,.1);border-radius:10px;background:#fff;padding:10px 12px;min-height:58px}
.vacancy-review-grid div.vacancy-review-help{cursor:help}
.vacancy-review-grid div.vacancy-review-help:hover{border-color:rgba(178,139,93,.32);box-shadow:0 0 0 3px rgba(178,139,93,.08)}
.vacancy-review-grid div.vacancy-review-missing{background:#fff1f2;border-color:rgba(185,28,28,.28)}
.vacancy-review-grid div.vacancy-review-missing span,.vacancy-review-grid div.vacancy-review-missing strong{color:#991b1b}
.vacancy-review-grid div.vacancy-review-missing:hover{border-color:rgba(185,28,28,.42);box-shadow:0 0 0 3px rgba(185,28,28,.08)}
.vacancy-review-grid span{display:block;color:#66738a;font-size:10px;font-weight:900;letter-spacing:.8px;text-transform:uppercase;margin-bottom:5px}
.vacancy-review-grid strong{display:block;color:var(--navy);font-size:13px;line-height:1.35;white-space:pre-wrap}
.vacancy-toggle-box{align-self:end!important;display:flex;align-items:center;border:1px solid rgba(14,32,74,.12);border-radius:10px;background:#f8fafc;height:52px!important;min-height:52px!important;max-height:52px!important;padding:0 16px;overflow:hidden}
.vacancy-toggle-box label{height:50px!important;min-height:50px!important;max-height:50px!important;width:100%;align-items:center!important}
.modal-actions{display:flex;justify-content:flex-end;align-items:center;gap:10px;margin-top:18px}
.vacancy-modal .modal-actions{border-top:1px solid rgba(14,32,74,.1);flex:0 0 auto;padding-top:16px}
.vacancy-modal .modal-actions .btn{min-height:56px;min-width:190px;border-radius:14px;font-size:15px;font-weight:900}
.role-library-shell{max-width:1040px;margin:0 auto}
.role-library-hero{display:grid;grid-template-columns:minmax(0,1.35fr) minmax(280px,.8fr);gap:26px;align-items:stretch;background:#fff;border:1px solid rgba(14,32,74,.12);border-radius:14px;padding:34px;box-shadow:0 18px 55px rgba(14,32,74,.08);margin-bottom:24px}
.role-library-copy{min-height:100%;display:flex;flex-direction:column}
.role-library-hero h1{font-family:'Cormorant Garamond','Garamond','Georgia',serif;font-size:38px;line-height:1.08;color:var(--navy);font-weight:600;margin-bottom:12px}
.role-library-hero h1 span{color:var(--gold)}
.role-library-hero p{font-size:15px;line-height:1.8;color:#526078;max-width:650px}
.role-library-readiness{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;margin-top:auto;max-width:820px;padding-top:28px}
.role-library-readiness div,.role-library-readiness button{border:1px solid rgba(178,139,93,.28);border-radius:10px;background:linear-gradient(135deg,rgba(178,139,93,.2),rgba(255,255,255,.96) 48%,rgba(178,139,93,.08));padding:16px;min-height:92px;display:flex;flex-direction:column;justify-content:center;text-align:left;font-family:inherit;box-shadow:0 10px 24px rgba(178,139,93,.08);cursor:pointer;transition:transform .18s ease,box-shadow .18s ease,border-color .18s ease}
.role-library-readiness button:hover{transform:translateY(-2px);box-shadow:0 14px 30px rgba(178,139,93,.16);border-color:rgba(178,139,93,.46)}
.role-library-readiness button:active{transform:translateY(0) scale(.98)}
.role-library-readiness button:focus-visible{outline:3px solid rgba(178,139,93,.22);outline-offset:3px}
.role-library-readiness strong{display:block;font-size:22px;line-height:1;color:var(--blue);margin-bottom:6px}
.role-library-readiness span{font-size:10px;color:#66738a;font-weight:800;letter-spacing:.6px;text-transform:uppercase}
.role-readiness-approved{border-color:rgba(52,168,93,.26)!important;background:linear-gradient(135deg,rgba(184,232,197,.38),#fff 52%,rgba(184,232,197,.18))!important}
.role-readiness-review{border-color:rgba(221,138,70,.32)!important;background:linear-gradient(135deg,rgba(242,207,170,.38),#fff 52%,rgba(242,207,170,.18))!important}
.role-readiness-missing{border-color:rgba(248,113,113,.24)!important;background:linear-gradient(135deg,rgba(254,226,226,.56),#fff 52%,rgba(254,226,226,.26))!important}
.role-readiness-primary{border-color:rgba(0,70,129,.24)!important;background:linear-gradient(135deg,rgba(217,236,251,.7),#fff 54%,rgba(217,236,251,.28))!important}
.role-readiness-secondary{border-color:rgba(178,139,93,.32)!important;background:linear-gradient(135deg,rgba(246,239,229,.74),#fff 54%,rgba(246,239,229,.34))!important}
.role-readiness-person-spec{border-color:rgba(52,168,93,.24)!important;background:linear-gradient(135deg,rgba(227,243,239,.62),#fff 54%,rgba(227,243,239,.26))!important}
.role-readiness-person-spec-missing{border-color:rgba(184,169,219,.3)!important;background:linear-gradient(135deg,rgba(238,233,251,.58),#fff 54%,rgba(238,233,251,.28))!important}
.role-readiness-approved strong{color:#15803d}
.role-readiness-review strong{color:#c56a1d}
.role-readiness-missing strong{color:#b91c1c}
.role-readiness-primary strong{color:#004681}
.role-readiness-secondary strong{color:#8a673f}
.role-readiness-person-spec strong{color:#15803d}
.role-readiness-person-spec-missing strong{color:#6b5ca5}
.role-readiness-good{border-color:rgba(52,168,93,.26)!important;background:linear-gradient(135deg,rgba(184,232,197,.42),#fff 54%,rgba(184,232,197,.18))!important}
.role-readiness-warning{border-color:rgba(221,138,70,.34)!important;background:linear-gradient(135deg,rgba(242,207,170,.44),#fff 54%,rgba(242,207,170,.2))!important}
.role-readiness-bad{border-color:rgba(248,113,113,.28)!important;background:linear-gradient(135deg,rgba(254,226,226,.62),#fff 54%,rgba(254,226,226,.3))!important}
.role-readiness-good strong{color:#15803d!important}
.role-readiness-warning strong{color:#c56a1d!important}
.role-readiness-bad strong{color:#b91c1c!important}
.role-library-stats{align-self:stretch}
.role-library-stats .role-stat-card{box-shadow:0 8px 20px rgba(14,32,74,.04);position:relative;overflow:hidden;color:var(--navy)}
.role-library-stats .role-stat-card::after{content:"";position:absolute;inset:0;background-image:radial-gradient(var(--role-dot,rgba(14,32,74,.12)) 1px,transparent 1px);background-size:13px 13px;opacity:.2;pointer-events:none}
.role-library-stats .role-stat-card strong,.role-library-stats .role-stat-card span{position:relative;z-index:1}
.role-library-stats .role-stat-card strong{color:var(--navy)}
.role-library-stats .role-stat-card span{color:#334155}
.role-stat-academic{background:linear-gradient(135deg,#d9ecfb,#c3ddf4)!important;border-color:#8ab8dc!important;--role-dot:#5f97c3}
.role-stat-non-teaching-academic{background:linear-gradient(135deg,#e3f3ef,#cce9df)!important;border-color:#8ccdb9!important;--role-dot:#56ae94}
.role-stat-specialist{background:linear-gradient(135deg,#fff3c4,#ffe7a3)!important;border-color:#dfbd4d!important;--role-dot:#c49a18}
.role-stat-technical{background:linear-gradient(135deg,#ffe1c8,#ffcfa8)!important;border-color:#e69a62!important;--role-dot:#c97337}
.role-stat-administrative{background:linear-gradient(135deg,#eee9fb,#ded6f3)!important;border-color:#b8a9db!important;--role-dot:#8a77bd}
.role-stat-non-academic{background:linear-gradient(135deg,#edf1f6,#dfe6ef)!important;border-color:#b5c2d2!important;--role-dot:#8091a6}
.role-stat-newly-added-job-role{background:linear-gradient(135deg,#f7e7f5,#ead2eb)!important;border-color:#bd83be!important;--role-dot:#9b4a9d}
.role-filter-panel{display:flex;flex-direction:column;gap:16px;background:#fff;border:1px solid rgba(14,32,74,.12);border-radius:14px;padding:18px 20px;box-shadow:0 12px 32px rgba(14,32,74,.06);margin-bottom:24px}
.role-filter-panel-title{display:flex;align-items:center;gap:12px;color:var(--gold);font-size:15px;font-weight:900;letter-spacing:1.1px;text-transform:uppercase}
.role-filter-panel-title::after{content:"";height:1px;background:rgba(14,32,74,.1);flex:1}
.role-filter-row{display:grid;gap:16px;align-items:end}
.role-filter-primary-row{grid-template-columns:minmax(360px,1fr) auto}
.role-filter-secondary-row{grid-template-columns:repeat(4,minmax(180px,1fr))}
.role-filter-field label{display:block;font-size:10px;font-weight:800;letter-spacing:.8px;text-transform:uppercase;color:#66738a;margin-bottom:7px}
.role-filter-field select,.role-filter-field input{height:44px}
.role-filter-count{min-width:112px;height:44px;display:flex;align-items:center;justify-content:center;gap:8px;border:1px solid rgba(0,70,129,.14);border-radius:10px;background:#eef5fb;color:var(--blue)}
.role-filter-count strong{font-size:18px;line-height:1}
.role-filter-count span{font-size:10px;font-weight:800;letter-spacing:.7px;text-transform:uppercase}
.role-library-list-panel{background:#fff;border:1px solid rgba(14,32,74,.12);border-radius:14px;padding:24px;box-shadow:0 12px 32px rgba(14,32,74,.06)}
.role-library-list-panel .vacancy-list-head>div{width:100%}
.role-library-list-panel .vacancy-list-head h2{display:flex;align-items:center;gap:12px;width:100%;font-family:'DM Sans','Calibri','Segoe UI',system-ui,sans-serif;font-size:15px;font-weight:900;letter-spacing:1.1px;text-transform:uppercase;color:var(--gold)!important}
.role-library-list-panel .vacancy-list-head h2::after{content:"";height:1px;background:rgba(14,32,74,.1);flex:1}
.role-library-list-panel .vacancy-list-head h2 span{flex:0 0 auto;color:var(--gold)!important;font-size:inherit;font-weight:inherit;letter-spacing:inherit}
body.light-mode #app .role-library-list-panel .vacancy-list-head h2,
body.light-mode #app .role-library-list-panel .vacancy-list-head h2 span{color:var(--gold)!important}
.role-library-secondary-panel{margin-top:22px;background:linear-gradient(180deg,#fbfdff,#f7fafe);border-style:dashed}
.role-library-secondary-panel .role-card{background:#fbfdff}
.role-library-list{display:grid;grid-template-columns:1fr;gap:12px}
.role-card{margin:0!important;border-color:rgba(14,32,74,.12)!important;box-shadow:none!important;position:relative;overflow:hidden}
.role-card::before{content:"";position:absolute;left:0;top:0;bottom:0;width:5px;background:var(--role-accent,var(--blue));z-index:2;pointer-events:none}
.role-card-academic{--role-accent:#8ab8dc}
.role-card-non-teaching-academic{--role-accent:#8ccdb9}
.role-card-specialist{--role-accent:#dfbd4d}
.role-card-technical{--role-accent:#e69a62}
.role-card-administrative{--role-accent:#b8a9db}
.role-card-non-academic{--role-accent:#b5c2d2}
.role-card-newly-added-job-role{--role-accent:#9b4a9d}
.role-row{padding:18px 22px 18px 70px!important;gap:14px;position:relative}
.role-row-main{flex:1;min-width:0}
.role-title{font-size:16px;font-weight:800;color:var(--navy);line-height:1.25}
.role-meta-line{display:flex;flex-direction:column;gap:4px;margin-top:7px;font-size:12px;color:#66738a}
.role-meta-line span{position:relative}
.role-meta-line strong{color:#3f4d68;font-size:11px;letter-spacing:.6px}
.role-primary-switch{display:inline-flex;align-items:center;gap:9px;width:max-content;margin-top:8px;color:#3f4d68;cursor:pointer;user-select:none}
.role-primary-switch input{position:absolute;opacity:0;pointer-events:none}
.role-primary-switch strong{color:#3f4d68;font-size:11px;font-weight:900;letter-spacing:.7px;text-transform:uppercase;line-height:1}
.role-primary-switch-active{display:inline-flex;align-items:center;color:#159447;font-size:10px;font-weight:900;letter-spacing:.08em;line-height:1;max-width:0;opacity:0;overflow:hidden;text-transform:uppercase;transition:max-width .16s ease,opacity .16s ease}
.role-primary-switch-track{position:relative;display:inline-flex;align-items:center;width:34px;height:18px;border:1px solid rgba(14,32,74,.18);border-radius:999px;background:#e5eaf0;box-shadow:inset 0 1px 2px rgba(14,32,74,.08);transition:background .16s ease,border-color .16s ease,box-shadow .16s ease}
.role-primary-switch-track span{position:absolute;left:2px;width:14px;height:14px;border-radius:999px;background:#fff;box-shadow:0 1px 3px rgba(14,32,74,.18);transition:transform .16s ease,background .16s ease}
.role-primary-switch input:checked+.role-primary-switch-track{background:#d9ecfb;border-color:#9dc5e6;box-shadow:inset 0 1px 2px rgba(0,70,129,.08),0 0 0 2px rgba(0,70,129,.04)}
.role-primary-switch input:checked+.role-primary-switch-track span{transform:translateX(16px);background:#004681}
.role-primary-switch:hover .role-primary-switch-track{border-color:#7eb3dd;box-shadow:inset 0 1px 2px rgba(0,70,129,.08),0 4px 12px rgba(0,70,129,.08)}
.role-primary-switch.armed .role-primary-switch-active{max-width:54px;opacity:1}
.role-primary-switch.armed .role-primary-switch-track{background:#dff5e7;border-color:#6ecb8f;box-shadow:inset 0 1px 2px rgba(21,148,71,.1),0 0 0 3px rgba(21,148,71,.1)}
.role-primary-switch.armed .role-primary-switch-track span{background:#159447}
.role-chip-row{display:flex;align-items:center;justify-content:flex-end;gap:8px;flex-wrap:wrap}
.role-chip{display:inline-flex;align-items:center;white-space:nowrap;border-radius:999px;border:1px solid rgba(14,32,74,.1);font-size:11px;font-weight:800;letter-spacing:.5px;text-transform:uppercase;padding:6px 10px}
.role-chip-select{appearance:none;-webkit-appearance:none;background-clip:padding-box;background-image:linear-gradient(45deg,transparent 50%,currentColor 50%),linear-gradient(135deg,currentColor 50%,transparent 50%);background-position:calc(100% - 15px) 50%,calc(100% - 10px) 50%;background-repeat:no-repeat;background-size:5px 5px;cursor:pointer;font-family:inherit;line-height:1.2;min-width:108px;width:auto!important;max-width:260px;padding:7px 28px 7px 12px;text-align:center;text-align-last:center;transition:border-color .15s ease,box-shadow .15s ease,transform .15s ease}
.role-chip-select:hover{box-shadow:0 6px 16px rgba(14,32,74,.1);transform:translateY(-1px)}
.role-chip-select:focus{outline:2px solid rgba(0,70,129,.22);outline-offset:2px}
.role-chip-select:disabled{cursor:progress;opacity:.7;transform:none}
.role-chip-academic{background:#d9ecfb;color:#0e3357;border-color:#8ab8dc}
.role-chip-non-teaching-academic{background:#e3f3ef;color:#174c41;border-color:#8ccdb9}
.role-chip-specialist{background:#fff3c4;color:#674f05;border-color:#dfbd4d}
.role-chip-technical{background:#ffe1c8;color:#6a3415;border-color:#e69a62}
.role-chip-administrative{background:#eee9fb;color:#44366b;border-color:#b8a9db}
.role-chip-non-academic{background:#edf1f6;color:#334155;border-color:#b5c2d2}
.role-chip-newly-added-job-role{background:#f7e7f5;color:#5b255f;border-color:#bd83be}
.role-chip-blue{background:#e6f0f8;color:#004681;border-color:rgba(0,70,129,.22)}
.role-chip-gold{background:#f6efe5;color:#8a673f;border-color:rgba(178,139,93,.3)}
.role-chip-muted{background:#eef2f6;color:#475569;border-color:rgba(100,116,139,.24)}
.role-chip-green{background:rgba(74,222,128,.11);color:#15803d;border-color:rgba(74,222,128,.2)}
.role-chip-warning{background:rgba(178,139,93,.12);color:#8a673f;border-color:rgba(178,139,93,.22)}
.role-chip-select{background-image:linear-gradient(45deg,transparent 50%,currentColor 50%),linear-gradient(135deg,currentColor 50%,transparent 50%);background-position:calc(100% - 15px) 50%,calc(100% - 10px) 50%;background-repeat:no-repeat;background-size:5px 5px}
.role-criteria-status-dot{width:30px;height:30px;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;border:2px solid rgba(14,32,74,.12);box-shadow:0 8px 20px rgba(14,32,74,.09),inset 0 2px 0 rgba(255,255,255,.5);cursor:help}
.role-row-criteria-status{position:absolute;left:25px;top:50%;transform:translateY(-50%);margin:0}
.role-criteria-status-adequate{background:linear-gradient(180deg,#b8e8c5,#62c982);border-color:#34a85d}
.role-criteria-status-missing{background:linear-gradient(180deg,#f4c4c4,#df6b6b);border-color:#c94f4f}
.role-criteria-status-inadequate{background:linear-gradient(180deg,#f2cfaa,#dd8a46);border-color:#bf6d2c}
.role-criteria-status-in-use{background:linear-gradient(180deg,#b9d4ed,#5f99cc);border-color:#2f6fa5}
.job-spec-edit-warning{background:#fff1f2;border:1px solid rgba(248,113,113,.28);border-left:4px solid #ef4444;border-radius:10px;color:#7f1d1d;font-size:13px;font-weight:700;line-height:1.5;margin:10px 0 18px;padding:12px 14px}
.job-spec-edit-warning strong{display:block;margin-bottom:4px;text-transform:uppercase;letter-spacing:.06em}
.job-spec-edit-warning p{margin:0 0 10px;color:#7f1d1d}
.job-role-readonly-title{border:1px solid rgba(14,32,74,.12);border-radius:10px;background:#f8fafc;margin:0 0 16px;padding:12px 14px}
.job-role-readonly-title span{display:block;color:#66738a;font-size:10px;font-weight:900;letter-spacing:.08em;margin-bottom:4px;text-transform:uppercase}
.job-role-readonly-title strong{color:var(--navy);font-size:16px}
.person-spec-alignment-review{display:grid;gap:10px;margin:14px 0}
.person-spec-alignment-review>strong{color:var(--navy);font-size:13px;font-weight:900;letter-spacing:.08em;text-transform:uppercase}
.person-spec-alignment-review>p{color:#66738a;font-size:13px;line-height:1.45;margin:0}
.person-spec-alignment-action{display:flex;align-items:flex-start;gap:10px;border:1px solid rgba(14,32,74,.12);border-radius:10px;background:#f8fafc;padding:12px}
.person-spec-alignment-action input{width:auto;margin-top:3px;flex:0 0 auto}
.person-spec-alignment-action span{display:grid;gap:5px;color:var(--navy);font-size:13px;line-height:1.4}
.person-spec-alignment-action small{color:#4f5f79;font-size:12px;line-height:1.4}
.person-spec-alignment-action em{color:#66738a;font-size:12px;font-style:normal;line-height:1.4}
.role-category-editor{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin:8px 0 18px}
.role-category-check{display:flex;align-items:flex-start;gap:10px;border:1px solid rgba(14,32,74,.12);border-radius:10px;background:#f8fafc;padding:12px;cursor:pointer}
.role-category-check input{width:auto;margin-top:3px;flex:0 0 auto}
.role-category-check span{display:block}
.role-category-check strong{display:block;font-size:13px;color:var(--navy);margin-bottom:2px}
.role-category-check small{display:block;font-size:11px;line-height:1.45;color:#66738a}
.home-menu{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:22px;margin:0 auto}
.dashboard-tool-section{margin:24px 0;padding:0}
.dashboard-admin-section{margin-top:0}
.dashboard-section-heading{display:flex;align-items:center;gap:12px;margin-bottom:16px;color:var(--navy)}
.dashboard-section-heading::after{content:"";height:1px;background:rgba(14,32,74,.1);flex:1}
.dashboard-section-heading span{font-size:15px;font-weight:800;letter-spacing:1.1px;text-transform:uppercase;color:var(--gold)}
.dashboard-utility-menu{margin-top:22px}
.home-menu-btn{min-height:176px;text-align:left;background:#fff;border:1px solid rgba(14,32,74,.14);border-radius:12px;padding:26px;cursor:pointer;color:var(--navy);font-family:inherit;transition:all .2s;display:flex;flex-direction:column;justify-content:space-between;gap:20px;overflow:hidden;box-shadow:0 14px 36px rgba(14,32,74,.08)}
.home-menu-btn:last-child:nth-child(odd){grid-column:1/-1;width:calc((100% - 18px)/2);justify-self:center}
.home-menu-btn:hover{border-color:rgba(0,70,129,.28);background:#f9fbff;transform:translateY(-2px);box-shadow:0 18px 44px rgba(14,32,74,.12)}
.home-menu-top{display:flex;align-items:flex-start;gap:16px}
.home-menu-graphic{width:56px;height:56px;flex:0 0 56px;border:1px solid var(--gold-border);border-radius:12px;background:rgba(178,139,93,0.1);color:var(--gold-light);display:flex;align-items:center;justify-content:center}
.home-menu-graphic svg{width:32px;height:32px;display:block}
.home-menu-title{display:block;font-size:20px;font-weight:700;color:var(--navy);margin-bottom:8px}
.home-menu-desc{display:block;font-size:13px;color:#66738a;line-height:1.62;max-width:330px}
.home-menu-cta{font-size:12px;font-weight:700;color:var(--gold);text-transform:uppercase;letter-spacing:.8px;display:flex;gap:12px;flex-wrap:wrap}
.home-menu-stat{display:inline-flex;white-space:nowrap}
.home-menu-stat+.home-menu-stat::before{content:"|";color:var(--text-faint);margin-right:12px}
.page-action-bar{width:100%;display:flex;flex-direction:column;gap:14px;margin-bottom:26px;background:#fff;border:1px solid rgba(14,32,74,.12);border-radius:14px;padding:18px 20px;box-shadow:0 12px 32px rgba(14,32,74,.06)}
body.light-mode .page-action-bar{background:#fff!important;border-color:rgba(14,32,74,.12);box-shadow:0 12px 32px rgba(14,32,74,.06)}
.page-action-bar-title{display:flex;align-items:center;gap:12px;color:var(--gold);font-size:15px;font-weight:900;letter-spacing:1.1px;text-transform:uppercase}
.page-action-bar-title::after{content:"";height:1px;background:rgba(14,32,74,.1);flex:1}
.page-action-bar-content{display:flex;align-items:stretch;justify-content:flex-start;gap:16px}
body.light-mode .home-btn,body.light-mode .page-action-btn{background:var(--blue);border-color:rgba(255,255,255,.1);color:#fff}
.page-action-group{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.page-action-nav{display:flex;align-items:stretch;flex:0 0 clamp(210px,23%,300px)}
.page-action-nav .home-btn{width:100%;justify-content:center}
.page-action-nav .home-btn-icon-only{min-height:92px;padding:18px}
.page-action-nav .home-btn-icon-only .page-action-icon{width:42px;height:42px;flex-basis:42px}
.page-action-functions{flex:1 1 auto;align-content:center}
.page-action-functions .page-action-btn{width:340px;justify-content:center}
.page-action-separator{width:2px;align-self:stretch;min-height:48px;background:rgba(0,70,129,.34);margin:0 6px;flex:0 0 2px}
.home-btn,.page-action-btn{display:inline-flex;align-items:center;gap:10px;min-height:52px;padding:13px 18px;background:var(--blue);border:2px solid rgba(255,255,255,.1);border-radius:10px;color:#fff;font-size:14px;font-weight:800;font-family:inherit;cursor:pointer;transition:background .18s,border-color .18s,color .18s,transform .16s,box-shadow .18s;box-shadow:0 10px 24px rgba(0,70,129,.18);transform-origin:center}
.home-btn{background:var(--blue);color:#fff;border-color:rgba(255,255,255,.1)}
.page-action-btn:hover,.home-btn:hover{background:var(--blue-light);border-color:rgba(255,255,255,.42);color:#fff;transform:translateY(-2px);box-shadow:0 14px 30px rgba(0,70,129,.22)}
.page-action-btn:active,.home-btn:active{background:var(--blue);border-color:rgba(255,255,255,.32);color:#fff;transform:scale(.98);box-shadow:0 6px 16px rgba(0,70,129,.18)}
.page-action-icon{width:19px;height:19px;display:block;flex:0 0 19px}
.admin-layout{display:grid;grid-template-columns:280px minmax(0,1fr);gap:18px}
.admin-user-list{background:var(--navy);border:1px solid var(--border);border-radius:12px;padding:12px;display:flex;flex-direction:column;gap:8px}
.admin-user-row{width:100%;text-align:left;border:1px solid var(--border);border-radius:10px;background:transparent;color:var(--text-mid);padding:12px;cursor:pointer;font-family:inherit;transition:all .2s}
.admin-user-row:hover,.admin-user-row.active{background:var(--surface-hover);border-color:rgba(10,90,158,.55);color:var(--white)}
.admin-user-row strong{display:block;color:var(--white);font-size:14px;margin-bottom:2px}
.admin-user-row span{display:block;font-size:12px;color:var(--text-muted);overflow-wrap:anywhere}
.admin-user-lock-tag{display:inline-flex!important;align-items:center;width:max-content;margin-left:6px;padding:2px 6px;border:1px solid rgba(191,145,82,.42);border-radius:999px;background:rgba(191,145,82,.12);color:var(--gold-light)!important;font-size:10px!important;font-weight:900;letter-spacing:.06em;text-transform:uppercase;vertical-align:middle}
.admin-form{background:var(--navy);border:1px solid var(--border);border-radius:12px;padding:22px}
.admin-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.admin-impersonation-control{display:flex;flex-direction:column;align-items:flex-end;gap:6px;min-width:180px}
.admin-impersonation-control .btn-outline{min-height:40px;white-space:nowrap;font-weight:800}
.admin-impersonation-control .btn-outline:disabled{opacity:.48;cursor:not-allowed}
.admin-impersonation-control span{font-size:11px;line-height:1.35;color:var(--text-muted);text-align:right;max-width:220px}
.admin-user-lock-notice{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:6px 14px;margin-bottom:16px;padding:12px 14px;border:1px solid rgba(191,145,82,.26);border-radius:10px;background:rgba(191,145,82,.08);color:var(--text-muted);font-size:13px;line-height:1.45}
.admin-user-lock-notice strong{color:var(--gold-light);font-size:12px;font-weight:900;letter-spacing:.08em;text-transform:uppercase}
.admin-user-lock-notice span{grid-column:1;color:var(--text-muted)}
.admin-user-lock-notice .btn-outline{grid-column:2;grid-row:1 / span 2;min-height:38px;white-space:nowrap}
.role-session-security-field{grid-column:1/-1}
.role-session-security-panel{border:1px solid var(--border);border-radius:12px;background:rgba(255,255,255,.025);padding:14px}
.role-session-security-control{display:flex;align-items:center;gap:10px;max-width:100%;min-height:44px;flex-wrap:wrap}
.role-session-lock-toggle{display:inline-flex;align-items:center;gap:10px;min-height:44px;margin:0!important;padding:0 14px;border:1px solid var(--border);border-radius:10px;background:var(--navy-light);color:var(--text-mid)!important;text-transform:none!important;letter-spacing:0!important;font-size:13px!important;font-weight:800!important;white-space:nowrap}
.role-session-lock-toggle input{width:auto;margin:0;accent-color:var(--blue)}
.role-session-lock-toggle span{line-height:1.3}
.role-session-minutes{display:inline-flex;align-items:center;gap:8px;min-height:44px;padding:0 12px;border:1px solid var(--border);border-radius:10px;background:var(--navy-light);color:var(--text-muted);font-size:12px;font-weight:800;white-space:nowrap}
.role-session-minutes input{width:70px!important;min-height:0!important;height:32px!important;text-align:center;margin:0!important;padding:4px 8px!important;border-radius:8px!important}
.role-session-minutes.disabled{opacity:.48}
.role-session-minutes.disabled input{cursor:not-allowed}
body.light-mode #app .role-session-lock-toggle,
body.light-mode #app .role-session-minutes{background:#f8fafc;border-color:rgba(14,32,74,.16);color:#66738a!important}
body.light-mode #app .role-session-security-panel{background:#f8fafc;border-color:rgba(14,32,74,.14)}
body.light-mode #app .role-session-lock-toggle span{color:#66738a}
.admin-section{background:var(--navy);border:1px solid var(--border);border-radius:12px;margin-bottom:18px;overflow:hidden}
.admin-section summary{list-style:none;display:flex;align-items:center;justify-content:space-between;gap:14px;padding:18px 22px;cursor:pointer}
.admin-section summary::-webkit-details-marker{display:none}
.admin-section summary h3{display:flex;align-items:center;gap:12px;font-family:inherit;font-size:15px;font-weight:900;color:var(--gold);letter-spacing:1.8px;text-transform:uppercase;margin:0 0 4px}
.admin-section summary h3::before{content:"";width:28px;height:3px;border-radius:999px;background:rgba(178,139,93,.46)}
.admin-section summary p{font-size:13px;color:var(--text-muted);margin:0}
.admin-section summary::after{content:"▾";color:var(--text-muted);font-size:14px;transition:transform .2s}
.admin-section:not([open]) summary::after{transform:rotate(-90deg)}
.admin-section-body{padding:0 22px 22px}
.permission-accordion{display:grid;grid-template-columns:1fr;gap:10px}
.permission-area{border:1px solid var(--border);border-radius:10px;background:rgba(9,22,55,.22);overflow:hidden}
.permission-area summary{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:0;cursor:pointer;list-style:none}
.permission-area summary::-webkit-details-marker{display:none}
.permission-area summary::after{content:"▾";color:var(--text-muted);font-size:13px;margin-right:14px;transition:transform .2s}
.permission-area:not([open]) summary::after{transform:rotate(-90deg)}
.permission-actions{border-top:1px solid var(--border);padding:12px 14px 14px;display:grid;grid-template-columns:1fr;gap:10px;background:rgba(255,255,255,.025)}
.permission-empty{font-size:12px;color:var(--text-muted);line-height:1.45;margin:0}
.permission-check{display:flex;gap:10px;align-items:flex-start;padding:10px 12px;border:1px solid var(--border);border-radius:10px;background:rgba(9,22,55,.28);font-size:13px;color:var(--text-mid);cursor:pointer}
.permission-area-check{flex:1;border:0;border-radius:0;background:transparent;padding:12px 14px}
.permission-action-check{background:rgba(9,22,55,.28)}
.permission-check input{width:16px;height:16px;margin-top:1px;accent-color:var(--gold)}
.permission-check span{display:block}
.permission-check strong{display:block;color:inherit;font-size:13px;line-height:1.35}
.permission-check small{display:block;color:var(--text-muted);font-size:11px;line-height:1.45;margin-top:4px}
.permission-check.disabled{opacity:.62;cursor:not-allowed}
.permission-check.permission-child-disabled{opacity:.48;cursor:not-allowed}
.user-editor-actions,.role-editor-actions,.logging-editor-actions{width:100%;display:grid;grid-template-columns:repeat(3,minmax(180px,220px));gap:14px;justify-content:end;align-items:stretch}
.user-editor-actions{margin-top:20px}
.role-editor-actions{margin:-4px 0 0;padding-top:16px}
.logging-editor-actions{margin-top:20px}
.user-editor-actions.no-danger::before,.role-editor-actions.no-danger::before,.logging-editor-actions.no-danger::before{content:""}
.user-editor-actions .btn,.user-editor-actions .btn-outline,.role-editor-actions .btn,.role-editor-actions .btn-outline,.logging-editor-actions .btn,.logging-editor-actions .btn-outline{width:100%;min-width:0;min-height:54px;border-radius:10px;font-size:14px;font-weight:800}
.role-delete-action,.user-delete-action,.logging-purge-action{order:10}
.card{background:var(--navy);border-radius:14px;border:1px solid var(--border);padding:28px;transition:border-color .3s}.card:hover{border-color:var(--gold-border)}
.card-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.notice{margin-top:24px;background:#fff;border-radius:12px;border:1px solid rgba(14,32,74,.12);padding:16px 20px;display:flex;gap:12px;font-size:13px;color:#66738a;line-height:1.6;box-shadow:0 12px 32px rgba(14,32,74,.06)}
.notice strong{color:var(--gold)}
.dashboard-oversight-notice{margin:0 0 24px;align-items:stretch;gap:18px;padding:18px 20px;font-size:15px;color:#4c5870;border-color:rgba(178,139,93,.28);background:linear-gradient(180deg,#fff 0,#fffaf2 100%)}
.dashboard-oversight-notice div{flex:1;align-self:center}
.dashboard-oversight-notice strong{font-size:16px;color:var(--navy)}
.admin-logging-notice{margin:18px 0 0}
.notice-warning-icon{display:flex;align-items:center;justify-content:center;align-self:stretch;color:var(--gold);min-width:34px}
.notice-warning-icon svg{width:34px;height:100%;min-height:48px;display:block}
/* Form elements */
select,input[type="text"],input[type="password"],input[type="email"],input[type="tel"],input[type="number"]{width:100%;padding:10px 14px;background:var(--navy-light);border:1px solid var(--border);border-radius:8px;color:var(--text-light);font-size:14px;font-family:inherit;outline:none;transition:border-color .2s}
select:focus,input[type="text"]:focus,input[type="password"]:focus,input[type="email"]:focus,input[type="tel"]:focus,input[type="number"]:focus{border-color:var(--gold-border)}
select option{background:var(--navy);color:var(--text-light)}
label{display:block;font-size:12px;font-weight:600;color:var(--text-faint);text-transform:uppercase;letter-spacing:1px;margin-bottom:6px}
.upload-zone{background:var(--navy);border:2px dashed var(--border);border-radius:14px;padding:32px;text-align:center;cursor:pointer;transition:all .2s}
.upload-zone:hover{border-color:var(--gold-border);background:rgba(178,139,93,0.04)}
.upload-zone.has-file{border-color:rgba(74,222,128,0.2);border-style:solid}
.file-tags{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:20px}
.file-tag{display:flex;align-items:center;gap:8px;background:var(--navy-light);border:1px solid var(--border);padding:6px 12px;border-radius:8px;font-size:12px;color:var(--text-mid)}
.file-tag button{background:none;border:none;color:var(--text-faint);cursor:pointer;font-size:15px}.file-tag button:hover{color:var(--red)}
.error-box{background:rgba(248,113,113,0.08);border:1px solid rgba(248,113,113,0.2);border-radius:10px;padding:10px 14px;font-size:13px;color:#fca5a5;margin-bottom:20px}
/* Analysing */
.spinner{display:inline-block;width:56px;height:56px;border:3px solid var(--navy-lighter);border-top-color:var(--gold);border-radius:50%;animation:spin .9s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.progress-track{height:4px;background:var(--navy-lighter);border-radius:2px;overflow:hidden;max-width:320px;margin:0 auto}
.progress-fill{height:100%;background:linear-gradient(90deg,var(--gold),var(--gold-light));border-radius:2px;transition:width .5s}
/* Results */
.candidate-card{background:var(--navy);border-radius:14px;border:1px solid var(--border);overflow:hidden;transition:all .3s;margin-bottom:12px}
.candidate-card.expanded{border-color:var(--gold-border);box-shadow:0 4px 40px rgba(178,139,93,0.06)}
.candidate-row{padding:20px 24px;cursor:pointer;display:flex;align-items:center;gap:20px;transition:background .15s}
.candidate-row:hover{background:var(--surface-hover)}
.rank{width:36px;text-align:center;font-size:20px;font-weight:800}
.rank-1{color:var(--gold);text-shadow:0 0 16px rgba(178,139,93,0.4)}.rank-2{color:#94a3b8}.rank-3{color:#cd7f32}.rank-other{color:var(--text-faint)}
.candidate-info{flex:1;min-width:0}.candidate-name{font-size:16px;font-weight:600;color:var(--white);margin-bottom:2px}.candidate-meta{font-size:12px;color:var(--text-muted);overflow-wrap:anywhere}
.talent-row-main{flex:1;min-width:0}
.data-reliability{width:168px;flex:0 0 168px;border:1px solid var(--border);border-radius:10px;padding:10px 12px;background:rgba(255,255,255,.025)}
.data-reliability-head{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:7px}
.data-reliability-label{font-size:9px;font-weight:800;color:var(--text-faint);text-transform:uppercase;letter-spacing:.8px}
.data-reliability-value{font-size:13px;font-weight:800}
.data-reliability-track{height:6px;border-radius:999px;background:var(--navy-lighter);overflow:hidden}
.data-reliability-fill{height:100%;border-radius:999px;transition:width .3s,background-color .3s}
.data-reliability-age{font-size:10px;color:var(--text-muted);margin-top:6px;white-space:nowrap}
.mini-scores{display:flex;gap:14px}.mini-score{text-align:center;min-width:36px}.mini-score-label{font-size:10px;color:var(--text-faint);font-weight:600;letter-spacing:.5px;margin-bottom:2px}.mini-score-value{font-size:15px;font-weight:700}
.expand-arrow{color:var(--text-faint);font-size:18px;transition:transform .3s}.expanded .expand-arrow{transform:rotate(180deg)}
.detail-panel{padding:0 24px 24px;animation:slideDown .3s ease}
@keyframes slideDown{from{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}
.detail-divider{height:1px;background:var(--border);margin-bottom:20px}
.detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.detail-section-title{font-size:11px;font-weight:700;color:var(--text-faint);text-transform:uppercase;letter-spacing:1.5px;margin-bottom:14px}
.role-detail-primary-title{display:flex;align-items:center;gap:10px;margin:0;color:#3f4d68;font-size:12px;font-weight:900;letter-spacing:1.8px}
.role-detail-primary-title:before{content:"";width:28px;height:3px;border-radius:999px;background:rgba(178,139,93,.46)}
.role-detail-section-header{display:flex;justify-content:space-between;align-items:center;gap:16px;margin-bottom:12px}
.role-detail-actions{display:flex;gap:8px;justify-content:flex-end;align-items:center;flex-wrap:wrap;margin-left:auto}
.role-detail-job-description{margin-bottom:18px}
.role-detail-section-break{height:1px;background:rgba(14,32,74,.12);margin:22px 0;position:relative}
.role-detail-section-break:before{content:none}
.role-detail-scoring-criteria{padding-top:2px}
.role-detail-action-btn{box-sizing:border-box;width:calc((100% - 30px)/4);min-width:0;max-width:none;height:48px;min-height:48px;display:inline-flex;align-items:center;justify-content:center;text-align:center;white-space:normal;line-height:1.12;padding-top:6px!important;padding-bottom:6px!important}
.role-record-toolbar{position:relative;display:flex;align-items:center;justify-content:flex-end;gap:10px;border:1px solid rgba(14,32,74,.12);border-radius:14px;background:linear-gradient(135deg,#fbfdff,#fff);box-shadow:0 10px 24px rgba(14,32,74,.04);padding:20px 14px 12px;margin:4px 0 20px;flex-wrap:wrap}
.role-record-toolbar-label{position:absolute;left:18px;top:0;transform:translateY(-50%);background:#fff;padding:0 9px;font-size:10px;font-weight:800;letter-spacing:1px;text-transform:uppercase;color:#66738a;white-space:nowrap}
.role-record-toolbar .role-detail-action-btn{width:calc((100% - 30px)/4);min-width:0;max-width:none;flex:0 1 calc((100% - 30px)/4);height:48px;min-height:48px}
.job-role-export-modal{max-width:820px}
.job-role-export-intro{font-size:13px;color:var(--text-muted);line-height:1.55;margin:0 0 16px}
.job-role-export-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:16px}
.job-role-export-box{border:1px solid rgba(14,32,74,.12);border-radius:14px;background:linear-gradient(135deg,#f8fbff,#fff);box-shadow:0 10px 22px rgba(14,32,74,.035);padding:14px}
.job-role-export-box h4{margin:0 0 10px;color:var(--navy);font-size:12px;font-weight:900;letter-spacing:.1em;text-transform:uppercase}
.job-role-export-choice,.job-role-export-section{display:flex;align-items:flex-start;gap:10px;border:1px solid rgba(14,32,74,.1);border-radius:10px;background:#fff;cursor:pointer;margin-bottom:8px;padding:10px 11px}
.job-role-export-choice input,.job-role-export-section input{accent-color:var(--blue);margin-top:2px}
.job-role-export-choice span{display:grid;gap:3px}
.job-role-export-choice strong,.job-role-export-section span{color:var(--navy);font-size:13px;font-weight:850}
.job-role-export-choice small{color:#66738a;font-size:12px;line-height:1.35}
@media (max-width:760px){.job-role-export-grid{grid-template-columns:1fr}}
.role-description-toolbar{position:relative;display:flex;align-items:center;justify-content:flex-end;gap:14px;border:1px solid rgba(14,32,74,.12);border-radius:14px;background:linear-gradient(135deg,#f8fafc,#fff);box-shadow:0 12px 26px rgba(14,32,74,.045);padding:22px 14px 12px;margin:8px 0 14px}
.role-description-toolbar-label{position:absolute;left:18px;top:0;transform:translateY(-50%);background:#fff;padding:0 9px;font-size:10px;font-weight:800;letter-spacing:1px;text-transform:uppercase;color:#66738a;white-space:nowrap}
.role-description-toolbar-actions{display:flex;align-items:stretch;justify-content:flex-end;gap:10px;flex:1;min-width:0;flex-wrap:wrap}
.role-description-toolbar-actions .role-detail-action-btn{width:calc((100% - 30px)/4);min-width:0;flex:0 1 calc((100% - 30px)/4);max-width:none;min-height:42px;padding-left:12px;padding-right:12px;white-space:nowrap}
.role-description-toolbar-actions .btn-danger{margin-left:2px}
.role-person-spec-toolbar{position:relative;display:flex;align-items:center;justify-content:flex-end;gap:14px;border:1px solid rgba(14,32,74,.12);border-radius:14px;background:linear-gradient(135deg,#f8fafc,#fff);box-shadow:0 12px 26px rgba(14,32,74,.045);padding:22px 14px 12px;margin:8px 0 14px}
.role-person-spec-toolbar-label{position:absolute;left:18px;top:0;transform:translateY(-50%);background:#fff;padding:0 9px;font-size:10px;font-weight:800;letter-spacing:1px;text-transform:uppercase;color:#66738a;white-space:nowrap}
.role-person-spec-toolbar-actions{display:flex;align-items:stretch;justify-content:space-between;gap:10px;flex:1;min-width:0;flex-wrap:wrap}
.role-person-spec-toolbar-actions.has-person-spec{justify-content:flex-end}
.role-person-spec-toolbar-actions>.role-detail-action-btn{width:calc((100% - 30px)/4);min-width:0;flex:0 1 calc((100% - 30px)/4);max-width:none;min-height:42px;padding-left:12px;padding-right:12px;white-space:nowrap}
.role-person-spec-copy{display:grid;grid-template-columns:190px minmax(360px,1fr);align-items:center;gap:0;margin-right:auto;width:min(100%,590px)}
.role-person-spec-copy select{box-sizing:border-box;height:52px;min-height:52px;min-width:0;background:#fff;border:2px solid rgba(178,139,93,.28);border-left:0;border-radius:0 10px 10px 0;color:var(--navy);font-size:12px;font-weight:800;padding:0 10px}
.role-person-spec-copy .role-person-spec-copy-btn{box-sizing:border-box;border-radius:10px 0 0 10px;box-shadow:none;height:52px;min-height:52px;min-width:150px;max-width:none;width:100%}
.role-person-spec-copy-empty{align-self:center;border:1px solid rgba(14,32,74,.1);border-radius:10px;background:#f8fafc;color:#66738a;font-size:12px;font-weight:800;padding:12px 14px}
.role-person-spec-display{background:#fff;border:1px solid rgba(14,32,74,.14);border-radius:10px;padding:0;max-height:520px;overflow:auto;color:#4f5f79;font-size:12px;line-height:1.48;box-shadow:0 12px 26px rgba(14,32,74,.035)}
.role-person-spec-empty{padding:16px 18px;text-align:center;color:#77839a;background:#f8fafc}
.person-spec-evidence-map{margin-top:12px;border:1px solid rgba(14,32,74,.12);border-radius:12px;background:linear-gradient(135deg,#f8fbff,#fff);box-shadow:0 10px 22px rgba(14,32,74,.035);padding:14px}
.person-spec-evidence-map-empty{display:grid;gap:5px;color:#65728a}
.person-spec-evidence-map-empty strong,.person-spec-evidence-map-head strong{color:var(--navy);font-size:13px;font-weight:900}
.person-spec-evidence-map-empty span,.person-spec-evidence-map-head span{color:#65728a;font-size:12px;line-height:1.45}
.person-spec-evidence-map-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:12px}
.person-spec-evidence-map-head>div:first-child{display:grid;gap:4px;max-width:680px}
.person-spec-evidence-map-counts{display:flex;align-items:center;justify-content:flex-end;gap:6px;flex-wrap:wrap}
.evidence-map-pill{appearance:none;border:1px solid rgba(14,32,74,.12);border-radius:999px;background:#fff;color:var(--navy);cursor:pointer;font-family:inherit;font-size:9px;font-weight:900;letter-spacing:.05em;padding:5px 8px;text-transform:uppercase;transition:box-shadow .15s ease,transform .15s ease,border-color .15s ease;white-space:nowrap}
.evidence-map-pill:hover{box-shadow:0 5px 14px rgba(14,32,74,.12);transform:translateY(-1px)}
.evidence-map-pill.active{box-shadow:0 0 0 2px rgba(14,32,74,.12),0 6px 16px rgba(14,32,74,.12);transform:translateY(-1px)}
.evidence-map-pill-all{background:#fff;border-color:rgba(14,32,74,.22);color:#0e204a}
.evidence-map-pill-document-assessable{background:#eaf7ef;border-color:#bfe7cc;color:#14532d}
.evidence-map-pill-partially-document-assessable{background:#fff6d8;border-color:#f1d480;color:#7a5623}
.evidence-map-pill-interview-reference{background:#eef2ff;border-color:#c7d2fe;color:#27376d}
.evidence-map-pill-compliance-check{background:#eaf4ff;border-color:#b9d8f2;color:#004681}
.evidence-map-pill-not-suitable-for-ai-scoring{background:#fff1f2;border-color:#fecdd3;color:#9f1239}
.person-spec-evidence-map-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}
.evidence-map-item{border-left:4px solid rgba(14,32,74,.18);border-radius:10px;background:#fff;border-top:1px solid rgba(14,32,74,.08);border-right:1px solid rgba(14,32,74,.08);border-bottom:1px solid rgba(14,32,74,.08);padding:10px 12px}
.evidence-map-item.is-filter-hidden,.evidence-map-item.is-preview-hidden{display:none}
.evidence-map-item-document-assessable{border-left-color:#5fc37d}
.evidence-map-item-partially-document-assessable{border-left-color:#f1c453}
.evidence-map-item-interview-reference{border-left-color:#8da2fb}
.evidence-map-item-compliance-check{border-left-color:#7ab8e8}
.evidence-map-item-not-suitable-for-ai-scoring{border-left-color:#fda4af}
.evidence-map-item-top{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:5px}
.evidence-map-item-top strong{color:var(--navy);font-size:11px;font-weight:900;letter-spacing:.06em;text-transform:uppercase}
.evidence-map-item-top span{color:#66738a;font-size:9px;font-weight:900;letter-spacing:.06em;text-transform:uppercase;white-space:nowrap}
.evidence-map-item p{color:#4f5f79;font-size:12px;line-height:1.4;margin:0 0 5px}
.evidence-map-item em{color:#66738a;display:block;font-size:11px;font-style:normal;line-height:1.4}
.person-spec-evidence-map-more{align-items:center;color:#66738a;display:flex;font-size:11px;font-weight:800;gap:10px;justify-content:flex-end;margin-top:10px;text-align:right}
.person-spec-evidence-map-more button{appearance:none;background:transparent;border:0;color:var(--blue);cursor:pointer;font-family:inherit;font-size:11px;font-weight:900;letter-spacing:.04em;padding:3px 0;text-transform:uppercase}
.person-spec-evidence-map-more button:hover{text-decoration:underline}
.role-person-spec-sections{display:grid;padding:14px;background:linear-gradient(180deg,#fff,#f8fbff)}
.role-person-spec-tabs{display:grid;grid-template-columns:repeat(auto-fit,minmax(132px,1fr));gap:6px 7px;margin:0 6px -1px;padding:8px 10px 0;border:1px solid rgba(14,32,74,.12);border-bottom:0;border-radius:14px 14px 0 0;background:linear-gradient(180deg,#e6eef6,#f7fbff);position:relative;z-index:2}
.role-person-spec-tab{appearance:none;border:1px solid rgba(14,32,74,.22);border-bottom-color:rgba(14,32,74,.3);border-radius:10px 10px 0 0;background:linear-gradient(180deg,rgba(14,32,74,.12),rgba(0,70,129,.07));color:var(--navy);cursor:pointer;display:flex;align-items:center;justify-content:space-between;gap:6px;height:34px;min-width:0;padding:0 10px;text-align:left;transition:background .16s ease,border-color .16s ease,color .16s ease,box-shadow .16s ease,transform .16s ease}
.role-person-spec-tab:hover{background:linear-gradient(180deg,rgba(0,70,129,.24),rgba(0,70,129,.12));border-color:rgba(0,70,129,.46);color:var(--blue);box-shadow:0 -3px 12px rgba(0,70,129,.12),inset 0 2px 0 rgba(255,255,255,.72);transform:translateY(-2px)}
.role-person-spec-tab:hover strong{background:#eaf4ff;color:var(--blue)}
.role-person-spec-tab.active{background:linear-gradient(180deg,#0e204a,#004681);border-color:rgba(0,70,129,.52);border-bottom-color:#004681;color:#fff;box-shadow:0 -5px 14px rgba(14,32,74,.12);transform:translateY(1px)}
.role-person-spec-tab span{font-size:9px;font-weight:900;letter-spacing:.08em;line-height:1.1;overflow:hidden;text-overflow:ellipsis;text-transform:uppercase;white-space:nowrap}
.role-person-spec-tab strong{align-items:center;background:#fff;border:1px solid rgba(0,70,129,.18);border-radius:999px;box-shadow:0 2px 7px rgba(14,32,74,.08);color:#004681;display:inline-flex;font-size:9px;font-weight:900;height:18px;justify-content:center;min-width:18px;padding:0 5px}
.role-person-spec-tab.active strong{background:#fff6d8;border-color:rgba(178,139,93,.68);box-shadow:0 2px 8px rgba(178,139,93,.2);color:#0e204a}
.role-person-spec-tab-panels{display:grid}
.role-person-spec-section{border:1px solid rgba(14,32,74,.12);border-radius:0 0 14px 14px;background:#fff;box-shadow:0 10px 22px rgba(14,32,74,.035);overflow:hidden}
.role-person-spec-section:not(.active){display:none}
.role-person-spec-section h4{margin:0;padding:10px 14px;background:#f3f7fb;border-bottom:1px solid rgba(14,32,74,.09);color:var(--navy);font-size:13px;font-weight:900;letter-spacing:.08em;text-transform:uppercase}
.role-person-spec-statements{display:grid;gap:0}
.role-person-spec-statement{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;padding:11px 14px;border-bottom:1px solid rgba(14,32,74,.07);color:#4f5f79;font-size:13px;line-height:1.45}
.role-person-spec-statement:last-child{border-bottom:0}
.role-person-spec-statement span{min-width:0}
.person-spec-importance{flex:0 0 auto;border:1px solid rgba(14,32,74,.12);border-radius:999px;padding:4px 11px;font-size:10px;font-weight:900;letter-spacing:.08em;text-transform:uppercase;color:#0e204a;box-shadow:0 5px 14px rgba(14,32,74,.055)}
.person-spec-importance-essential{background:linear-gradient(135deg,#0e204a,#004681);border-color:rgba(178,139,93,.82);color:#fff;box-shadow:0 7px 18px rgba(14,32,74,.16),inset 0 1px 0 rgba(255,255,255,.22),0 0 0 1px rgba(178,139,93,.34)}
.person-spec-importance-desirable{background:linear-gradient(135deg,#fffaf0,#fff);border-color:rgba(178,139,93,.46);color:#7a5623;box-shadow:0 5px 14px rgba(178,139,93,.08)}
.role-person-spec-table{width:100%;border-collapse:separate;border-spacing:0;min-width:900px}
.role-person-spec-table th{position:sticky;top:0;background:#f4f7fb;color:#3f4d68;font-size:10px;font-weight:900;letter-spacing:1px;text-transform:uppercase;text-align:left;border-bottom:1px solid rgba(14,32,74,.14);padding:10px 12px;z-index:1}
.role-person-spec-table td{vertical-align:top;border-bottom:1px solid rgba(14,32,74,.08);padding:10px 12px;color:#4f5f79}
.role-person-spec-table tr:last-child td{border-bottom:0}
.role-person-spec-table td:first-child{font-weight:800;color:var(--navy);width:15%}
.role-person-spec-table td:nth-child(2){width:35%}
.role-person-spec-raw{padding:18px 20px}
.person-spec-editor{display:grid;gap:16px;margin-bottom:14px;max-height:58vh;overflow:auto;padding:2px 6px 2px 2px}
.person-spec-editor-section{border:1px solid rgba(14,32,74,.14);border-radius:16px;background:linear-gradient(180deg,#fff,#f7fafc);box-shadow:0 12px 28px rgba(14,32,74,.055);overflow:hidden;padding:0}
.person-spec-editor-section-head{display:flex;align-items:center;justify-content:space-between;gap:12px;background:linear-gradient(135deg,#edf5fb,#fff);border-bottom:1px solid rgba(14,32,74,.09);padding:12px 14px}
.person-spec-editor-section-head label{margin:0;color:var(--gold);font-size:10px;font-weight:900;letter-spacing:.12em;text-transform:uppercase}
.person-spec-editor-section-actions{display:flex;align-items:center;justify-content:flex-end;gap:8px;flex-wrap:wrap}
.person-spec-editor-section-head .btn-outline{min-height:34px;padding:7px 10px;font-size:11px;border-radius:9px;color:#8a1f1f;border-color:rgba(248,113,113,.28);background:#fff7f7}
.person-spec-section-name{border:0!important;border-bottom:1px solid rgba(14,32,74,.1)!important;border-radius:0!important;background:#fff!important;color:var(--navy)!important;font-size:17px!important;font-weight:800;margin:0!important;padding:13px 16px!important}
.person-spec-editor-requirements{counter-reset:personSpecRequirement;display:grid;gap:8px;padding:14px}
.person-spec-editor-row{counter-increment:personSpecRequirement;display:grid;grid-template-columns:34px 52px minmax(220px,1fr) 136px 92px;gap:9px;align-items:start;border:1px solid rgba(14,32,74,.1);border-radius:12px;background:#fff;padding:10px;box-shadow:0 8px 18px rgba(14,32,74,.035)}
.person-spec-editor-row::before{content:counter(personSpecRequirement);align-items:center;background:#eef5fb;border:1px solid rgba(0,70,129,.14);border-radius:999px;color:var(--blue);display:flex;font-size:12px;font-weight:900;height:28px;justify-content:center;margin-top:7px;width:28px}
.person-spec-row-move-actions{display:grid;grid-template-columns:1fr;gap:4px}
.person-spec-move-btn{appearance:none;border:1px solid rgba(0,70,129,.16);border-radius:8px;background:#f8fbff;color:var(--blue);cursor:pointer;font-family:inherit;font-size:9px;font-weight:900;letter-spacing:.08em;line-height:1;min-height:22px;padding:5px 7px;text-transform:uppercase;transition:background .15s ease,border-color .15s ease,color .15s ease,transform .15s ease}
.person-spec-move-btn:hover:not(:disabled){background:#eaf4ff;border-color:rgba(0,70,129,.3);transform:translateY(-1px)}
.person-spec-move-btn:disabled{cursor:not-allowed;opacity:.35;transform:none}
.edit-job-description-modal .person-spec-requirement-text{background:#f8fafc!important;border-color:rgba(14,32,74,.14)!important;color:var(--navy)!important;font-size:13px!important;line-height:1.45!important;margin:0!important;min-height:48px!important;height:48px;resize:vertical}
.edit-job-description-modal .person-spec-requirement-text:not(:focus){overflow:hidden}
.edit-job-description-modal .person-spec-requirement-text:focus{overflow:auto}
.person-spec-importance-select{align-self:start;background:#f8fafc!important;border-color:rgba(14,32,74,.14)!important;color:var(--navy)!important;font-size:12px!important;font-weight:800;height:48px!important;margin:0!important}
.person-spec-editor-row .btn-danger{align-self:start;border-radius:10px;font-size:11px;height:48px;min-height:48px;padding:0 10px}
.vacancy-modal .vacancy-professional-qualification-row .btn-danger{align-self:center;height:72px!important;min-height:72px!important}
.person-spec-add-requirement-btn{margin:0 14px 14px;min-height:38px;width:220px}
.person-spec-add-section-btn{margin-top:2px;min-height:42px;width:220px}
.role-description-display{background:#fff;border:1px solid rgba(14,32,74,.14);border-radius:10px;padding:18px 20px;max-height:340px;overflow-y:auto;color:#4f5f79;font-size:13px;line-height:1.62;box-shadow:0 12px 26px rgba(14,32,74,.035)}
.role-description-display h3{margin:0 0 12px;color:var(--navy);font-size:17px;line-height:1.25;font-weight:800;letter-spacing:.02em;text-transform:uppercase}
.role-description-display h4{margin:16px 0 7px;color:var(--navy);font-size:13px;line-height:1.3;font-weight:900}
.role-description-display p{margin:0 0 9px}
.role-description-list{margin:6px 0 14px 20px;padding:0}
.role-description-list li{margin:0 0 6px;padding-left:4px}
.role-criteria-toolbar{position:relative;display:flex;align-items:center;justify-content:flex-end;gap:14px;border:1px solid rgba(14,32,74,.12);border-radius:14px;background:linear-gradient(135deg,#f8fafc,#fff);box-shadow:0 12px 26px rgba(14,32,74,.045);padding:22px 14px 12px;margin:8px 0 14px;overflow:visible}
.role-criteria-toolbar-label{position:absolute;left:18px;top:0;transform:translateY(-50%);z-index:2;background:#fff;padding:0 9px;font-size:10px;font-weight:800;line-height:1.2;letter-spacing:1px;text-transform:uppercase;color:#66738a;white-space:nowrap}
.role-criteria-toolbar-actions{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));align-items:stretch;justify-content:stretch;gap:10px;flex:1;min-width:0;width:100%}
.role-criteria-toolbar-actions .role-detail-action-btn{width:100%;min-width:0;max-width:none;min-height:48px;padding-left:10px;padding-right:10px;white-space:normal;line-height:1.15}
.role-criteria-toolbar-actions .role-detail-action-btn:only-child{grid-column:4}
.role-criteria-toolbar-actions .btn-danger{margin-left:0}
.scoring-framework-display{display:grid;gap:14px}
.scoring-framework-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}
.scoring-framework-card{background:linear-gradient(135deg,#fff,#f8fafc);border:1px solid rgba(14,32,74,.13);border-radius:12px;padding:14px 16px;box-shadow:0 12px 28px rgba(14,32,74,.045)}
.scoring-framework-card-top{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;margin-bottom:6px}
.scoring-framework-card-top span{font-size:13px;font-weight:900;color:var(--gold)}
.scoring-framework-card-top small{font-size:10px;font-weight:900;text-transform:uppercase;letter-spacing:.8px;color:#66738a;text-align:right}
.scoring-framework-card p{font-size:13px;color:#43516a;line-height:1.55;margin:0}
.scoring-framework-support{border:1px solid var(--border);border-radius:12px;background:linear-gradient(135deg,#f8fafc,#fff);padding:16px 18px;display:grid;gap:12px;box-shadow:0 12px 26px rgba(14,32,74,.035)}
.scoring-framework-support>strong{font-size:14px;font-weight:950;text-transform:uppercase;letter-spacing:1.8px;color:var(--navy);line-height:1.2}
.scoring-framework-support div{display:grid;gap:3px;border-top:1px solid rgba(14,32,74,.08);padding-top:8px}
.scoring-framework-support div:first-of-type{border-top:0;padding-top:0}
.scoring-framework-support b{font-size:13px;color:var(--navy);font-weight:850}
.scoring-framework-support span{font-size:12px;color:var(--text-muted);line-height:1.45}
.scoring-framework-support-mandatory{border-color:rgba(185,139,93,.42);background:linear-gradient(135deg,rgba(250,244,235,.86),#fff)}
.scoring-framework-support-mandatory>strong{color:#6f4c1d}
.scoring-framework-support-human{border-color:rgba(0,70,129,.28);background:linear-gradient(135deg,rgba(234,244,255,.82),#fff)}
.scoring-framework-support-human>strong{color:#004681}
.criteria-audit-panel{display:grid;grid-template-columns:minmax(0,1fr) minmax(240px,calc((100% - 30px)/4));gap:20px;align-items:start;border:1px solid rgba(14,32,74,.14);border-radius:14px;padding:16px 18px;margin:0 0 14px;background:#f8fafc;box-shadow:0 12px 28px rgba(14,32,74,.05)}
.criteria-audit-panel-warning{border-color:rgba(221,138,70,.42);background:linear-gradient(135deg,rgba(242,207,170,.26),#fff)}
.criteria-audit-panel-pending{border-color:rgba(221,138,70,.34);background:linear-gradient(135deg,rgba(242,207,170,.16),#fff)}
.criteria-audit-panel-failed{border-color:rgba(248,113,113,.42);background:linear-gradient(135deg,rgba(254,226,226,.46),#fff)}
.criteria-audit-panel-ok{border-color:rgba(52,168,93,.24);background:linear-gradient(135deg,rgba(184,232,197,.22),#fff)}
.criteria-audit-copy strong{display:block;color:var(--navy);font-size:15px;margin-bottom:5px}
.criteria-audit-copy span{display:block;color:#66738a;font-size:12px;font-weight:800;letter-spacing:.04em;text-transform:uppercase;margin-bottom:8px}
.criteria-audit-copy p{color:#43516a;font-size:13px;line-height:1.55;margin:0 0 8px}
.criteria-audit-copy ul{margin:8px 0 0 18px;color:#43516a;font-size:12px;line-height:1.5}
.criteria-audit-actions{display:flex;flex-direction:column;gap:8px;align-items:stretch;width:100%}
.criteria-audit-actions .role-detail-action-btn{width:100%;max-width:none;flex:0 0 auto;white-space:normal;min-height:46px}
.score-bar{margin-bottom:12px}.score-bar-header{display:flex;justify-content:space-between;font-size:12px;margin-bottom:4px;color:var(--text-mid)}.score-bar-value{font-weight:600}
.score-bar-track{height:6px;background:var(--navy-lighter);border-radius:3px;overflow:hidden}.score-bar-fill{height:100%;border-radius:3px;transition:width 1s cubic-bezier(0.16,1,0.3,1)}
.ai-summary{font-size:14px;line-height:1.7;color:var(--text-mid);background:var(--navy-dark);border:1px solid var(--border);border-radius:10px;padding:16px}
.strength-item,.concern-item{font-size:13px;color:var(--text-mid);padding:5px 0 5px 12px;line-height:1.5;margin-bottom:4px}
.strength-item{border-left:2px solid rgba(74,222,128,0.25)}.concern-item{border-left:2px solid var(--gold-border)}
.red-flag-item{font-size:13px;color:var(--red);padding:5px 0 5px 12px;line-height:1.5;margin-bottom:4px;border-left:2px solid rgba(248,113,113,0.3);background:rgba(248,113,113,0.04);border-radius:0 6px 6px 0;padding-right:8px}
.disclaimer{margin-top:32px;background:var(--navy);border-radius:12px;border:1px solid var(--border);padding:20px;display:flex;gap:12px;font-size:12px;color:var(--text-muted);line-height:1.6}
.disclaimer strong{color:var(--gold)}
/* History */
.history-item{background:var(--navy);border:1px solid var(--border);border-radius:12px;padding:20px;display:flex;justify-content:space-between;align-items:center;margin-bottom:10px;cursor:pointer;transition:all .2s}
.history-item:hover{border-color:var(--gold-border);background:var(--surface-hover)}
.history-info h4{font-size:15px;font-weight:600;color:var(--white);margin-bottom:3px}
.history-info p{font-size:12px;color:var(--text-muted)}
.history-actions{display:flex;gap:8px;align-items:center}
.badge{display:inline-block;padding:3px 10px;border-radius:20px;font-size:11px;font-weight:600}
.badge-gold{background:var(--gold-dim);color:var(--gold)}
/* Roles management */
.role-item{background:var(--navy);border:1px solid var(--border);border-radius:10px;padding:16px 20px;display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}
.role-item-title{font-size:14px;font-weight:600;color:var(--white)}
.role-item-meta{font-size:11px;color:var(--text-muted);margin-top:2px}
/* Modal */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,0.6);display:flex;align-items:center;justify-content:center;z-index:100;animation:fadeIn .2s;overflow:hidden;overscroll-behavior:contain}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
.modal{background:var(--navy);border:1px solid var(--border);border-radius:16px;padding:32px;width:90%;max-width:520px;max-height:80vh;overflow-y:auto;overscroll-behavior:contain}
.modal h3{font-family:'Cormorant Garamond',serif;font-size:22px;font-weight:600;margin-bottom:16px;color:var(--white)}
.dialog-message{font-size:14px;color:var(--text-muted);line-height:1.6;margin-bottom:18px}
.dialog-actions{display:grid;grid-template-columns:repeat(2,minmax(160px,1fr));gap:12px;justify-content:flex-end;max-width:440px;margin-left:auto}
.dialog-actions-single{grid-template-columns:minmax(180px,260px);justify-content:center;margin-left:auto;margin-right:auto}
.app-alert-modal .dialog-message{text-align:center}
.dialog-action-btn{width:100%;min-height:46px;display:inline-flex;align-items:center;justify-content:center;text-align:center;font-size:14px;font-weight:800;border-width:2px}
.dialog-actions .btn-outline{background:#fff;color:var(--navy);border-color:rgba(14,32,74,.26)}
.dialog-actions .btn-outline:hover{background:#eef5fb;border-color:rgba(0,70,129,.36);color:var(--blue)}
.add-job-description-modal{width:min(96vw,1080px);max-width:1080px;max-height:96vh;padding:22px 34px;overflow-y:auto}
.add-job-description-modal h3{margin-bottom:8px}
.add-job-description-modal .role-category-editor{grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;margin:8px 0 12px}
.add-job-description-modal .role-category-check{min-height:62px;padding:8px 12px;gap:8px}
.add-job-description-modal .role-category-check strong{font-size:11px;line-height:1.2;margin-bottom:2px}
.add-job-description-modal .role-category-check small{font-size:9px;line-height:1.25}
.job-role-create-intro{font-size:13px;line-height:1.55;color:var(--text-muted);margin:0 0 14px}
.new-job-role-analyse-btn{width:100%;min-height:42px;margin:0 0 14px;display:inline-flex;align-items:center;justify-content:center;gap:10px;box-shadow:0 14px 28px rgba(0,70,129,.16)}
.new-job-role-analyse-btn.is-running{background:#b28b5d!important;border-color:#8a673f!important;color:#fff!important;cursor:progress;position:relative;overflow:hidden}
.new-job-role-analyse-btn.is-running::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.28),transparent);animation:analyseSweep 1.1s linear infinite}
.analyse-spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,.45);border-top-color:#fff;border-radius:999px;animation:analyseSpin .8s linear infinite;position:relative;z-index:1}
.new-job-role-analyse-btn span:last-child{position:relative;z-index:1}
@keyframes analyseSpin{to{transform:rotate(360deg)}}
@keyframes analyseSweep{from{transform:translateX(-100%)}to{transform:translateX(100%)}}
.new-job-role-draft-list{display:grid;gap:12px;margin:14px 0}
.new-job-role-draft-heading{font-size:12px;font-weight:900;letter-spacing:1px;text-transform:uppercase;color:var(--text-muted)}
.new-job-role-source-duplicates{border:1px solid rgba(178,139,93,.28);border-left:5px solid var(--gold);border-radius:10px;background:#fff8eb;color:#5f4628;padding:12px 14px;font-size:13px;line-height:1.45}
.new-job-role-source-duplicates strong{display:block;color:#5f4628;font-size:13px;font-weight:900;text-transform:uppercase;letter-spacing:.7px;margin-bottom:3px}
.new-job-role-source-duplicates p{margin:0 0 8px;color:#5f4628;font-weight:800}
.new-job-role-source-duplicates ul{margin:0;padding-left:18px}
.new-job-role-source-duplicates li{margin:3px 0}
.new-job-role-file-errors{border:2px solid #dc2626;border-left-width:6px;border-radius:10px;background:#fee2e2;color:#7f1d1d;padding:11px 13px;margin-top:9px;font-size:13px;line-height:1.45;box-shadow:0 10px 24px rgba(127,29,29,.12)}
.new-job-role-file-errors strong{display:block;color:#7f1d1d;font-size:13px;font-weight:950;text-transform:uppercase;letter-spacing:.8px;margin-bottom:3px}
.new-job-role-file-errors p{margin:0 0 7px;color:#7f1d1d;font-weight:800}
.new-job-role-file-errors ul{margin:0;padding-left:18px}
.new-job-role-file-errors li{margin:4px 0;font-weight:750}
.new-job-role-source-rejections{border:2px solid #dc2626;border-left-width:6px;border-radius:10px;background:#fee2e2;color:#7f1d1d;padding:13px 15px;font-size:13px;line-height:1.45;box-shadow:0 10px 24px rgba(127,29,29,.12)}
.new-job-role-source-rejections strong{display:block;color:#7f1d1d;font-size:13px;font-weight:950;text-transform:uppercase;letter-spacing:.8px;margin-bottom:4px}
.new-job-role-source-rejections p{margin:0 0 8px;color:#7f1d1d;font-weight:800}
.new-job-role-source-rejections ul{margin:0;padding-left:18px}
.new-job-role-source-rejections li{margin:4px 0;font-weight:750}
.new-job-role-assisted-create{border-top:1px solid rgba(127,29,29,.2);margin-top:12px;padding-top:12px}
.new-job-role-assisted-create label{color:#7f1d1d;font-size:12px;font-weight:950;letter-spacing:.8px;text-transform:uppercase}
.new-job-role-assisted-create div{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:8px;margin-top:6px}
.new-job-role-assisted-create input{background:#fff;border-color:rgba(127,29,29,.28);margin:0}
.new-job-role-assisted-create button{white-space:nowrap}
@media(max-width:760px){.new-job-role-assisted-create div{grid-template-columns:1fr}.new-job-role-assisted-create button{width:100%;white-space:normal}}
.new-job-role-draft{border:1px solid rgba(14,32,74,.12);border-radius:10px;background:#f8fafc;padding:12px}
.new-job-role-draft-top{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:10px}
.new-job-role-draft-top strong{color:var(--navy);font-size:13px}
.new-job-role-draft textarea{min-height:96px;margin-bottom:10px}
.new-job-role-draft textarea:last-child{min-height:72px;margin-bottom:0}
.new-job-role-duplicate{border:2px solid #dc2626;border-left-width:6px;border-radius:8px;background:#fee2e2;color:#7f1d1d;padding:12px 14px;margin:8px 0 12px;font-size:14px;font-weight:800;line-height:1.45;box-shadow:0 10px 24px rgba(127,29,29,.12)}
.new-job-role-duplicate p{margin:6px 0 10px;color:#7f1d1d;font-weight:750}
.new-job-role-duplicate p span{font-weight:950;text-decoration:underline;text-decoration-thickness:2px;text-underline-offset:3px}
.new-job-role-duplicate div{display:flex;gap:8px;flex-wrap:wrap;margin-top:8px}
.new-job-role-duplicate .active{background:#fff;border-color:#7f1d1d;color:#7f1d1d;box-shadow:0 0 0 2px rgba(127,29,29,.16)}
.new-job-role-overwrite-check{display:flex;align-items:flex-start;gap:10px;background:#fff;border:2px solid rgba(127,29,29,.28);border-radius:8px;color:#7f1d1d;font-size:13px;font-weight:900;margin:10px 0;padding:10px 12px}
.new-job-role-overwrite-check input{width:auto;margin-top:3px;flex:0 0 auto}
.new-job-role-action-confirmation{border:1px solid rgba(52,168,93,.26);border-left:5px solid #16a34a;border-radius:8px;background:#ecfdf3;color:#14532d;padding:11px 13px;margin:8px 0 12px;font-size:13px;line-height:1.45}
.new-job-role-action-confirmation strong{display:block;font-size:13px;margin-bottom:3px;text-transform:uppercase;letter-spacing:.8px}
.new-job-role-action-confirmation p{margin:0;color:#14532d;font-weight:800}
.new-job-role-person-spec-box{border:1px solid rgba(14,32,74,.12);border-radius:10px;background:#fff;margin-top:8px;padding:10px 12px}
.new-job-role-person-spec-toggle{display:flex;align-items:flex-start;gap:10px;color:var(--navy);font-size:13px;font-weight:900;margin:0 0 10px}
.new-job-role-person-spec-toggle input{width:auto;margin-top:3px;flex:0 0 auto}
.new-job-role-final-list{display:grid;gap:10px;margin:14px 0 18px}
.new-job-role-final-list div{border:1px solid rgba(14,32,74,.12);border-radius:10px;background:#f8fafc;padding:12px}
.new-job-role-final-list strong{display:block;color:var(--navy);font-size:14px;margin-bottom:4px}
.new-job-role-final-list span{display:block;color:#334155;font-size:13px;font-weight:800;margin-bottom:3px}
.new-job-role-final-list small{display:block;color:var(--text-muted);font-size:12px}
.add-job-description-modal textarea{min-height:136px}
.add-job-save-status{font-size:12px;color:var(--text-muted);margin:-8px 0 10px;min-height:14px}
.add-job-save-status.active{background:#eef5fb;border:1px solid rgba(0,70,129,.18);border-left:4px solid var(--blue);border-radius:10px;color:var(--navy);font-size:14px;font-weight:800;line-height:1.45;margin:0 0 14px;padding:12px 14px;box-shadow:0 10px 30px rgba(14,32,74,.08)}
.add-job-duplicate-box{background:#fff1f2;border:1px solid rgba(248,113,113,.28);border-left:4px solid #ef4444;border-radius:10px;color:var(--navy);font-size:13px;line-height:1.45;margin:0 0 14px;padding:12px 14px}
.add-job-duplicate-box strong{display:block;font-size:14px;margin-bottom:4px}
.add-job-duplicate-box p{color:#566174;margin:0 0 12px}
.add-job-duplicate-title{color:var(--navy);font-weight:900;text-decoration:underline;text-decoration-thickness:2px;text-underline-offset:3px}
.add-job-duplicate-actions{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;justify-content:end;max-width:720px;margin-left:auto}
.add-job-duplicate-actions .btn,.add-job-duplicate-actions .btn-outline{width:100%;min-height:44px;display:inline-flex;align-items:center;justify-content:center;text-align:center;font-weight:800}
.add-job-alternative-actions{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;justify-content:end;max-width:460px;margin-left:auto}
.add-job-alternative-actions .btn,.add-job-alternative-actions .btn-outline{width:100%;min-height:44px;display:inline-flex;align-items:center;justify-content:center;text-align:center;font-weight:800}
.add-job-title-error{background:rgba(248,113,113,.08);border:1px solid rgba(248,113,113,.2);border-radius:10px;color:#b91c1c;font-size:12px;font-weight:700;margin:0 0 10px;padding:9px 12px}
.add-job-modal-actions{display:grid;grid-template-columns:repeat(2,minmax(180px,1fr));gap:12px;justify-content:end;max-width:460px;margin-left:auto}
.add-job-action-btn{width:100%;min-height:44px;display:inline-flex;align-items:center;justify-content:center;text-align:center;font-size:14px;font-weight:800;border-width:2px}
body.light-mode .add-job-description-modal .btn-outline{background:#fff;color:var(--navy);border-color:rgba(14,32,74,.22)}
body.light-mode .add-job-description-modal .btn-outline:hover{background:#eef5fb;border-color:rgba(0,70,129,.32);color:var(--blue)}
.edit-job-description-modal{width:min(96vw,1120px);max-width:1120px;max-height:94vh;padding:28px 38px;overflow-y:auto}
.edit-job-description-modal h3{margin-bottom:12px}
.edit-job-description-modal .role-category-editor{grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;margin:8px 0 12px}
.edit-job-description-modal .role-category-check{min-height:66px;padding:9px 12px;gap:8px}
.edit-job-description-modal .role-category-check strong{font-size:11px;line-height:1.2;margin-bottom:2px}
.edit-job-description-modal .role-category-check small{font-size:9px;line-height:1.25}
.edit-job-description-modal textarea{min-height:260px;font-size:12px;line-height:1.55;margin-bottom:12px}
.edit-job-description-modal .dialog-actions{margin-top:12px}
textarea{width:100%;min-height:120px;padding:10px 14px;background:var(--navy-light);border:1px solid var(--border);border-radius:8px;color:var(--text-light);font-size:13px;font-family:inherit;outline:none;resize:vertical;overscroll-behavior:contain}
textarea:focus{border-color:var(--gold-border)}
/* Authenticated SGS light workspace */
body.light-mode #app .hero h1,
body.light-mode #app h2,
body.light-mode #app h3,
body.light-mode #app h4,
body.light-mode #app .candidate-name,
body.light-mode #app .document-item-title,
body.light-mode #app .history-info h4,
body.light-mode #app .role-item-title,
body.light-mode #app .admin-user-row strong,
body.light-mode #app .audit-title,
body.light-mode #app [style*="color:var(--white)"],
body.light-mode #app [style*="color:var(--text-light)"]{color:var(--navy)!important}
body.light-mode #app .hero p,
body.light-mode #app .candidate-meta,
body.light-mode #app .document-item-meta,
body.light-mode #app .history-info p,
body.light-mode #app .role-item-meta,
body.light-mode #app .admin-user-row,
body.light-mode #app .admin-user-row span,
body.light-mode #app .audit-meta,
body.light-mode #app .score-bar-header,
body.light-mode #app .ai-summary,
body.light-mode #app .strength-item,
body.light-mode #app .concern-item,
body.light-mode #app .file-tag,
body.light-mode #app [style*="color:var(--text-mid)"],
body.light-mode #app [style*="color:var(--text-muted)"]{color:#66738a!important}
body.light-mode #app label,
body.light-mode #app .detail-section-title,
body.light-mode #app .mini-score-label,
body.light-mode #app .data-reliability-label,
body.light-mode #app .expand-arrow,
body.light-mode #app [style*="color:var(--text-faint)"]{color:#7a8498!important}
body.light-mode #app .card,
body.light-mode #app .candidate-card,
body.light-mode #app .history-item,
body.light-mode #app .role-item,
body.light-mode #app .admin-section,
body.light-mode #app .admin-form,
body.light-mode #app .admin-user-list,
body.light-mode #app .document-item,
body.light-mode #app .ai-summary,
body.light-mode #app .upload-zone,
body.light-mode #app .file-tag,
body.light-mode #app .disclaimer,
body.light-mode #app .audit-list,
body.light-mode #app .data-reliability,
body.light-mode #app [style*="background:var(--navy"]{
  background:#fff!important;
  border-color:rgba(14,32,74,.12)!important;
  box-shadow:0 12px 32px rgba(14,32,74,.06);
}
body.light-mode #app [style*="background:rgba(9,22,55"],
body.light-mode #app [style*="background:rgba(255,255,255,.025)"]{
  background:#f8fafc!important;
  border-color:rgba(14,32,74,.12)!important;
}
body.light-mode #app .candidate-card.expanded,
body.light-mode #app .card:hover,
body.light-mode #app .history-item:hover,
body.light-mode #app .role-item:hover{border-color:rgba(178,139,93,.34)!important}
body.light-mode #app .candidate-row:hover,
body.light-mode #app .admin-user-row:hover,
body.light-mode #app .admin-user-row.active{background:#f6f9fc!important;border-color:rgba(0,70,129,.22)!important;color:var(--navy)!important}
body.light-mode #app .role-card:not(.expanded) .role-row{position:relative;z-index:1;background:transparent!important}
body.light-mode #app .role-card-status-missing:not(.expanded){background:linear-gradient(135deg,rgba(254,226,226,.5),#fff 58%,rgba(254,226,226,.22))!important;border-color:#f3b6b6!important}
body.light-mode #app .role-card-status-inadequate:not(.expanded){background:linear-gradient(135deg,rgba(242,207,170,.42),#fff 58%,rgba(242,207,170,.18))!important;border-color:#e2ba95!important}
body.light-mode #app .role-card-status-adequate:not(.expanded){background:linear-gradient(135deg,rgba(184,232,197,.42),#fff 58%,rgba(184,232,197,.18))!important;border-color:#a7dbb6!important}
body.light-mode #app .role-card-status-in-use:not(.expanded){background:linear-gradient(135deg,rgba(185,212,237,.46),#fff 58%,rgba(185,212,237,.2))!important;border-color:#99c0df!important}
body.light-mode #app .role-card-status-newly-added:not(.expanded){background:linear-gradient(135deg,rgba(247,231,245,.82),#fff 58%,rgba(234,210,235,.34))!important;border-color:#d7a8d8!important}
body.light-mode #app input[type="text"],
body.light-mode #app input[type="password"],
body.light-mode #app input[type="email"],
body.light-mode #app input[type="url"],
body.light-mode #app input[type="tel"],
body.light-mode #app input[type="number"],
body.light-mode #app select,
body.light-mode #app textarea{
  background:#f8fafc!important;
  color:var(--navy)!important;
  border-color:rgba(14,32,74,.16)!important;
}
body.light-mode #app input:focus,
body.light-mode #app select:focus,
body.light-mode #app textarea:focus{border-color:rgba(178,139,93,.46)!important;box-shadow:0 0 0 3px rgba(178,139,93,.12)}
body.light-mode #app select option{background:#fff;color:var(--navy)}
body.light-mode #app .role-chip-select{background-image:linear-gradient(45deg,transparent 50%,currentColor 50%),linear-gradient(135deg,currentColor 50%,transparent 50%)!important;background-position:calc(100% - 15px) 50%,calc(100% - 10px) 50%!important;background-repeat:no-repeat!important;background-size:5px 5px!important;border-width:1px!important;border-radius:999px!important;font-size:11px!important;font-weight:800!important;letter-spacing:.5px!important;text-transform:uppercase!important}
body.light-mode #app .role-chip-select.role-chip-academic{background-color:#d9ecfb!important;color:#0e3357!important;border-color:#8ab8dc!important}
body.light-mode #app .role-chip-select.role-chip-non-teaching-academic{background-color:#e3f3ef!important;color:#174c41!important;border-color:#8ccdb9!important}
body.light-mode #app .role-chip-select.role-chip-specialist{background-color:#fff3c4!important;color:#674f05!important;border-color:#dfbd4d!important}
body.light-mode #app .role-chip-select.role-chip-technical{background-color:#ffe1c8!important;color:#6a3415!important;border-color:#e69a62!important}
body.light-mode #app .role-chip-select.role-chip-administrative{background-color:#eee9fb!important;color:#44366b!important;border-color:#b8a9db!important}
body.light-mode #app .role-chip-select.role-chip-non-academic{background-color:#edf1f6!important;color:#334155!important;border-color:#b5c2d2!important}
body.light-mode #app .role-chip-select.role-chip-newly-added-job-role{background-color:#f7e7f5!important;color:#5b255f!important;border-color:#bd83be!important}
body.light-mode #app .btn-outline{background:#fff;color:var(--navy);border-color:rgba(14,32,74,.16)}
body.light-mode #app .btn-outline:hover{background:#eef5fb;border-color:rgba(0,70,129,.28);color:var(--blue)}
body.light-mode #app .home-btn:hover,
body.light-mode #app .page-action-btn:hover{background:var(--blue-light);border-color:rgba(255,255,255,.42);color:#fff}
body.light-mode .btn-blue,body.light-mode #app .btn-blue{background:var(--blue);color:#fff}
body.light-mode .btn-blue:hover,body.light-mode #app .btn-blue:hover{background:var(--blue-light);color:#fff}
body.light-mode .btn-blue:disabled,body.light-mode #app .btn-blue:disabled{background:#64748b;color:#e2e8f0;cursor:not-allowed;opacity:.72;box-shadow:none;transform:none}
body.light-mode .btn-danger,body.light-mode #app .btn-danger,body.light-mode .btn-danger-solid,body.light-mode #app .btn-danger-solid{background:linear-gradient(135deg,#991b1b,#dc2626);border-color:#7f1d1d;color:#fff;box-shadow:0 12px 28px rgba(185,28,28,.24)}
body.light-mode .btn-danger:hover,body.light-mode #app .btn-danger:hover,body.light-mode .btn-danger-solid:hover,body.light-mode #app .btn-danger-solid:hover{background:linear-gradient(135deg,#7f1d1d,#b91c1c);border-color:#7f1d1d;color:#fff;box-shadow:0 16px 34px rgba(185,28,28,.32)}
body.light-mode #app .btn-gold{background:var(--gold);color:var(--navy)}
body.light-mode #app .admin-section summary h3{color:var(--gold)!important}
body.light-mode #app .permission-check{background:#f8fafc!important;border-color:rgba(14,32,74,.12)!important;color:#526078!important}
body.light-mode #app .detail-divider{background:rgba(14,32,74,.12)}
body.light-mode #app .score-bar-track,
body.light-mode #app .data-reliability-track,
body.light-mode #app .progress-track{background:#e7edf5!important}
body.light-mode #app .upload-zone:hover{background:#f6f9fc!important;border-color:rgba(178,139,93,.34)!important}
body.light-mode #app .red-flag-item{background:rgba(248,113,113,.08)!important;color:#b91c1c!important}
body.light-mode .modal{background:#fff;color:var(--navy);border-color:rgba(14,32,74,.12);box-shadow:0 24px 80px rgba(14,32,74,.22)}
body.light-mode .modal h3{color:var(--navy)}
body.light-mode .modal input,
body.light-mode .modal textarea,
body.light-mode .modal select{background:#f8fafc;color:var(--navy);border-color:rgba(14,32,74,.16)}
.header-auth{display:flex;align-items:center;gap:10px;margin-left:2px;white-space:nowrap}
.header-auth-separator{width:1px;height:24px;background:rgba(255,255,255,.12);display:inline-block}
.server-health{display:inline-flex;align-items:center;gap:7px;min-height:34px;padding:0 12px;color:var(--text-muted);font-size:12px;font-weight:700;border:1px solid rgba(255,255,255,.18);border-radius:8px;background:rgba(255,255,255,.025);box-shadow:inset 0 1px 0 rgba(255,255,255,.05)}
.server-health-light{width:9px;height:9px;border-radius:999px;background:var(--text-faint);box-shadow:0 0 0 3px rgba(255,255,255,0.04)}
.server-health.online .server-health-light{background:var(--green);box-shadow:0 0 0 3px rgba(74,222,128,0.12)}
.server-health.offline .server-health-light{background:var(--red);box-shadow:0 0 0 3px rgba(248,113,113,0.12)}
.server-health.online .server-health-text{color:var(--green)}
.server-health.offline .server-health-text{color:var(--red)}
.session-countdown{display:none;align-items:center;gap:8px;min-height:34px;padding:0 12px;border:1px solid rgba(255,255,255,.18);border-radius:8px;background:rgba(255,255,255,.025);color:var(--text-muted);font-size:12px;font-weight:800;letter-spacing:.04em;box-shadow:inset 0 1px 0 rgba(255,255,255,.05)}
.session-countdown::before{content:"";width:15px;height:15px;border:2px solid currentColor;border-radius:999px;box-sizing:border-box;background:radial-gradient(circle at center,currentColor 0 1.5px,transparent 2px),linear-gradient(currentColor,currentColor) 50% 3px/2px 6px no-repeat,linear-gradient(currentColor,currentColor) 50% 50%/5px 2px no-repeat}
.session-countdown.warning{border-color:rgba(191,145,82,.55);background:rgba(191,145,82,.12);color:var(--gold-light)}
.session-timeout-warning{position:fixed;top:74px;left:0;right:0;z-index:1500;width:100%;min-height:33vh;display:flex;align-items:center;justify-content:center;gap:42px;padding:32px clamp(24px,7vw,120px);border-bottom:1px solid rgba(191,145,82,.46);background:linear-gradient(180deg,#fff 0%,#f7f9fc 100%);box-shadow:0 28px 90px rgba(14,32,74,.28);color:var(--navy);animation:sessionWarningSlide .26s ease-out}
.session-timeout-warning>div{max-width:920px}
.session-timeout-warning strong{display:block;font-size:clamp(18px,2vw,30px);font-weight:900;letter-spacing:.12em;text-transform:uppercase;color:var(--gold);margin-bottom:12px}
.session-timeout-warning span{display:block;font-size:clamp(30px,4vw,62px);font-weight:900;line-height:1.08;color:var(--navy)}
.session-timeout-warning button{flex:0 0 auto;min-height:58px;padding:0 30px;border:1px solid rgba(0,70,129,.28);border-radius:10px;background:var(--blue);color:#fff;font-family:inherit;font-size:16px;font-weight:900;cursor:pointer}
.session-timeout-warning button:hover{background:#0a5a9e}
@keyframes sessionWarningSlide{from{transform:translateY(-100%);opacity:.2}to{transform:translateY(0);opacity:1}}
.auth-user{display:inline-flex;align-items:center;gap:8px;min-height:34px;padding:0 12px;color:var(--gold);font-size:13px;font-weight:700;line-height:1;border:1px solid rgba(255,255,255,.18);border-radius:8px;background:rgba(255,255,255,.025);box-shadow:inset 0 1px 0 rgba(255,255,255,.05)}
.auth-user::before{content:"";width:19px;height:19px;background:currentColor;display:inline-block;flex:0 0 19px;-webkit-mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 64 64'%3E%3Ccircle cx='32' cy='17' r='14' fill='black'/%3E%3Cpath d='M8 60V50c0-14 10.5-24 24-24s24 10 24 24v10H8z' fill='black'/%3E%3C/svg%3E") center/contain no-repeat;mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 64 64'%3E%3Ccircle cx='32' cy='17' r='14' fill='black'/%3E%3Cpath d='M8 60V50c0-14 10.5-24 24-24s24 10 24 24v10H8z' fill='black'/%3E%3C/svg%3E") center/contain no-repeat}
.auth-role{display:inline-flex;align-items:center;gap:8px;background:rgba(255,255,255,.025);border:1px solid rgba(255,255,255,.18);border-radius:8px;color:var(--text-mid);font-size:12px;font-weight:700;font-family:inherit;padding:8px 10px;line-height:1;cursor:default;box-shadow:inset 0 1px 0 rgba(255,255,255,.05)}
.auth-user-view{display:none}
.auth-role.clickable{cursor:pointer;border-color:rgba(255,255,255,.22)}
.auth-role.clickable:hover{border-color:rgba(10,90,158,.55);background:rgba(10,90,158,.18);color:var(--white)}
.auth-role.impersonating{color:var(--gold);border-color:var(--gold-border);background:rgba(178,139,93,.08)}
.auth-role-caret{font-size:10px;color:var(--text-muted)}
.auth-logout{min-height:34px;display:inline-flex;align-items:center;justify-content:center;gap:8px;background:rgba(255,255,255,.025);color:var(--text-muted);border:1px solid rgba(255,255,255,.2);border-radius:8px;font-size:13px;font-weight:700;cursor:pointer;font-family:inherit;transition:color .16s,border-color .16s,background .16s,transform .08s,box-shadow .16s;padding:0 12px;box-shadow:inset 0 1px 0 rgba(255,255,255,.05)}
.auth-logout-icon{font-size:15px;line-height:1}
.auth-lock-icon{position:relative;display:inline-block;width:13px;height:11px;border:2px solid currentColor;border-radius:3px;margin-top:4px;opacity:.9}
.auth-lock-icon::before{content:"";position:absolute;left:1px;top:-8px;width:7px;height:7px;border:2px solid currentColor;border-bottom:0;border-radius:7px 7px 0 0}
.auth-logout:hover{color:var(--gold-light);border-color:var(--gold-border);background:var(--surface-hover)}
.auth-logout:active{transform:translateY(1px) scale(.98);background:rgba(178,139,93,.14);border-color:rgba(191,145,82,.58);box-shadow:inset 0 2px 5px rgba(0,0,0,.2)}
@media(max-width:1100px){
  body{padding-top:66px}
  .header-top{min-height:66px;padding:12px 20px}
  .vacancy-foundation-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .policy-foundation-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
}
@media(max-width:700px){
  .dashboard-hero,.vacancy-hero,.role-library-hero{grid-template-columns:1fr}
  .dashboard-visual{border-left:0;border-top:1px solid rgba(14,32,74,.1);min-height:210px}
  .dashboard-visual img{min-height:210px}
  .card-grid,.detail-grid,.home-menu{grid-template-columns:1fr}
  .home-menu-btn{min-height:148px;padding:22px}
  .home-menu-btn:last-child:nth-child(odd){grid-column:auto;width:100%}
  .mini-scores{display:none}
  .container{padding:24px 14px}
  .hero{margin-bottom:32px}
  .page-action-bar{align-items:stretch;margin-bottom:18px;padding:12px;gap:10px}
  .page-action-bar-content{gap:10px}
  .page-action-nav{flex-basis:170px}
  .page-action-functions{align-items:stretch}
  .candidate-row{align-items:flex-start;gap:14px;padding:18px}
  .candidate-row .rank{width:28px;font-size:18px}
  .data-reliability{width:100%;flex-basis:100%}
  .document-item{align-items:flex-start;flex-direction:column}
  .document-actions{width:100%;justify-content:flex-start;flex-wrap:wrap}
  .admin-layout,.admin-form-grid{grid-template-columns:1fr}
  .admin-impersonation-control{width:100%;align-items:stretch}
  .admin-impersonation-control span{text-align:left;max-width:none}
  .admin-user-lock-notice{grid-template-columns:1fr}
  .admin-user-lock-notice span,.admin-user-lock-notice .btn-outline{grid-column:auto;grid-row:auto}
  .role-session-security-control{align-items:flex-start;flex-direction:column}
  .role-session-minutes{justify-content:space-between}
  .session-timeout-warning{top:66px;min-height:36vh;flex-direction:column;align-items:flex-start;gap:22px}
  .session-timeout-warning button{width:100%}
  .vacancy-site-admin-row,.vacancy-site-details-grid,.site-asset-repositories{grid-template-columns:1fr}
  .vacancy-site-description,.vacancy-site-remove{grid-column:auto;grid-row:auto}
  .vacancy-site-remove{justify-content:flex-start}
  .vacancy-site-remove .btn{width:min(100%,220px);max-width:220px}
  .site-asset-tile{grid-template-columns:64px minmax(0,1fr)}
  .site-asset-status-stack{grid-column:1/-1;flex-direction:row;flex-wrap:wrap;justify-content:flex-end}
  .user-editor-actions,.role-editor-actions,.logging-editor-actions{grid-template-columns:1fr}
  .vacancy-foundation-grid{grid-template-columns:1fr}
  .policy-foundation-grid{grid-template-columns:1fr}
  .vacancy-hero,.dashboard-hero-copy,.vacancy-list-panel,.role-library-hero,.role-library-list-panel{padding:24px}
  .vacancy-row{align-items:flex-start;flex-direction:column}
  .vacancy-row-meta{justify-content:flex-start}
  .role-row{align-items:flex-start;flex-direction:column}
  .role-chip-row{justify-content:flex-start}
  .role-detail-section-header{align-items:flex-start;flex-direction:column}
  .role-detail-actions{width:100%;justify-content:flex-end}
  .role-detail-action-btn{width:min(100%,220px)}
  .role-description-toolbar{align-items:stretch;flex-direction:column}
  .role-description-toolbar-actions{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));justify-content:stretch}
  .role-description-toolbar-actions .role-detail-action-btn{width:100%;max-width:none;white-space:normal}
  .role-person-spec-toolbar{align-items:stretch;flex-direction:column}
  .role-person-spec-toolbar-actions{display:grid;grid-template-columns:1fr;justify-content:stretch}
  .role-person-spec-toolbar-actions .role-detail-action-btn{width:100%;max-width:none;white-space:normal}
  .role-person-spec-copy{grid-template-columns:minmax(120px,.42fr) minmax(0,1fr);min-width:0;width:100%}
  .role-person-spec-copy .role-person-spec-copy-btn{min-width:0}
  .person-spec-evidence-map-head{flex-direction:column}
  .person-spec-evidence-map-counts{justify-content:flex-start}
  .person-spec-evidence-map-grid{grid-template-columns:1fr}
  .role-criteria-toolbar{align-items:stretch;flex-direction:column}
  .role-criteria-toolbar-actions{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));justify-content:stretch}
  .role-criteria-toolbar-actions .role-detail-action-btn{width:100%;max-width:none;white-space:normal}
  .role-criteria-toolbar-actions .role-detail-action-btn:only-child{grid-column:2}
  .criteria-audit-panel{grid-template-columns:1fr}
  .criteria-audit-actions{align-items:stretch}
  .role-category-editor{grid-template-columns:1fr}
  .add-job-description-modal{max-height:86vh;padding:24px;width:94%}
  .add-job-description-modal .role-category-editor{grid-template-columns:repeat(2,minmax(0,1fr))}
  .edit-job-description-modal{max-height:88vh;padding:24px;width:94%}
  .edit-job-description-modal .role-category-editor{grid-template-columns:repeat(2,minmax(0,1fr))}
  .add-job-duplicate-actions{grid-template-columns:1fr;max-width:none}
  .add-job-alternative-actions{grid-template-columns:1fr;max-width:none}
  .dialog-actions{grid-template-columns:1fr;max-width:none}
  .role-library-readiness{grid-template-columns:1fr}
  .role-filter-primary-row,.role-filter-secondary-row{grid-template-columns:1fr}
  .role-filter-count{width:100%;justify-content:flex-start;padding:0 14px}
  .history-item,.role-item{align-items:flex-start;gap:12px;flex-direction:column}
  .history-actions{width:100%;justify-content:flex-end;flex-wrap:wrap}
  .modal{padding:24px;width:94%;max-height:86vh}
}
@media(max-width:520px){
  body{padding-top:64px}
  .header-top{min-height:64px;padding:10px 14px}
  .header-left{gap:12px}
  .header-auth{gap:6px;margin-left:8px}
  .header-logo{height:34px}
  .header-divider{display:none}
  .header-title{font-size:15px}
  .header-sub{font-size:10px;letter-spacing:.2px}
  .add-job-description-modal .role-category-editor{grid-template-columns:1fr}
  .add-job-modal-actions{grid-template-columns:1fr;max-width:none}
  .auth-user,.auth-role{font-size:12px}
  .server-health-text{display:none}
  .auth-logout{min-height:32px;padding:0 10px;font-size:12px}
  .auth-logout-text{display:none}
  .hero h1{font-size:30px}
  .home-menu-top{gap:12px}
  .home-menu-graphic{width:48px;height:48px;flex-basis:48px}
  .home-menu-graphic svg{width:28px;height:28px}
  .card{padding:22px}
  .candidate-row{flex-wrap:wrap}
  .detail-panel{padding:0 18px 18px}
  .btn,.btn-outline{width:auto;max-width:100%}
}
.hidden{display:none!important}
/* Loading overlay */
.loading-overlay{position:fixed;inset:0;background:rgba(10,23,54,0.85);display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:200;animation:fadeIn .2s}
.loading-overlay .spinner{margin-bottom:20px}
.loading-overlay h3{font-family:'Cormorant Garamond',serif;font-size:20px;font-weight:600;color:var(--white);margin-bottom:8px}
.loading-overlay p{font-size:13px;color:var(--text-muted);text-align:center;max-width:420px;white-space:pre-line}
.loading-overlay .loading-hint{font-size:11px;line-height:1.45;max-width:360px;margin-top:10px;opacity:.72}
.login-card input{height:40px}
.login-divider{display:flex;align-items:center;gap:12px;margin:18px 0 12px;color:var(--text-muted);font-size:11px;font-weight:800;letter-spacing:.12em;text-transform:uppercase}
.login-divider::before,.login-divider::after{content:"";height:1px;background:var(--border);flex:1}
.session-lock-note{display:flex;align-items:center;justify-content:space-between;gap:14px;border:1px solid rgba(191,145,82,.28);background:rgba(191,145,82,.08);border-radius:10px;padding:12px 14px;margin-bottom:18px;color:var(--text-muted);font-size:13px;line-height:1.45}
.session-lock-note strong{display:block;color:var(--gold);font-size:12px;letter-spacing:.06em;text-transform:uppercase;margin-bottom:2px}
.session-lock-note span{display:block}
.session-lock-note button{flex:0 0 auto;min-height:34px;padding:0 12px;border:1px solid rgba(191,145,82,.38);border-radius:8px;background:rgba(191,145,82,.14);color:var(--gold-light);font-family:inherit;font-size:12px;font-weight:900;cursor:pointer}
.session-lock-note button:hover{background:rgba(191,145,82,.22)}
.login-microsoft-placeholder{width:100%;min-height:48px;display:flex;align-items:center;justify-content:center;border:1px solid rgba(0,70,129,.28);border-radius:10px;background:rgba(10,90,158,.06);color:var(--blue);font-family:inherit;font-size:14px;font-weight:800;cursor:not-allowed;opacity:.72}
.login-microsoft-placeholder:not(:disabled){cursor:pointer;opacity:1;background:#fff}
.login-sso-note{font-size:12px;color:var(--text-muted);line-height:1.45;text-align:center;margin:9px 0 0}
.manual-login-panel{border-top:1px solid var(--border);margin-top:18px;padding-top:14px}
.manual-login-panel summary{cursor:pointer;color:var(--text-muted);font-size:12px;font-weight:900;letter-spacing:.08em;text-transform:uppercase}
.manual-login-panel div{margin-top:14px}
.login-progress{height:4px;background:var(--navy-lighter);border-radius:999px;overflow:hidden;margin-top:14px}
.login-progress span{display:block;width:45%;height:100%;background:linear-gradient(90deg,var(--gold),var(--gold-light));border-radius:999px;animation:loginProgress 1s ease-in-out infinite}
@keyframes loginProgress{0%{transform:translateX(-110%)}100%{transform:translateX(240%)}}
body.apply-mode{background:var(--navy-dark);color:var(--text-light)}
body.apply-mode .container{max-width:980px}
.apply-shell{background:var(--navy);border:1px solid var(--border);border-radius:14px;padding:32px;box-shadow:0 4px 40px rgba(0,0,0,.12)}
.apply-maintenance{background:var(--navy);border:1px solid rgba(248,113,113,.24);border-radius:14px;padding:36px 32px;box-shadow:0 4px 40px rgba(0,0,0,.12)}
.apply-maintenance h1{font-family:'Cormorant Garamond','Georgia',serif;font-size:34px;font-weight:600;line-height:1.2;color:var(--white);margin-bottom:14px}
.apply-maintenance h1 span{color:var(--gold)}
.apply-maintenance p{font-size:15px;color:var(--text-mid);line-height:1.7;max-width:760px}
.apply-heading{border-bottom:1px solid var(--border);padding-bottom:22px;margin-bottom:26px}
.apply-heading h1{font-family:'Cormorant Garamond','Georgia',serif;font-size:34px;font-weight:600;line-height:1.2;color:var(--white);margin-bottom:14px}
.apply-heading h1 span{color:var(--gold)}
.apply-meta{display:flex;gap:12px;flex-wrap:wrap;color:var(--text-mid);font-size:13px;margin-bottom:0}
.apply-meta span{border:1px solid var(--border);border-radius:999px;padding:5px 10px;background:var(--surface)}
.apply-intro{font-size:15px;color:var(--text-mid);line-height:1.7;max-width:780px;margin-bottom:24px}
.apply-intro strong{color:var(--gold-light)}
.apply-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px 32px}
.apply-field label{color:var(--text-faint);font-size:12px;margin-bottom:6px}
.apply-field input,.apply-field select,.apply-field textarea{background:var(--navy-light);border:1px solid var(--border);color:var(--text-light);border-radius:8px}
.apply-field input::placeholder,.apply-field textarea::placeholder{color:var(--text-faint)}
.apply-help{font-size:11px;color:var(--text-muted);line-height:1.45;margin-top:7px}
.apply-field textarea{min-height:90px}
.date-field{position:relative}
.date-input-wrap{display:flex;align-items:center;background:var(--navy-light);border:1px solid var(--border);border-radius:8px;transition:border-color .2s}
.date-input-wrap:focus-within{border-color:var(--gold-border)}
.date-input-wrap input{border:0;background:transparent}
.date-picker-btn{width:42px;height:40px;border:0;border-left:1px solid var(--border);background:transparent;color:var(--gold-light);font-size:16px;cursor:pointer}
.date-picker{position:absolute;top:74px;left:0;right:0;z-index:50;background:var(--navy);border:1px solid var(--gold-border);border-radius:12px;box-shadow:0 18px 50px rgba(0,0,0,.28);padding:14px;max-width:360px}
.date-picker-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}
.date-picker-title{font-size:14px;font-weight:700;color:var(--white)}
.date-nav{width:32px;height:32px;border:1px solid var(--border);border-radius:8px;background:var(--navy-light);color:var(--text-light);cursor:pointer}
.date-nav:disabled{opacity:.35;cursor:not-allowed}
.date-weekdays,.date-grid-days{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}
.date-weekdays span{font-size:10px;font-weight:700;color:var(--text-faint);text-align:center;text-transform:uppercase;padding:4px 0}
.date-day{height:34px;border:1px solid transparent;border-radius:8px;background:transparent;color:var(--text-mid);font-family:inherit;cursor:pointer}
.date-day:hover:not(:disabled){border-color:var(--gold-border);color:var(--gold-light);background:var(--gold-dim)}
.date-day.selected{background:var(--gold);color:var(--navy-dark);font-weight:800}
.date-day.today{border-color:var(--gold-border)}
.date-day.muted{color:var(--text-faint);opacity:.45}
.date-day:disabled{opacity:.25;cursor:not-allowed}
.apply-section{margin-top:30px;border-top:1px solid var(--border);padding-top:24px}
.apply-section h2{font-family:'Cormorant Garamond','Georgia',serif;font-size:26px;font-weight:600;color:var(--white);margin-bottom:18px}
.apply-documents-section{grid-column:1/-1;margin-top:8px;margin-bottom:10px}
.apply-upload{display:grid;grid-template-columns:180px minmax(0,1fr);gap:8px 16px;align-items:center;padding:14px 0;border-top:1px solid rgba(142,160,198,.18)}
.apply-upload:first-of-type{border-top:0;padding-top:2px}
.apply-upload-label{font-size:13px;font-weight:700;color:var(--text-light)}
.apply-upload-label span{font-weight:400;color:var(--text-muted)}
.apply-upload-control{display:grid;grid-template-columns:max-content minmax(0,1fr);align-items:start;gap:12px;min-width:0}
.apply-file-btn{display:inline-flex;align-items:center;gap:8px;width:max-content;padding:8px 12px;background:var(--navy-light);border:1px solid var(--border);border-radius:8px;color:var(--text-light);cursor:pointer;font-size:13px;transition:all .2s}
.apply-file-btn:hover{border-color:var(--gold-border);color:var(--gold-light)}
.apply-file-name{display:flex;flex-direction:column;align-items:flex-start;gap:8px;min-width:0}
.apply-file-chip{display:inline-grid;grid-template-columns:minmax(0,1fr) 24px;align-items:center;gap:8px;max-width:100%;min-width:min(360px,100%);padding:6px 8px 6px 10px;background:var(--navy-light);border:1px solid var(--border);border-radius:8px;color:var(--text-mid);font-size:12px}
.apply-file-chip-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.apply-file-remove{width:24px;height:24px;display:inline-flex;align-items:center;justify-content:center;border:1px solid var(--border);border-radius:6px;background:transparent;color:var(--text-muted);cursor:pointer;font-size:16px;line-height:1;font-weight:800;flex:0 0 24px}
.apply-file-remove:hover,.apply-file-remove:focus{border-color:#fca5a5;color:#fca5a5;background:rgba(252,165,165,.08);outline:none}
.apply-validation-status{grid-column:2;font-size:12px;line-height:1.5;max-width:680px;display:flex;flex-wrap:wrap;gap:8px 10px}
.cv-validation-label{display:inline-flex;align-items:center;gap:8px;font-weight:800;letter-spacing:.2px}
.cv-validation-label.scanning{color:var(--gold-light)}
.cv-validation-label.valid{color:var(--green)}
.cv-validation-label.error{color:#fca5a5}
.cv-validation-progress{width:220px;height:5px;margin-top:8px;background:var(--navy-lighter);border-radius:999px;overflow:hidden}
.cv-validation-progress span{display:block;width:45%;height:100%;background:linear-gradient(90deg,var(--gold),var(--blue-light));border-radius:999px;animation:cvValidationProgress 1s ease-in-out infinite}
@keyframes cvValidationProgress{0%{transform:translateX(-120%)}100%{transform:translateX(240%)}}
.question-block{border-top:1px solid var(--border);padding-top:18px;margin-top:18px}
.question-block p{color:var(--text-mid);line-height:1.55;margin-bottom:10px}
.segmented{display:inline-flex;border:1px solid var(--border);border-radius:8px;overflow:hidden;background:var(--navy-light)}
.segmented label{padding:8px 18px;margin:0;color:var(--text-mid);font-size:12px;font-weight:700;cursor:pointer}
.segmented input{display:none}
.segmented label:has(input:checked){background:var(--gold-dim);color:var(--gold-light)}
.declaration-box{display:flex;gap:16px;background:var(--navy-dark);border:1px solid var(--border);border-radius:12px;padding:18px 20px;color:var(--text-mid);line-height:1.55;margin-top:24px}
.declaration-box input{width:20px;height:20px;margin-top:4px;flex:0 0 20px}
.apply-offence-statement{color:var(--white);line-height:1.6;margin-top:24px;font-size:16px;font-weight:700;background:var(--navy-dark);border:1px solid var(--gold-border);border-radius:12px;padding:18px 20px}
.apply-actions{display:flex;justify-content:flex-end;gap:14px;margin-top:26px}
.apply-access-panel{width:min(1040px,calc(100% - 32px));margin:24px auto;padding:18px;border:1px solid rgba(255,255,255,.12);border-radius:8px;background:rgba(0,28,54,.72)}
.apply-access-panel h2{margin:0 0 6px;font-family:'Cormorant Garamond',serif;font-size:24px;color:var(--white)}
.apply-access-panel p{margin:0 0 14px;color:var(--text-muted);font-size:13px;line-height:1.5}
.apply-access-controls{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr) auto;gap:10px;align-items:end}
.apply-access-note{font-size:13px;color:var(--text-muted);line-height:1.5;margin-top:12px}
.apply-access-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px 18px;margin:14px 0}
.apply-access-actions{display:flex;gap:10px;flex-wrap:wrap;justify-content:flex-end;margin-top:16px}
.submit-tooltip-wrap{position:relative;display:inline-flex}
.submit-tooltip{position:absolute;right:0;bottom:calc(100% + 12px);width:300px;background:var(--navy-dark);border:1px solid var(--gold-border);border-radius:12px;padding:14px 16px;color:var(--text-mid);font-size:12px;line-height:1.45;box-shadow:0 18px 50px rgba(0,0,0,.32);opacity:0;pointer-events:none;transform:translateY(6px);transition:all .18s;z-index:80}
.submit-tooltip-wrap:hover .submit-tooltip,.submit-tooltip-wrap:focus-within .submit-tooltip{opacity:1;transform:translateY(0)}
.submit-tooltip strong{display:block;color:var(--gold-light);font-size:12px;text-transform:uppercase;letter-spacing:.7px;margin-bottom:8px}
.submit-tooltip ul{margin:0;padding-left:18px}
.submit-tooltip li{margin:4px 0}
.status-select{width:auto;min-width:160px}
body.apply-mode{background:linear-gradient(180deg,#f8f7f4 0,#f3f5f8 46%,#e9edf4 100%);color:var(--navy)}
body.apply-mode .container{max-width:1040px}
body.apply-mode .apply-shell,
body.apply-mode .apply-maintenance{
  background:#fff;
  border-color:rgba(14,32,74,.12);
  box-shadow:0 18px 55px rgba(14,32,74,.08);
}
body.apply-mode .apply-heading{border-bottom-color:rgba(14,32,74,.12)}
body.apply-mode .apply-heading h1,
body.apply-mode .apply-maintenance h1,
body.apply-mode .apply-section h2,
body.apply-mode #applyRoleTitle{color:var(--navy)!important}
body.apply-mode .apply-heading h1 span,
body.apply-mode .apply-maintenance h1 span{color:var(--gold)}
body.apply-mode .apply-intro,
body.apply-mode .apply-maintenance p,
body.apply-mode .apply-meta,
body.apply-mode .apply-help,
body.apply-mode .question-block p,
body.apply-mode .declaration-box,
body.apply-mode .apply-file-chip{color:#66738a}
body.apply-mode .apply-intro strong{color:var(--gold)}
body.apply-mode .apply-meta span{
  background:#f8fafc;
  border-color:rgba(14,32,74,.12);
  color:#526078;
}
body.apply-mode .apply-field label{color:#7a8498}
body.apply-mode .apply-field input,
body.apply-mode .apply-field select,
body.apply-mode .apply-field textarea,
body.apply-mode .date-input-wrap{
  background:#f8fafc;
  border-color:rgba(14,32,74,.16);
  color:var(--navy);
}
body.apply-mode .apply-field input::placeholder,
body.apply-mode .apply-field textarea::placeholder{color:#9aa3b5}
body.apply-mode .apply-field input:focus,
body.apply-mode .apply-field select:focus,
body.apply-mode .apply-field textarea:focus,
body.apply-mode .date-input-wrap:focus-within{
  border-color:rgba(178,139,93,.46);
  box-shadow:0 0 0 3px rgba(178,139,93,.12);
}
body.apply-mode .apply-field select option{background:#fff;color:var(--navy)}
body.apply-mode .date-picker{
  background:#fff;
  border-color:rgba(178,139,93,.34);
  box-shadow:0 18px 55px rgba(14,32,74,.14);
}
body.apply-mode .date-picker-title{color:var(--navy)}
body.apply-mode .date-nav{background:#f8fafc;border-color:rgba(14,32,74,.12);color:var(--navy)}
body.apply-mode .date-weekdays span{color:#7a8498}
body.apply-mode .date-day{color:#526078}
body.apply-mode .date-day:hover:not(:disabled){background:#f8f3ec;color:var(--gold);border-color:rgba(178,139,93,.34)}
body.apply-mode .date-day.selected{background:var(--gold);color:var(--navy)}
body.apply-mode .apply-section,
body.apply-mode .question-block,
body.apply-mode .apply-upload{border-color:rgba(14,32,74,.12)}
body.apply-mode .apply-upload-label{color:var(--navy)}
body.apply-mode .apply-upload-label span{color:#7a8498}
body.apply-mode .apply-file-btn,
body.apply-mode .apply-file-chip,
body.apply-mode .segmented{
  background:#f8fafc;
  border-color:rgba(14,32,74,.16);
  color:var(--navy);
}
body.apply-mode .apply-file-btn:hover{background:#eef5fb;border-color:rgba(0,70,129,.28);color:var(--blue)}
body.apply-mode .apply-file-remove{border-color:rgba(14,32,74,.16);color:#7a8498}
body.apply-mode .apply-file-remove:hover,
body.apply-mode .apply-file-remove:focus{border-color:#fca5a5;color:#b91c1c;background:rgba(248,113,113,.08)}
body.apply-mode .cv-validation-label.scanning{color:var(--gold)}
body.apply-mode .cv-validation-label.valid{color:#15803d}
body.apply-mode .cv-validation-label.error{color:#b91c1c}
body.apply-mode .cv-validation-progress{background:#e7edf5}
body.apply-mode .segmented label{color:#526078}
body.apply-mode .segmented label:has(input:checked){background:#f8f3ec;color:var(--gold)}
body.apply-mode .declaration-box{
  background:#f8fafc;
  border-color:rgba(14,32,74,.12);
}
body.apply-mode .apply-offence-statement{
  background:#fff7ed;
  border-color:rgba(178,139,93,.34);
  color:var(--navy);
}
body.apply-mode .submit-tooltip{
  background:#fff;
  border-color:rgba(178,139,93,.34);
  color:#66738a;
  box-shadow:0 18px 55px rgba(14,32,74,.14);
}
body.apply-mode .submit-tooltip strong{color:var(--gold)}
body.apply-mode .error-box{background:rgba(248,113,113,.08);border-color:rgba(248,113,113,.22);color:#b91c1c}
.audit-shell{max-width:1180px;margin:0 auto}
.audit-hero{grid-template-columns:minmax(0,1.2fr) minmax(320px,.75fr)}
.audit-tabs{display:flex;gap:10px;margin:0 0 16px}
.audit-tabs button{border:2px solid rgba(14,32,74,.12);background:#fff;color:var(--navy);border-radius:10px;padding:12px 18px;font-weight:800;cursor:pointer;transition:background .18s,border-color .18s,transform .16s}
.audit-tabs button:hover{background:#eef5fb;border-color:rgba(0,70,129,.24);transform:translateY(-1px)}
.audit-tabs button.active{background:var(--blue);border-color:var(--blue);color:#fff}
.audit-filter-panel{display:grid;grid-template-columns:minmax(0,1.4fr) minmax(240px,.6fr);gap:14px;background:#fff;border:1px solid rgba(14,32,74,.12);border-radius:14px;padding:18px;margin-bottom:16px;box-shadow:0 12px 32px rgba(14,32,74,.06)}
.audit-filter-panel label{display:block;font-size:11px;text-transform:uppercase;letter-spacing:.08em;font-weight:800;color:#66738a;margin-bottom:7px}
.audit-filter-panel input,.audit-filter-panel select{width:100%;background:#f8fafc;border:1px solid rgba(14,32,74,.16);border-radius:10px;color:var(--navy);padding:12px 14px;font-family:inherit;font-size:14px}
.audit-log-list{display:grid;grid-template-columns:1fr;gap:12px}
.audit-log-card{background:#fff;border:1px solid rgba(14,32,74,.12);border-radius:14px;box-shadow:0 12px 32px rgba(14,32,74,.06);overflow:hidden}
.audit-log-card summary{display:flex;justify-content:space-between;align-items:center;gap:18px;padding:18px 22px;cursor:pointer;list-style:none}
.audit-log-card summary::-webkit-details-marker{display:none}
.audit-log-card summary strong{display:block;color:var(--navy);font-size:15px;margin-bottom:5px}
.audit-log-card summary small{display:block;color:#66738a;font-size:12px}
.audit-log-meta{display:inline-flex;align-items:center;justify-content:center;min-width:120px;border:1px solid rgba(0,70,129,.14);border-radius:999px;background:#eef5fb;color:var(--blue);padding:7px 10px;font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.04em;text-align:center}
.audit-log-detail{border-top:1px solid rgba(14,32,74,.1);padding:18px 22px 22px}
.audit-detail-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;margin-bottom:16px}
.audit-detail-grid div{border:1px solid rgba(14,32,74,.1);border-radius:10px;background:#f8fafc;padding:12px}
.audit-detail-grid span{display:block;color:#66738a;font-size:10px;font-weight:800;letter-spacing:.06em;text-transform:uppercase;margin-bottom:5px}
.audit-detail-grid strong{display:block;color:var(--navy);font-size:13px;line-height:1.35}
.audit-log-detail pre{white-space:pre-wrap;word-break:break-word;max-height:340px;overflow:auto;background:#f8fafc;border:1px solid rgba(14,32,74,.1);border-radius:10px;color:#334155;padding:14px;font-size:12px;line-height:1.55}
.audit-prompt-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.audit-prompt-grid h4{font-size:12px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:#66738a;margin-bottom:8px}
.audit-empty{text-align:center;background:#fff;border:1px solid rgba(14,32,74,.12);border-radius:14px;padding:70px 24px;color:#66738a;box-shadow:0 12px 32px rgba(14,32,74,.06)}
.audit-empty div{font-size:34px;margin-bottom:12px}
.audit-empty h3{font-family:'Cormorant Garamond',serif;font-size:26px;color:var(--navy);margin-bottom:8px}
@media(max-width:700px){
  .vacancy-content-builder-head{flex-direction:column}
  .vacancy-content-builder-actions{justify-content:stretch;width:100%}
  .vacancy-content-builder-actions .btn{width:100%}
  .vacancy-content-builder-grid{grid-template-columns:1fr}
  .vacancy-content-preview-panel{position:static}
  .job-vacancy-content-preview header,.job-vacancy-content-preview section{padding-left:20px;padding-right:20px}
  .prompt-admin-hero,.prompt-admin-layout,.prompt-info-grid,.prompt-tune-notes{grid-template-columns:1fr}
  .prompt-admin-hero-panel{grid-template-columns:1fr;border-left:0;border-top:1px solid rgba(14,32,74,.1)}
  .prompt-admin-list-panel{position:static;height:auto;min-height:0}
  .prompt-admin-list{max-height:680px}
  .prompt-detail-head{flex-direction:column}
  .audit-filter-panel,.audit-detail-grid,.audit-prompt-grid{grid-template-columns:1fr}
  .audit-log-card summary{align-items:flex-start;flex-direction:column}
  .audit-log-meta{min-width:0}
  .apply-shell{padding:22px 16px}
  .apply-grid{grid-template-columns:1fr}
  .apply-upload{grid-template-columns:1fr}
  .apply-validation-status{grid-column:1}
  .apply-actions{justify-content:stretch;flex-direction:column}
  .apply-actions .btn{width:100%}
  .apply-access-controls,.apply-access-grid{grid-template-columns:1fr}
  .apply-access-actions{justify-content:stretch}
  .apply-access-actions button{width:100%}
  .submit-tooltip-wrap{width:100%}
  .submit-tooltip{left:0;right:0;width:auto}
}
