/* ─── Prime Recruitment v2 (revision 3) — theme styles ─────────────────────
   Sourced from prime-recruitment (10).html. Two-CTA header, three-service-line
   structure, prominent HR Legal Partner band, expanded sector taxonomy.
─────────────────────────────────────────────────────────────────────── */

/* Palette aligned to the Prime Recruitment logo:
   Navy #1f2a5a (primary), Red #d8232f (accent), warm neutrals */
:root,[data-theme="light"]{
  --bg:#f4f1ec;
  --surface:#fbf8f3;
  --surface2:#ffffff;
  --surface3:#ebe6dc;
  --border:#c8c1b3;
  --divider:#dad3c5;
  --text:#13193a;
  --muted:#4f5572;
  --faint:#8a90a3;
  --inverse:#fbf8f3;
  --primary:#1f2a5a;
  --primary-h:#16204a;
  --primary-l:#dce0ed;
  --primary-soft:#eef0f7;
  --accent:#d8232f;
  --accent-h:#b81e29;
  --accent-soft:#fbe5e7;
  --gold:#a17a2b;
  --gold-soft:#f1e9d8;
  --r-sm:.375rem;--r-md:.5rem;--r-lg:.875rem;--r-xl:1.25rem;--r-2xl:1.75rem;--r-full:9999px;
  --t:180ms cubic-bezier(.16,1,.3,1);
  --sh-sm:0 1px 3px rgba(19,25,58,.06);
  --sh-md:0 8px 24px rgba(19,25,58,.07);
  --sh-lg:0 20px 60px rgba(19,25,58,.1);
  --sh-xl:0 32px 80px rgba(19,25,58,.14);
  --display:'Zodiak',Georgia,serif;
  --body:'General Sans','Inter',system-ui,sans-serif;
}
[data-theme="dark"]{
  --bg:#0d1024;
  --surface:#141833;
  --surface2:#1c2140;
  --surface3:#252b4d;
  --border:#3a4067;
  --divider:#2c325a;
  --text:#e8e6e0;
  --muted:#b3b8cc;
  --faint:#80869e;
  --inverse:#0d1024;
  --primary:#7986c6;
  --primary-h:#9aa4d4;
  --primary-l:#2a3160;
  --primary-soft:#1f254a;
  --accent:#e8505c;
  --accent-h:#f06870;
  --accent-soft:#3a1c20;
  --gold:#d4b06e;
  --gold-soft:#3a3220;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;scroll-padding-top:7rem}
body{min-height:100dvh;line-height:1.65;font-family:var(--body);font-size:clamp(1rem,.95rem + .2vw,1.0625rem);color:var(--text);background:var(--bg)}
img,svg{display:block;max-width:100%;height:auto}
button,a,input,textarea,select{font:inherit;color:inherit}
button{background:none;border:none;cursor:pointer}
a{text-decoration:none;color:inherit}
ul{list-style:none}
h1,h2,h3,h4{line-height:1.15;text-wrap:balance;font-family:var(--display);font-weight:400}
p{text-wrap:pretty}
:focus-visible{outline:2px solid var(--primary);outline-offset:3px;border-radius:var(--r-sm)}
@media (prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important}}
.skip{position:absolute;left:1rem;top:-100px;background:var(--primary);color:#fff;padding:.75rem 1rem;border-radius:var(--r-md);z-index:100}
.skip:focus{top:1rem}
.wrap{width:min(calc(100% - 3rem),1260px);margin-inline:auto}
.section{padding-block:clamp(3rem,8vw,6rem)}
.alt{background:var(--surface)}

/* Views with CSS-only fallback */
.view{display:none}
.view.is-active{display:block}
section.view:target{display:block}
main:not(:has(section.view:target)) section[data-view="home"]{display:block}

.eyebrow{display:inline-flex;align-items:center;gap:.5rem;font-size:clamp(.72rem,.68rem + .2vw,.8rem);letter-spacing:.18em;text-transform:uppercase;color:var(--muted);font-family:var(--body);font-weight:500}
.eyebrow::before{content:"";flex:none;width:2rem;height:1px;background:var(--primary);opacity:.55}
.h-section{font-size:clamp(1.6rem,1.2rem + 1.5vw,2.5rem);font-weight:400;letter-spacing:-.025em;margin-block:1rem 1.25rem}
.lead{color:var(--muted);max-width:60ch}

.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;min-height:50px;padding:.875rem 1.6rem;border-radius:var(--r-full);font-size:.9rem;font-weight:600;letter-spacing:.005em;transition:all var(--t);border:1.5px solid transparent;cursor:pointer;white-space:nowrap}
.btn-primary{background:var(--primary);color:#fff;box-shadow:var(--sh-sm)}
.btn-primary:hover{background:var(--primary-h);transform:translateY(-1px);box-shadow:var(--sh-md)}
.btn-accent{background:var(--accent);color:#fff;box-shadow:var(--sh-sm)}
.btn-accent:hover{background:var(--accent-h);transform:translateY(-1px);box-shadow:var(--sh-md)}
.btn-secondary{background:transparent;border-color:color-mix(in oklab,var(--text) 18%,transparent);color:var(--text)}
.btn-secondary:hover{background:var(--surface2);border-color:var(--primary)}
.btn-sm{min-height:42px;padding:.6rem 1.1rem;font-size:.825rem}

/* Header */
.head{position:sticky;top:0;z-index:60;backdrop-filter:blur(18px) saturate(1.6);-webkit-backdrop-filter:blur(18px) saturate(1.6);background:color-mix(in oklab,var(--bg) 85%,transparent);border-bottom:1px solid color-mix(in oklab,var(--text) 7%,transparent)}
.nav{display:flex;align-items:center;justify-content:space-between;min-height:7rem;gap:1rem}
.brand{display:inline-flex;align-items:center}
.brand img{height:80px;width:auto}
@media (max-width:760px){.brand img{height:64px}}
[data-theme="dark"] .brand img{filter:brightness(1.15) contrast(1.05)}
nav.primary ul{display:flex;align-items:center;gap:1.75rem}
nav.primary a{font-size:.9rem;color:var(--muted);transition:color var(--t);position:relative;padding-block:.25rem;cursor:pointer;font-weight:500}
nav.primary a:hover,nav.primary a.is-active{color:var(--text)}
nav.primary a.is-active::after{content:"";position:absolute;left:0;right:0;bottom:-3px;height:2px;background:var(--accent)}
.h-right{display:flex;align-items:center;gap:.6rem}
.icon-btn{display:grid;place-items:center;width:44px;height:44px;border-radius:50%;border:1px solid color-mix(in oklab,var(--text) 10%,transparent);background:var(--surface2);transition:all var(--t)}
.icon-btn:hover{background:var(--surface3)}
.menu-btn{display:none}

/* Hero */
.hero{position:relative;overflow:clip;padding-block:clamp(3rem,7vw,5.5rem) clamp(2rem,4vw,3.5rem);background:var(--surface2)}
.hero::before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse 60% 45% at 82% 0%,color-mix(in oklab,var(--primary) 8%,transparent),transparent),radial-gradient(ellipse 45% 55% at 10% 80%,color-mix(in oklab,var(--accent) 4%,transparent),transparent);pointer-events:none}
.hero-in{position:relative;display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(2rem,5vw,4rem);align-items:start}
.hero h1{font-size:clamp(2.4rem,1.4rem + 3.5vw,4.6rem);letter-spacing:-.04em;color:var(--text);max-width:15ch;margin-block:1.25rem 1.5rem}
.hero h1 em{font-style:italic;color:var(--primary)}
.hero .lead{font-size:clamp(1.05rem,1rem + .4vw,1.25rem);max-width:42ch;line-height:1.55}
.hero-cta{display:flex;flex-wrap:wrap;gap:.75rem;margin-top:1.75rem}
.stats{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem;margin-top:2rem;padding-top:1.5rem;border-top:1px solid var(--divider)}
.stat strong{display:block;font-family:var(--display);font-size:clamp(1.5rem,1.2rem + .8vw,2rem);letter-spacing:-.03em;color:var(--primary)}
.stat span{font-size:.72rem;text-transform:uppercase;letter-spacing:.14em;color:var(--muted);margin-top:.25rem;display:block}

/* Live Mandates panel (hero right) */
.hp{position:relative;border-radius:var(--r-2xl);background:var(--surface2);border:1px solid color-mix(in oklab,var(--text) 8%,transparent);box-shadow:var(--sh-xl);overflow:clip}
.hp-bar{height:3px;background:linear-gradient(90deg,var(--primary),var(--accent))}
.hp-body{padding:1.75rem}
.hp-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}
.hp-head h3{font-family:var(--body);font-size:.78rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}
.hp-head a{font-size:.75rem;color:var(--primary);font-weight:600}
.role-list{display:grid;gap:.75rem}
.role-item{display:grid;grid-template-columns:1fr auto;align-items:center;gap:.75rem;padding:1rem 1.25rem;border-radius:var(--r-lg);background:var(--surface);border:1px solid color-mix(in oklab,var(--text) 7%,transparent);transition:all var(--t);cursor:pointer;color:var(--text);text-align:left;width:100%}
.role-item:hover{border-color:var(--primary);transform:translateX(2px);box-shadow:var(--sh-sm)}
.role-item h4{font-family:var(--body);font-size:.95rem;font-weight:600;margin-bottom:2px}
.role-item p{font-size:.8rem;color:var(--muted)}
.role-tag{font-size:.7rem;text-transform:uppercase;letter-spacing:.12em;white-space:nowrap;padding:.3rem .7rem;border-radius:var(--r-full);font-weight:700;background:color-mix(in oklab,var(--primary) 12%,var(--surface));color:var(--primary)}

/* Page hero (interior pages) */
.ph{position:relative;overflow:clip;padding-block:clamp(3rem,5vw,5rem) clamp(2rem,3.5vw,3rem);background:var(--surface2)}
.ph::before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse 60% 45% at 82% 0%,color-mix(in oklab,var(--primary) 8%,transparent),transparent),radial-gradient(ellipse 45% 55% at 10% 80%,color-mix(in oklab,var(--accent) 4%,transparent),transparent);pointer-events:none}
.ph-in{position:relative;max-width:58rem}
.ph h1{font-size:clamp(2rem,1.4rem + 2.4vw,3.4rem);letter-spacing:-.035em;margin-block:1rem 1.25rem}
.ph h1 em{font-style:italic;color:var(--primary)}
.ph .lead{font-size:clamp(1.05rem,1rem + .3vw,1.2rem);max-width:54ch;line-height:1.55}

/* Categories band */
.band{padding-block:1.75rem;border-block:1px solid color-mix(in oklab,var(--text) 7%,transparent);background:var(--surface)}
.band-in{display:grid;grid-template-columns:auto 1fr;gap:2.5rem;align-items:center}
.chips{display:flex;flex-wrap:wrap;gap:.6rem}
.chip{padding:.55rem 1rem;border-radius:var(--r-full);background:var(--surface2);border:1px solid color-mix(in oklab,var(--text) 9%,transparent);font-size:.85rem;color:var(--text);font-weight:500}

/* Dual cards (Hiring / Candidates) */
.dual{display:grid;grid-template-columns:1fr 1fr;gap:1.25rem;margin-top:2rem}
.dual-card{padding:2rem;border-radius:var(--r-2xl);background:var(--surface2);border:1px solid color-mix(in oklab,var(--text) 8%,transparent);box-shadow:var(--sh-sm);transition:all var(--t);display:flex;flex-direction:column;gap:1rem;color:var(--text);cursor:pointer}
.dual-card:hover{box-shadow:var(--sh-lg);transform:translateY(-2px);border-color:var(--primary)}
.dual-card .badge{display:inline-block;padding:.35rem .85rem;border-radius:var(--r-full);font-size:.7rem;text-transform:uppercase;letter-spacing:.14em;font-weight:700;align-self:flex-start}
.dual-card .badge.hire{background:var(--accent-soft);color:var(--accent)}
.dual-card .badge.cand{background:var(--primary-soft);color:var(--primary)}
.dual-card h3{font-size:1.5rem;letter-spacing:-.02em}
.dual-card p{color:var(--muted);font-size:1rem;line-height:1.6;flex:1}
.dual-card .arr{font-size:.875rem;color:var(--primary);font-weight:600;margin-top:.5rem}

/* Services (advisory split) */
.advisory{display:grid;grid-template-columns:.9fr 1.1fr;gap:clamp(2rem,5vw,3rem);align-items:start}
.sticky{position:sticky;top:7.5rem;padding:2rem;border-radius:var(--r-2xl);background:var(--surface2);border:1px solid color-mix(in oklab,var(--text) 8%,transparent);box-shadow:var(--sh-md)}
.sticky blockquote{font-family:var(--display);font-size:clamp(1.4rem,1.6vw,2rem);line-height:1.2;letter-spacing:-.02em;margin-top:1.25rem;color:var(--text)}
.sticky p{margin-top:1.25rem;color:var(--muted)}
.svc-list{display:grid;gap:1rem}
.svc{padding:1.75rem 2rem;border-radius:var(--r-xl);background:var(--surface2);border:1px solid color-mix(in oklab,var(--text) 8%,transparent);transition:all var(--t)}
.svc:hover{box-shadow:var(--sh-md);border-color:color-mix(in oklab,var(--primary) 22%,transparent)}
.svc h3{font-family:var(--body);font-size:1.05rem;font-weight:700;color:var(--text);margin-bottom:.5rem;letter-spacing:-.01em}
.svc-sub{font-size:.78rem;color:var(--primary);font-weight:600;text-transform:uppercase;letter-spacing:.1em;margin-bottom:.75rem;font-style:normal}
.svc p{color:var(--muted);margin-bottom:.75rem}
.svc ul{display:grid;gap:.45rem;margin-top:.75rem}
.svc li{font-size:.875rem;color:var(--muted);padding-left:1.1rem;position:relative;line-height:1.55}
.svc li::before{content:"";position:absolute;left:0;top:.6em;width:.35rem;height:.35rem;border-radius:50%;background:var(--primary)}


.sector-chips{display:flex;flex-wrap:wrap;gap:.75rem;margin-top:2rem}
.sec-chip{padding:.75rem 1.25rem;border-radius:var(--r-full);background:var(--surface2);border:1px solid color-mix(in oklab,var(--text) 9%,transparent);font-size:.9rem;color:var(--text);font-weight:500}

/* Sectors */
.sg{display:grid;grid-template-columns:repeat(5,1fr);gap:1rem;margin-top:2rem}
.sc{padding:1.5rem 1.25rem;border-radius:var(--r-xl);min-height:230px;background:var(--surface2);border:1px solid color-mix(in oklab,var(--text) 8%,transparent);display:flex;flex-direction:column;justify-content:space-between;box-shadow:var(--sh-sm);transition:all var(--t);cursor:pointer}
.sc:hover{box-shadow:var(--sh-md);transform:translateY(-2px);border-color:var(--primary)}
.sn{font-size:.72rem;color:var(--accent);text-transform:uppercase;letter-spacing:.14em;font-weight:700}
.sc h3{font-size:1.2rem;letter-spacing:-.02em;color:var(--text)}
.sc p{font-size:.875rem;color:var(--muted)}

/* Sector deep cards on Services page */
.sd{padding:1.75rem;border-radius:var(--r-2xl);background:var(--surface2);border:1px solid color-mix(in oklab,var(--text) 8%,transparent);box-shadow:var(--sh-sm);display:grid;grid-template-columns:1fr 1.5fr;gap:1.75rem;margin-bottom:1.25rem;scroll-margin-top:8rem}
.sd-side{display:flex;flex-direction:column;gap:.75rem}
.sd-num{font-family:var(--display);font-size:clamp(2.1rem,1.2rem + 2.8vw,4rem);color:var(--primary);line-height:1;letter-spacing:-.05em;opacity:.4}
.sd-side h3{font-size:clamp(1.4rem,1.2rem + 1vw,2rem);letter-spacing:-.02em;color:var(--text)}
.sd-side > p{color:var(--muted);line-height:1.6}
.sd-blocks{display:grid;gap:1.25rem}
.sd-bl strong{display:block;font-size:.72rem;text-transform:uppercase;letter-spacing:.14em;color:var(--accent);margin-bottom:.5rem;font-weight:700}
.sd-bl ul{display:grid;gap:.5rem}
.sd-bl li{font-size:.875rem;color:var(--muted);padding-left:1rem;position:relative}
.sd-bl li::before{content:"—";position:absolute;left:0;color:var(--primary);font-weight:600}

/* Process steps */
.pg{display:grid;grid-template-columns:repeat(5,1fr);gap:1rem;margin-top:2rem}
.pc{padding:1.5rem;border-radius:var(--r-xl);background:var(--surface2);border:1px solid color-mix(in oklab,var(--text) 7%,transparent);box-shadow:var(--sh-sm);display:flex;flex-direction:column;gap:.5rem}
.pn{width:2.2rem;height:2.2rem;border-radius:50%;display:grid;place-items:center;font-family:var(--display);font-size:.875rem;background:var(--primary-soft);color:var(--primary);margin-bottom:.75rem;border:1px solid color-mix(in oklab,var(--primary) 20%,transparent);font-weight:600}
.pc h3{font-family:var(--body);font-size:1rem;font-weight:600;color:var(--text)}
.pc p{font-size:.875rem;color:var(--muted)}
.pc .pw{font-size:.72rem;text-transform:uppercase;letter-spacing:.14em;color:var(--accent);margin-top:auto;padding-top:.75rem;font-weight:600}

/* Talent Solutions grid */
.ts-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-top:2rem}
.ts{padding:1.75rem;border-radius:var(--r-xl);background:var(--surface2);border:1px solid color-mix(in oklab,var(--text) 8%,transparent);box-shadow:var(--sh-sm);display:flex;flex-direction:column;gap:.5rem}
.ts-n{width:2.4rem;height:2.4rem;border-radius:50%;display:grid;place-items:center;font-family:var(--display);font-size:.95rem;background:var(--accent-soft);color:var(--accent);margin-bottom:.5rem;border:1px solid color-mix(in oklab,var(--accent) 25%,transparent);font-weight:600}
.ts h3{font-family:var(--body);font-size:1.05rem;font-weight:600;letter-spacing:-.01em;margin-bottom:.25rem;color:var(--text)}
.ts .ts-tag{font-size:.78rem;color:var(--primary);font-weight:600;margin-bottom:.5rem;font-style:italic}
.ts p{font-size:.875rem;color:var(--muted);line-height:1.6}

/* Team — 6 in one row on desktop */
.team-intro{display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(2rem,5vw,4rem);align-items:end;margin-bottom:3rem}
.team-intro h2{font-size:clamp(1.6rem,1.2rem + 1.5vw,2.5rem);margin-block:1rem 1.25rem;letter-spacing:-.025em;max-width:22ch;color:var(--text)}
.team-intro p{color:var(--muted);line-height:1.65;max-width:50ch}
.team-q{padding:1.75rem;border-left:3px solid var(--accent);background:var(--surface);border-radius:0 var(--r-xl) var(--r-xl) 0}
.team-q blockquote{font-family:var(--display);font-size:clamp(1.05rem,1rem + .4vw,1.25rem);line-height:1.45;color:var(--text)}
.team-q cite{display:block;margin-top:1rem;font-style:normal;font-size:.72rem;text-transform:uppercase;letter-spacing:.14em;color:var(--muted);font-weight:600}
.team-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem;margin-top:2rem}
.tm{background:var(--surface2);border:1px solid color-mix(in oklab,var(--text) 7%,transparent);border-radius:var(--r-xl);padding:1.5rem 1.25rem;display:flex;flex-direction:column;gap:.875rem;box-shadow:var(--sh-sm);transition:all var(--t);min-height:380px}
.tm:hover{box-shadow:var(--sh-md);transform:translateY(-2px)}
.tm-monogram{width:3.5rem;height:3.5rem;border-radius:50%;display:grid;place-items:center;font-family:var(--display);font-size:1.2rem;color:#fff;background:linear-gradient(135deg,var(--primary),color-mix(in oklab,var(--primary) 70%,var(--accent)));letter-spacing:-.03em;font-weight:500}
.tm h3{font-size:1.05rem;letter-spacing:-.01em;color:var(--text);font-family:var(--body);font-weight:600;line-height:1.2}
.tm .tm-role{font-size:.7rem;text-transform:uppercase;letter-spacing:.12em;color:var(--accent);font-weight:600}
.tm p{font-size:.85rem;color:var(--muted);line-height:1.55;flex:1}
.tm-ll{display:inline-flex;align-items:center;font-size:.7rem;text-transform:uppercase;letter-spacing:.12em;font-weight:600;color:var(--primary);transition:color var(--t);margin-top:auto;padding-top:.5rem;border-top:1px solid color-mix(in oklab,var(--text) 7%,transparent)}
.tm-ll:hover{color:var(--accent)}

/* Job postings */
.vtools{padding:1.5rem 0;border-bottom:1px solid color-mix(in oklab,var(--text) 7%,transparent);margin-bottom:2rem}
.vt-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr auto;gap:.75rem;align-items:center}
.vt-grid input,.vt-grid select{height:46px;padding:0 1rem;border-radius:var(--r-md);border:1px solid color-mix(in oklab,var(--text) 12%,transparent);background:var(--surface2);color:var(--text);font-size:.875rem;transition:border-color var(--t)}
.vt-grid input:focus,.vt-grid select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-soft)}
#vc{font-size:.875rem;color:var(--muted);white-space:nowrap;font-weight:500}
.vlist{display:grid;gap:1rem}
.vcard{display:grid;grid-template-columns:auto 1fr auto auto;gap:1.5rem;align-items:center;padding:1.5rem 1.75rem;border-radius:var(--r-xl);background:var(--surface2);border:1px solid color-mix(in oklab,var(--text) 8%,transparent);box-shadow:var(--sh-sm);transition:all var(--t);cursor:pointer;text-align:left;width:100%;color:var(--text)}
.vcard:hover{box-shadow:var(--sh-md);transform:translateY(-1px);border-color:var(--primary)}
.vref{width:3rem;height:3rem;border-radius:50%;background:var(--primary-soft);color:var(--primary);display:grid;place-items:center;font-family:var(--display);font-size:.875rem;font-weight:600}
.vmain h3{font-size:1.05rem;letter-spacing:-.01em;margin-bottom:.4rem;font-family:var(--body);font-weight:600}
.vmeta{display:flex;flex-wrap:wrap;gap:.6rem;font-size:.75rem;color:var(--muted)}
.vmeta span.dot{color:var(--faint)}
.vtag{display:inline-block;padding:.3rem .75rem;border-radius:var(--r-full);font-size:.7rem;text-transform:uppercase;letter-spacing:.12em;font-weight:700;white-space:nowrap;background:var(--primary-soft);color:var(--primary)}
.varr{color:var(--primary);font-weight:700}
.vempty{padding:2.5rem 1.75rem;text-align:center;border:1px dashed color-mix(in oklab,var(--text) 14%,transparent);border-radius:var(--r-xl);background:var(--surface)}
.vempty h3{font-size:1.25rem;margin-bottom:.75rem;color:var(--text)}
.vempty p{color:var(--muted);margin-bottom:1.25rem;max-width:40ch;margin-inline:auto}
.vdetail{display:none;background:var(--surface2);padding:2rem;border-radius:var(--r-2xl);border:1px solid color-mix(in oklab,var(--text) 8%,transparent);box-shadow:var(--sh-md);margin-bottom:2rem;scroll-margin-top:9rem}
.vdetail.is-open{display:block}
.vback{display:inline-flex;align-items:center;gap:.5rem;font-size:.875rem;color:var(--primary);margin-bottom:1.25rem;font-weight:600;cursor:pointer}
.vdetail h2{font-size:clamp(1.5rem,1.2rem + 1.1vw,2.25rem);letter-spacing:-.025em;margin-bottom:.75rem;color:var(--text)}
.vdetail .meta{display:flex;flex-wrap:wrap;gap:.75rem;margin-bottom:1.75rem;font-size:.875rem;color:var(--muted);align-items:center}
.vd-body{display:grid;grid-template-columns:1.4fr 1fr;gap:clamp(1.75rem,4vw,3rem)}
.vd-body h3{font-family:var(--body);font-size:1rem;font-weight:600;margin-block:1.25rem .75rem;color:var(--text)}
.vd-body h3:first-child{margin-top:0}
.vd-body p{font-size:.875rem;color:var(--muted);margin-bottom:.75rem;line-height:1.7}
.vd-body ul{display:grid;gap:.5rem}
.vd-body li{font-size:.875rem;color:var(--muted);padding-left:1rem;position:relative;line-height:1.6}
.vd-body li::before{content:"—";position:absolute;left:0;color:var(--primary);font-weight:600}

/* Forms */
.form{display:grid;gap:1rem}
.field label{display:block;font-size:.72rem;text-transform:uppercase;letter-spacing:.13em;color:var(--muted);margin-bottom:.5rem;font-weight:600}
.field input,.field textarea,.field select{width:100%;border-radius:var(--r-md);min-height:48px;border:1px solid color-mix(in oklab,var(--text) 12%,transparent);background:var(--surface);padding:.9rem 1rem;font-size:.9rem;color:var(--text);transition:border-color var(--t)}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-soft)}
.field textarea{min-height:110px;resize:vertical;font-family:inherit}
.fnote{font-size:.72rem;color:var(--muted);margin-top:.5rem;line-height:1.5}
.f-opt{font-size:.7rem;text-transform:none;letter-spacing:0;color:var(--faint);margin-left:4px;font-weight:400}
.field input[type="file"]{min-height:48px;padding:.8rem 1rem;cursor:pointer}
.field input[type="file"]::file-selector-button{margin-right:.75rem;padding:.45rem .9rem;border-radius:var(--r-full);border:1px solid color-mix(in oklab,var(--primary) 30%,transparent);background:var(--primary-soft);color:var(--primary);font-size:.7rem;font-weight:700;cursor:pointer;text-transform:uppercase;letter-spacing:.1em}
.divider-or{display:flex;align-items:center;gap:.75rem;margin:.25rem 0;color:var(--faint);font-size:.7rem;text-transform:uppercase;letter-spacing:.18em;font-weight:600}
.divider-or::before,.divider-or::after{content:"";flex:1;height:1px;background:var(--divider)}
.contact-c{padding:2rem;border-radius:var(--r-2xl);background:var(--surface2);border:1px solid color-mix(in oklab,var(--text) 8%,transparent);box-shadow:var(--sh-sm)}
.contact-c h3{font-family:var(--body);font-size:1.2rem;font-weight:600;color:var(--text)}
.contact-c .sub{margin-top:.75rem;color:var(--muted);font-size:.875rem;margin-bottom:1.5rem}
.csplit{display:grid;grid-template-columns:1fr 1.4fr;gap:clamp(1.75rem,5vw,3rem);align-items:start}
.cinfo{display:grid;gap:1.5rem;padding:.5rem}
.ci strong{display:block;font-size:.72rem;text-transform:uppercase;letter-spacing:.14em;color:var(--accent);margin-bottom:.5rem;font-weight:700}
.ci p,.ci a{font-size:.875rem;color:var(--muted);display:block;line-height:1.6}
.ci a:hover{color:var(--text)}

/* Final CTA */
.cta-w{position:relative;overflow:clip;border-radius:var(--r-2xl);box-shadow:var(--sh-xl)}
.cta-i{padding:clamp(2.5rem,6vw,4rem);background:linear-gradient(135deg,var(--primary) 0%,color-mix(in oklab,var(--primary) 75%,var(--accent)) 100%);color:#fff;display:grid;grid-template-columns:1.1fr .9fr;gap:2rem;align-items:center}
.cta-i h2{font-size:clamp(2rem,1.2rem + 2.5vw,3.4rem);font-weight:300;letter-spacing:-.035em;max-width:18ch}
.cta-i p{margin-top:1rem;color:rgba(255,255,255,.75);max-width:50ch}
.cta-act{margin-top:1.75rem;display:flex;flex-wrap:wrap;gap:.75rem}
.cta-bp{background:#fff;color:var(--primary)}
.cta-bp:hover{background:var(--surface3);color:var(--primary)}
.cta-bs{color:#fff;border-color:rgba(255,255,255,.25);background:transparent}
.cta-bs:hover{background:rgba(255,255,255,.1)}
.cta-list{display:grid;gap:1rem}
.cta-pt{padding-left:1.25rem;position:relative;color:rgba(255,255,255,.85);font-size:.875rem}
.cta-pt::before{content:"";position:absolute;left:0;top:.6em;width:.4rem;height:.4rem;border-radius:50%;background:var(--accent)}

/* HR Legal Partner — prominent */
.partner-band{padding-block:clamp(2.5rem,5vw,3.5rem);background:var(--surface2);border-top:1px solid color-mix(in oklab,var(--text) 7%,transparent);border-bottom:1px solid color-mix(in oklab,var(--text) 7%,transparent)}
.partner-in{display:grid;grid-template-columns:auto 1fr;gap:clamp(2rem,5vw,3rem);align-items:center}
.partner-meta{display:flex;flex-direction:column;gap:.5rem}
.partner-lbl{font-size:.7rem;text-transform:uppercase;letter-spacing:.18em;color:var(--accent);font-weight:700}
.partner-title{font-family:var(--display);font-size:clamp(1.4rem,1.2rem + .8vw,2rem);letter-spacing:-.02em;color:var(--text);line-height:1.2}
.partner-desc{color:var(--muted);font-size:.95rem;line-height:1.55;max-width:50ch;margin-top:.5rem}
.partner-logo-wrap{display:flex;justify-content:flex-end}
.partner-logo-wrap img{height:80px;width:auto}
@media (max-width:760px){
  .partner-in{grid-template-columns:1fr;gap:1.5rem;text-align:left}
  .partner-logo-wrap{justify-content:flex-start}
  .partner-logo-wrap img{height:60px}
}

/* Footer */
footer{background:var(--text);color:var(--inverse);padding-top:clamp(3rem,6vw,4rem)}
.f-top{display:grid;grid-template-columns:1.6fr 1fr 1fr;gap:clamp(2rem,4vw,3rem);padding-bottom:2.5rem;border-bottom:1px solid rgba(255,255,255,.1)}
.fb-img{background:#fff;padding:.75rem 1rem;border-radius:var(--r-md);display:inline-block;margin-bottom:1.25rem}
.fb-img img{height:42px}
.f-tag{font-size:.875rem;color:rgba(255,255,255,.65);line-height:1.7;max-width:38ch}
.f-cnt{margin-top:1.25rem;display:grid;gap:.75rem}
.f-cnt a,.f-cnt p{font-size:.875rem;color:rgba(255,255,255,.65);display:flex;gap:.75rem;align-items:flex-start}
.f-cnt a:hover{color:#fff}
.fci{flex:none;width:1.1rem;height:1.1rem;opacity:.55;margin-top:.15rem}
.f-col h4{font-family:var(--body);font-size:.72rem;text-transform:uppercase;letter-spacing:.18em;color:rgba(255,255,255,.45);margin-bottom:1.25rem;font-weight:700}
.f-col ul{display:grid;gap:.75rem}
.f-col a{font-size:.875rem;color:rgba(255,255,255,.65);transition:color var(--t);cursor:pointer}
.f-col a:hover{color:#fff}
.f-bot{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1rem;padding-block:1.25rem;font-size:.72rem;color:rgba(255,255,255,.35)}


/* Hide HR Legal Partner band on Job Postings, Seekers, Contact */
html[data-view="jobs"] .partner-band,
html[data-view="seekers"] .partner-band,
html[data-view="contact"] .partner-band{display:none}

/* Responsive */
@media (max-width:1100px){
  .hero-in,.advisory,.team-intro,.csplit,.cta-i,.vd-body,.dual{grid-template-columns:1fr}
  .sg,.pg,.ts-grid{grid-template-columns:repeat(2,1fr)}
  .team-grid{grid-template-columns:repeat(3,1fr)}
  .f-top{grid-template-columns:1fr 1fr}
  .sticky{position:static}
  .sd{grid-template-columns:1fr}
  .vt-grid{grid-template-columns:1fr 1fr}
}
@media (max-width:760px){
  .menu-btn{display:grid}
  nav.primary{position:absolute;left:0;right:0;top:100%;background:var(--bg);box-shadow:0 12px 32px rgba(19,25,58,.12);border-top:1px solid color-mix(in oklab,var(--text) 6%,transparent);border-bottom:1px solid color-mix(in oklab,var(--text) 8%,transparent);display:none;z-index:50}
  nav.primary.open{display:block}
  nav.primary ul{flex-direction:column;padding:1rem 1.5rem 1.5rem;gap:0;align-items:stretch}
  nav.primary li{border-bottom:1px solid color-mix(in oklab,var(--text) 5%,transparent)}
  nav.primary li:last-child{border-bottom:0}
  nav.primary a{display:block;padding:1rem 0}
  nav.primary a.is-active{color:var(--accent);font-weight:600}
  nav.primary a.is-active::after{display:none}
  .h-right .btn{display:none}
  .stats{grid-template-columns:1fr}
  .pg,.sg,.f-top,.ts-grid{grid-template-columns:1fr}
  .team-grid{grid-template-columns:1fr}
  .band-in{grid-template-columns:1fr;gap:1.25rem}
  .vt-grid{grid-template-columns:1fr}
  .vcard{grid-template-columns:1fr auto;gap:.75rem;padding:1.25rem;align-items:flex-start}
  .vref,.varr{display:none}
  .cta-i{padding:1.75rem 1.5rem}
  .f-bot{flex-direction:column;align-items:flex-start}
  .mcta{display:block!important;padding-top:.5rem;padding-bottom:.5rem;border-bottom:0!important}
  .mcta a.btn{padding:.875rem 1.5rem!important;margin-bottom:.5rem;display:flex!important}
  .mcta a.btn-accent{background:var(--accent)!important;color:#fff!important}
  .mcta a.btn-primary{background:var(--primary)!important;color:#fff!important}
}
.mcta{display:none}


/* ═══════════════════════════════════════════
   WORDPRESS — view fallback, prose, CF7, WP Job Manager, archive, etc.
═══════════════════════════════════════════ */

/* When viewing a WP page, each page renders its own .view via PHP — make it visible. */
.view.is-active,
body.singular .view,
body.archive .view,
body.search .view { display: block; }

/* Prose / content area for native WP pages */
.prose { max-width: 720px; margin-inline: auto; }
.prose h2 { font-family: var(--display); font-size: clamp(1.5rem,1.1rem + 1vw,2rem); font-weight: 400; letter-spacing: -.025em; margin-block: 2rem 1rem; }
.prose h3 { font-family: var(--display); font-size: 1.25rem; font-weight: 400; letter-spacing: -.02em; margin-block: 1.5rem .75rem; }
.prose p { margin-bottom: 1rem; color: var(--text); line-height: 1.75; }
.prose a { color: var(--primary); text-decoration: underline; text-underline-offset: 3px; }
.prose ul, .prose ol { margin: 1rem 0 1.25rem 1.5rem; }
.prose ul { list-style: disc; }
.prose ol { list-style: decimal; }
.prose li { margin-bottom: .5rem; }
.prose blockquote { margin: 1.5rem 0; padding: 1.25rem 1.5rem; border-left: 3px solid var(--primary); background: var(--surface2); border-radius: var(--r-md); font-family: var(--display); font-style: italic; }
.prose img { border-radius: var(--r-lg); margin: 1.5rem 0; }

/* ─── Contact Form 7 — match the .form/.field pattern ─── */
.wpcf7 .wpcf7-form { display: grid; gap: 1rem; }
.wpcf7 label { display: block; font-size: .72rem; text-transform: uppercase; letter-spacing: .13em; color: var(--muted); margin-bottom: .5rem; font-weight: 500; }
.wpcf7 input[type="text"],
.wpcf7 input[type="email"],
.wpcf7 input[type="tel"],
.wpcf7 input[type="url"],
.wpcf7 textarea,
.wpcf7 select,
.wpcf7-file {
  width: 100%; border-radius: var(--r-md); min-height: 48px;
  border: 1px solid color-mix(in oklab, var(--text) 12%, transparent);
  background: var(--surface); padding: .9rem 1rem; font-size: .875rem;
  transition: border-color var(--t), box-shadow var(--t);
  color: var(--text);
}
.wpcf7 input:focus, .wpcf7 textarea:focus, .wpcf7 select:focus {
  outline: none; border-color: var(--primary);
  box-shadow: 0 0 0 3px color-mix(in oklab, var(--primary) 18%, transparent);
}
.wpcf7 textarea { min-height: 130px; resize: vertical; }
.wpcf7 .wpcf7-submit { width: 100%; min-height: 56px; padding: 1rem 1.5rem; background: var(--primary); color: #fff; border: none; border-radius: var(--r-full); font-size: .875rem; font-weight: 600; cursor: pointer; transition: background var(--t), transform var(--t); }
.wpcf7 .wpcf7-submit:hover { background: var(--primary-h); transform: translateY(-1px); }
.wpcf7 .wpcf7-response-output { margin-top: 1rem; padding: 1rem 1.25rem; border-radius: var(--r-md); border: 1px solid var(--primary); background: color-mix(in oklab, var(--primary) 8%, var(--surface)); font-size: .875rem; }
.wpcf7-not-valid-tip { color: var(--accent, #d8232f); font-size: .8rem; margin-top: .35rem; }
.wpcf7-spinner { display: inline-block; vertical-align: middle; margin-left: .5rem; }

.wpcf7 .fnote, .wpcf7 .f-opt { font-size: .72rem; color: var(--faint); margin-top: .5rem; font-weight: 400; text-transform: none; letter-spacing: 0; }

/* ─── WP Job Manager — match the source HTML's vlist / vcard / vdetail look ─── */
.pr-job-board { display: grid; gap: 1rem; }
.pr-job-filters { background: var(--surface2); border: 1px solid var(--border); border-radius: var(--r-lg); padding: 1.25rem; margin-bottom: 1.5rem; }
.pr-job-filters form { display: grid; grid-template-columns: 1.5fr 1fr 1fr 1fr; gap: .75rem; align-items: end; }
.pr-job-filters label { display: block; font-size: .72rem; text-transform: uppercase; letter-spacing: .13em; color: var(--muted); margin-bottom: .35rem; }
.pr-job-filters input, .pr-job-filters select { width: 100%; min-height: 44px; border-radius: var(--r-md); border: 1px solid color-mix(in oklab, var(--text) 12%, transparent); background: var(--surface); padding: .65rem .9rem; font-size: .875rem; color: var(--text); }

.pr-job-list { display: grid; gap: .75rem; list-style: none; padding: 0; margin: 0; }
.pr-job-card {
  display: grid; grid-template-columns: auto 1fr auto auto; align-items: center;
  gap: 1rem; padding: 1.25rem 1.5rem;
  background: var(--surface2);
  border: 1px solid var(--border); border-radius: var(--r-xl);
  transition: all var(--t); text-decoration: none; color: inherit;
}
.pr-job-card:hover { box-shadow: var(--sh-md); transform: translateY(-2px); }
.pr-job-card .vref { font-family: var(--display); font-size: .95rem; font-weight: 400; color: var(--muted); letter-spacing: -.01em; min-width: 4.5rem; }
.pr-job-card h3 { font-family: var(--display); font-size: 1.125rem; font-weight: 400; letter-spacing: -.02em; margin: 0 0 .25rem; color: var(--text); }
.pr-job-card .vmeta { display: flex; gap: .5rem; font-size: .8rem; color: var(--muted); flex-wrap: wrap; }
.pr-job-card .vmeta span { white-space: nowrap; }
.pr-job-card .vtag { padding: .3rem .75rem; border-radius: var(--r-full); font-size: .72rem; text-transform: uppercase; letter-spacing: .12em; font-weight: 600; background: color-mix(in oklab, var(--primary) 14%, var(--surface)); color: var(--primary); }
.pr-job-card .varr { color: var(--muted); font-size: 1.25rem; }

.pr-job-single {
  background: var(--surface2); border: 1px solid var(--border);
  border-radius: var(--r-2xl); padding: 2rem 2.5rem;
  box-shadow: var(--sh-md);
}
.pr-job-single h1 { font-family: var(--display); font-size: clamp(1.75rem,1.2rem + 2vw,2.5rem); font-weight: 400; letter-spacing: -.035em; margin-bottom: .75rem; }
.pr-job-single .meta { display: flex; gap: .5rem; flex-wrap: wrap; color: var(--muted); font-size: .875rem; margin-bottom: 1.5rem; }
.pr-job-single .vd-body { display: grid; grid-template-columns: 1fr 1fr; gap: 2rem; margin-top: 1.5rem; }
.pr-job-single h3 { font-family: var(--body); font-size: .85rem; font-weight: 600; text-transform: uppercase; letter-spacing: .12em; color: var(--primary); margin-bottom: .75rem; }
.pr-job-single ul { display: grid; gap: .5rem; }
.pr-job-single ul li { padding-left: 1.25rem; position: relative; font-size: .9rem; color: var(--muted); line-height: 1.55; }
.pr-job-single ul li::before { content: ""; position: absolute; left: 0; top: .75em; width: .35rem; height: .35rem; border-radius: 50%; background: var(--primary); }
.pr-job-single .apply { margin-top: 2rem; padding-top: 1.5rem; border-top: 1px solid var(--divider); }

/* ─── Archive / blog / search ─── */
.page-hero {
  position: relative;
  padding-block: clamp(4rem, 8vw, 7rem) clamp(2rem, 4vw, 3rem);
  background: var(--surface2);
  border-bottom: 1px solid var(--divider);
}
.page-hero h1 { font-family: var(--display); font-size: clamp(2rem,1.2rem + 2vw,2.5rem); font-weight: 400; letter-spacing: -.035em; margin: 1rem 0 1rem; }
.page-hero .lead { color: var(--muted); font-size: 1.125rem; line-height: 1.55; max-width: 60ch; }

.posts-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.25rem; padding-block: clamp(3rem, 6vw, 5rem); }
.post-card { background: var(--surface2); border: 1px solid var(--border); border-radius: var(--r-xl); overflow: clip; transition: all var(--t); }
.post-card:hover { box-shadow: var(--sh-md); transform: translateY(-2px); }
.post-card-body { padding: 1.5rem; }
.post-card h2 { font-family: var(--display); font-size: 1.25rem; font-weight: 400; letter-spacing: -.02em; margin-bottom: .5rem; }
.post-card h2 a { color: var(--text); }
.post-card-meta { font-size: .72rem; text-transform: uppercase; letter-spacing: .14em; color: var(--muted); margin-bottom: .75rem; }
.post-card p { font-size: .875rem; color: var(--muted); }

.pagination { display: flex; flex-wrap: wrap; gap: .5rem; justify-content: center; margin-top: 3rem; }
.pagination .page-numbers { min-width: 2.5rem; padding: .6rem 1rem; border-radius: var(--r-full); background: var(--surface2); border: 1px solid var(--border); font-size: .875rem; color: var(--muted); text-align: center; transition: all var(--t); }
.pagination .page-numbers:hover, .pagination .page-numbers.current { background: var(--primary); color: #fff; border-color: var(--primary); }

/* 404 */
.error-page { padding-block: clamp(4rem, 10vw, 6rem); text-align: center; }
.error-page h1 { font-family: var(--display); font-size: clamp(2rem,1.4rem + 2vw,3rem); font-weight: 400; }
.error-page p { color: var(--muted); margin: 1rem 0 2rem; }

/* WordPress utility */
.screen-reader-text { border: 0; clip: rect(1px,1px,1px,1px); clip-path: inset(50%); height: 1px; width: 1px; overflow: hidden; position: absolute !important; word-wrap: normal !important; }
.alignwide { max-width: 1080px; margin-inline: auto; }
.alignfull { width: 100vw; margin-inline: calc(50% - 50vw); max-width: none; }

@media (max-width: 1140px) {
  .posts-grid { grid-template-columns: repeat(2, 1fr); }
  .pr-job-filters form { grid-template-columns: 1fr 1fr; }
  .pr-job-single .vd-body { grid-template-columns: 1fr; }
}
@media (max-width: 760px) {
  .posts-grid { grid-template-columns: 1fr; }
  .pr-job-filters form { grid-template-columns: 1fr; }
  .pr-job-card { grid-template-columns: 1fr; text-align: left; }
  .pr-job-card .varr { display: none; }
}
