/* ===========================================================
   HumanRise — shared site styles
   Brand palette from HumanRise Colour Palette.pdf
   =========================================================== */
:root{
  --white:#FFFFFF;
  --lav:#8E8AAE;
  --purple:#7869BC;     /* primary */
  --slate:#6E86AE;
  --deep:#456285;
  --ink:#23222B;
  --deep700:#33485F;
  --lav050:#F7F6FB;
  --lav100:#E7E5F0;
  --lav200:#C6C4D6;
  --lav300:#AAA7C2;
  --sky:#F4F7FA;
  --line:#E2E1EA;
  --maxw:1240px;
  --gutter:120px;
  --rail:54px;
}
*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{margin:0;background:var(--white);color:var(--ink);
  font-family:'Roboto',system-ui,-apple-system,sans-serif;
  -webkit-font-smoothing:antialiased;line-height:1.6;}
.material-symbols-outlined{font-variation-settings:'FILL' 0,'wght' 400,'GRAD' 0,'opsz' 24;}
a{color:inherit;text-decoration:none;}
h1,h2,h3{margin:0;letter-spacing:-0.02em;text-wrap:balance;}
p{margin:0;}
img{display:block;max-width:100%;}

/* ---------- buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:8px;border:none;cursor:pointer;white-space:nowrap;
  font-family:'Roboto';font-weight:700;font-size:15px;letter-spacing:.03em;
  padding:15px 28px;border-radius:12px;transition:transform .15s ease,box-shadow .2s ease,background .2s ease;}
.btn:active{transform:scale(.97);}
.btn-primary{background:var(--purple);color:#fff;box-shadow:0 8px 22px rgba(120,105,188,.28);}
.btn-primary:hover{background:#6a5bb0;box-shadow:0 12px 28px rgba(120,105,188,.36);}
.btn-ghost{background:#fff;color:var(--deep);border:1.6px solid var(--slate);padding:13.4px 26px;}
.btn-ghost:hover{background:var(--lav050);}
.btn-light{background:#fff;color:var(--deep);}
.btn-light:hover{box-shadow:0 12px 28px rgba(0,0,0,.18);}
.btn-sm{padding:11px 20px;font-size:13.5px;border-radius:10px;}

/* ---------- top nav ---------- */
header.nav{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.9);
  backdrop-filter:blur(12px);border-bottom:1px solid var(--line);}
.nav-inner{max-width:var(--maxw);margin:0 auto;padding:14px 36px;
  display:flex;align-items:center;justify-content:space-between;gap:18px;}
.brand img{height:44px;width:auto;}
.nav-links{display:flex;align-items:center;gap:2px;}
.nav-links a{padding:9px 11px;border-radius:8px;font-size:14.5px;font-weight:500;
  color:var(--deep700);transition:background .15s,color .15s;white-space:nowrap;}
.nav-links a:hover{background:var(--lav050);color:var(--purple);}
.nav-links a.active{color:var(--purple);font-weight:700;}
.nav-links a.ext{display:inline-flex;align-items:center;gap:3px;}
.nav-links a.ext .material-symbols-outlined{font-size:15px;opacity:.7;}
.nav-cta{margin-left:4px;}
.hamburger{display:none;background:none;border:none;cursor:pointer;color:var(--deep);
  width:44px;height:44px;align-items:center;justify-content:center;}
.hamburger .material-symbols-outlined{font-size:30px;}

/* ---------- mobile menu ---------- */
.mobile-menu{display:none;}

/* ---------- shared layout ---------- */
.wrap{max-width:var(--maxw);margin:0 auto;padding-left:var(--gutter);padding-right:40px;}
.wrap-c{max-width:var(--maxw);margin:0 auto;padding:0 40px;}
.eyebrow{font-size:14px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--slate);}
section{position:relative;z-index:1;}
.ph{border-radius:18px;background:var(--sky);border:1px dashed var(--lav200);
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;
  color:var(--lav300);font-size:12.5px;letter-spacing:.14em;text-transform:uppercase;font-weight:600;min-height:300px;}
.ph .material-symbols-outlined{font-size:34px;}

/* ---------- home: rising trail ---------- */
.page{position:relative;overflow:hidden;}
.trail{position:absolute;left:calc(var(--rail) - 40px);top:170px;width:80px;height:calc(100% - 170px);
  z-index:0;pointer-events:none;}
.trail path{stroke:var(--lav200);stroke-width:2.4;fill:none;stroke-linecap:round;stroke-dasharray:2 9;}
.marker{position:absolute;left:calc(var(--rail) - 18px);width:38px;height:38px;border-radius:50%;
  background:#fff;border:2px solid var(--slate);display:flex;align-items:center;justify-content:center;
  font-size:13px;font-weight:800;color:var(--deep);z-index:2;}

/* ---------- home hero ---------- */
.hero{padding:54px 0 60px;}
.hero .lead{max-width:660px;}
.hero h1{font-size:78px;line-height:1.0;font-weight:800;margin:18px 0 22px;}
.hero h1 .accent{color:var(--purple);}
.hero-star{position:absolute;left:calc(var(--rail) - 58px);top:-4px;width:118px;height:118px;z-index:2;}
.hero p.sub{font-size:20px;line-height:1.6;color:var(--deep700);max-width:560px;margin-bottom:32px;}
.hero .actions{display:flex;flex-wrap:wrap;gap:14px;}
.hero .trust{display:flex;gap:30px;margin-top:38px;flex-wrap:wrap;}
.hero .trust .stat .n{font-size:34px;font-weight:800;color:var(--purple);line-height:1;}
.hero .trust .stat .l{font-size:14px;color:var(--deep700);margin-top:6px;}

/* ---------- home: 3 path boxes ---------- */
.paths{padding:30px 0 26px;}
.paths-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;}
.path{border-radius:20px;padding:32px 30px 28px;position:relative;overflow:hidden;
  border:1px solid var(--lav100);background:var(--lav050);display:flex;flex-direction:column;
  transition:transform .25s ease,box-shadow .25s ease;}
.path:hover{transform:translateY(-5px);box-shadow:0 16px 36px rgba(69,98,133,.13);}
.path .star-bg{position:absolute;right:-22px;top:-22px;width:128px;height:128px;opacity:.55;}
.path .ic{width:50px;height:50px;border-radius:13px;background:#fff;display:flex;align-items:center;
  justify-content:center;box-shadow:0 6px 16px rgba(69,98,133,.12);margin-bottom:16px;position:relative;}
.path .ic .material-symbols-outlined{font-size:26px;}
.path h3{font-size:23px;font-weight:800;margin-bottom:9px;position:relative;}
.path p{font-size:15.5px;color:var(--deep700);margin-bottom:18px;position:relative;flex:1;}
.path .go{font-size:14.5px;font-weight:700;display:inline-flex;align-items:center;gap:6px;position:relative;}
.path .go .material-symbols-outlined{font-size:18px;}
.path.biz .go{color:var(--deep);}
.path.jobs .go{color:var(--slate);}
.path.ind .go{color:var(--purple);}
.path.ind{background:linear-gradient(150deg,#fff,var(--lav050));}

/* ---------- section heading ---------- */
.sec-head{margin-bottom:34px;}
.sec-head h2{font-size:42px;font-weight:800;}
.sec-head p{font-size:18px;color:var(--deep700);margin-top:10px;max-width:560px;}
.sec-head.center{text-align:center;}
.sec-head.center p{margin-left:auto;margin-right:auto;}

/* ---------- services cards ---------- */
.services{padding:50px 0;}
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;}
.svc{background:var(--lav050);border:1px solid var(--lav100);border-radius:18px;padding:30px 28px;
  transition:transform .25s ease,box-shadow .25s ease;}
.svc:hover{transform:translateY(-5px);box-shadow:0 16px 36px rgba(69,98,133,.13);}
.svc .top{display:flex;align-items:center;gap:12px;margin-bottom:14px;}
.svc .top img{width:38px;height:38px;}
.svc .top .num{font-size:13px;font-weight:800;color:var(--lav300);}
.svc h3{font-size:21px;font-weight:700;margin-bottom:8px;}
.svc p{font-size:15.5px;color:var(--deep700);}
.svc a.more{display:inline-flex;align-items:center;gap:5px;margin-top:14px;font-size:14px;font-weight:700;color:var(--purple);}
.svc a.more .material-symbols-outlined{font-size:17px;}

/* ---------- proof ---------- */
.proof{padding:50px 0;}
.proof-grid{display:grid;grid-template-columns:1.05fr 0.95fr;gap:46px;align-items:center;}
.proof h2{font-size:36px;font-weight:800;margin-bottom:14px;}
.proof p{font-size:17px;color:var(--deep700);max-width:440px;margin-bottom:24px;}
.proof .nums{display:flex;gap:40px;}
.proof .nums .n{font-size:38px;font-weight:800;color:var(--purple);line-height:1;}
.proof .nums .l{font-size:14px;color:var(--deep700);margin-top:6px;}

/* ---------- CareerCat partner band ---------- */
.partner{padding:50px 0 60px;}
.partner-card{display:grid;grid-template-columns:1.1fr 0.9fr;gap:48px;align-items:center;
  background:linear-gradient(125deg,var(--deep),var(--slate));border-radius:26px;padding:50px 54px;
  color:#fff;position:relative;overflow:hidden;}
.partner-card .bg-star{position:absolute;right:30px;bottom:-46px;width:230px;height:230px;opacity:.16;}
.partner-card .inner{position:relative;}
.partner .kicker{display:inline-flex;align-items:center;gap:8px;background:rgba(255,255,255,.16);
  padding:7px 15px;border-radius:999px;font-size:12.5px;font-weight:700;letter-spacing:.1em;
  text-transform:uppercase;margin-bottom:16px;}
.partner h2{font-size:34px;font-weight:800;margin-bottom:14px;}
.partner p.body{font-size:17px;line-height:1.62;opacity:.94;max-width:440px;margin-bottom:22px;}
.partner .feats{display:flex;flex-wrap:wrap;gap:10px 20px;margin-bottom:26px;}
.partner .feat{display:flex;align-items:center;gap:8px;font-size:14.5px;font-weight:500;opacity:.95;}
.partner .feat .material-symbols-outlined{font-size:20px;}
.cat-preview{background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.18);border-radius:18px;
  min-height:240px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;
  color:rgba(255,255,255,.85);}
.cat-preview .material-symbols-outlined{font-size:40px;}
.cat-preview .pill{font-size:12px;letter-spacing:.14em;text-transform:uppercase;font-weight:600;opacity:.8;}

/* ---------- inner-page hero ---------- */
.page-hero{background:var(--lav050);border-bottom:1px solid var(--lav100);padding:60px 0 56px;position:relative;overflow:hidden;}
.page-hero .bg-star{position:absolute;right:-30px;top:-40px;width:260px;height:260px;opacity:.5;pointer-events:none;}
.page-hero .crumb{font-size:13px;font-weight:600;letter-spacing:.04em;color:var(--lav300);margin-bottom:14px;}
.page-hero .crumb a:hover{color:var(--purple);}
.page-hero h1{font-size:54px;line-height:1.05;font-weight:800;max-width:780px;margin-bottom:16px;}
.page-hero h1 .accent{color:var(--purple);}
.page-hero p{font-size:19px;color:var(--deep700);max-width:620px;}
.page-hero .actions{display:flex;flex-wrap:wrap;gap:14px;margin-top:26px;}

/* generic section spacing for inner pages */
.block{padding:62px 0;}
.block.alt{background:var(--lav050);}
.lede{font-size:20px;line-height:1.7;color:var(--deep700);max-width:760px;}

/* feature list (two-col text) */
.feature-row{display:grid;grid-template-columns:1fr 1fr;gap:50px;align-items:center;}
.feature-row.rev .txt{order:2;}
.feature-row h2{font-size:34px;font-weight:800;margin-bottom:14px;}
.feature-row p{font-size:16.5px;color:var(--deep700);margin-bottom:14px;}
.ul-check{list-style:none;padding:0;margin:10px 0 0;}
.ul-check li{display:flex;gap:10px;align-items:flex-start;font-size:16px;color:var(--deep700);margin-bottom:12px;}
.ul-check li .material-symbols-outlined{color:var(--purple);font-size:22px;flex:none;}

/* iframe wrapper for Placement Partner */
.pp-frame-wrap{background:#fff;border:1px solid var(--lav100);border-radius:18px;overflow:hidden;
  box-shadow:0 10px 30px rgba(69,98,133,.08);}
.pp-frame-wrap iframe{display:block;width:100%;border:0;min-height:900px;}
.pp-note{display:flex;gap:12px;align-items:flex-start;background:var(--sky);border:1px solid var(--lav100);
  border-radius:14px;padding:16px 18px;font-size:14px;color:var(--deep700);margin-bottom:26px;}
.pp-note .material-symbols-outlined{color:var(--slate);font-size:22px;flex:none;}
.pp-note code{background:#fff;border:1px solid var(--lav100);border-radius:6px;padding:1px 6px;font-size:12.5px;color:var(--deep);}

/* steps */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;}
.step{background:#fff;border:1px solid var(--lav100);border-radius:16px;padding:26px 26px;}
.step .n{width:38px;height:38px;border-radius:50%;background:var(--purple);color:#fff;display:flex;
  align-items:center;justify-content:center;font-weight:800;font-size:15px;margin-bottom:14px;}
.step h3{font-size:19px;font-weight:700;margin-bottom:7px;}
.step p{font-size:15px;color:var(--deep700);}

/* contact form */
.contact-grid{display:grid;grid-template-columns:0.9fr 1.1fr;gap:50px;align-items:start;}
.field{margin-bottom:18px;}
.field label{display:block;font-size:13.5px;font-weight:600;color:var(--deep);margin-bottom:7px;letter-spacing:.01em;}
.field input,.field textarea,.field select{width:100%;font-family:'Roboto';font-size:15px;color:var(--ink);
  padding:13px 15px;border:1.5px solid var(--lav200);border-radius:11px;background:#fff;transition:border .15s,box-shadow .15s;}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--purple);box-shadow:0 0 0 3px rgba(120,105,188,.15);}
.field textarea{min-height:130px;resize:vertical;}
.contact-info .row{display:flex;gap:14px;align-items:flex-start;margin-bottom:22px;}
.contact-info .row .ic{width:46px;height:46px;border-radius:12px;background:var(--lav050);border:1px solid var(--lav100);
  display:flex;align-items:center;justify-content:center;color:var(--purple);flex:none;}
.contact-info .row h4{font-size:16px;font-weight:700;margin-bottom:3px;}
.contact-info .row p{font-size:15px;color:var(--deep700);}

/* CTA band */
.cta-band{background:var(--purple);color:#fff;border-radius:26px;padding:50px 54px;text-align:center;position:relative;overflow:hidden;}
.cta-band .bg-star{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:420px;height:420px;opacity:.12;}
.cta-band h2{font-size:38px;font-weight:800;margin-bottom:12px;position:relative;}
.cta-band p{font-size:18px;opacity:.92;max-width:540px;margin:0 auto 26px;position:relative;}
.cta-band .actions{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;position:relative;}

/* ---------- footer ---------- */
footer.site{background:var(--ink);color:#fff;padding:56px 0 36px;position:relative;z-index:1;}
.foot-grid{max-width:var(--maxw);margin:0 auto;padding:0 40px;
  display:flex;justify-content:space-between;gap:40px;flex-wrap:wrap;margin-bottom:40px;}
.foot-brand{max-width:320px;}
.foot-brand img{height:64px;margin-bottom:16px;}
.foot-brand p{color:rgba(255,255,255,.6);font-size:14.5px;}
.foot-cols{display:flex;gap:60px;flex-wrap:wrap;}
.foot-cols .col h4{font-size:13px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--lav300);margin-bottom:14px;}
.foot-cols .col a{display:block;font-size:15px;color:rgba(255,255,255,.78);margin-bottom:11px;}
.foot-cols .col a:hover{color:#fff;}
.foot-cols .col a .material-symbols-outlined{font-size:15px;vertical-align:-2px;opacity:.6;}
.foot-bottom{max-width:var(--maxw);margin:0 auto;padding:22px 40px 0;border-top:1px solid rgba(255,255,255,.12);
  font-size:13px;color:rgba(255,255,255,.5);display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;}

/* ---------- responsive ---------- */
@media (max-width:1180px){
  :root{--gutter:64px;}
  .hero h1{font-size:64px;}
  .nav-links a{padding:9px 9px;font-size:14px;}
}
@media (max-width:1040px){
  .paths-grid{grid-template-columns:1fr;}
  .nav-links{display:none;}
  .hamburger{display:inline-flex;}
}
@media (max-width:860px){
  :root{--gutter:24px;}
  .trail,.marker,.hero-star{display:none;}
  .nav-inner{padding:12px 20px;}
  .wrap{padding-right:24px;}
  .hero{padding:38px 0 46px;}
  .hero h1{font-size:44px;}
  .hero p.sub{font-size:18px;}
  .svc-grid,.proof-grid,.partner-card,.feature-row,.steps,.contact-grid{grid-template-columns:1fr;}
  .feature-row.rev .txt{order:0;}
  .partner-card{padding:38px 28px;}
  .partner-card .bg-star{display:none;}
  .page-hero h1{font-size:38px;}
  .sec-head h2{font-size:30px;}
  .cta-band{padding:40px 26px;}
  .cta-band h2{font-size:30px;}
  .block{padding:46px 0;}
}
.mobile-menu.open{display:block;position:fixed;inset:0;z-index:60;background:rgba(35,34,43,.4);}
.mobile-menu .sheet{position:absolute;top:0;right:0;width:80%;max-width:330px;height:100%;
  background:#fff;padding:22px 20px;display:flex;flex-direction:column;gap:2px;overflow-y:auto;
  box-shadow:-10px 0 40px rgba(0,0,0,.2);}
.mobile-menu .sheet .close{align-self:flex-end;background:none;border:none;cursor:pointer;color:var(--deep);width:44px;height:44px;}
.mobile-menu .sheet .close .material-symbols-outlined{font-size:28px;}
.mobile-menu .sheet a{padding:13px 12px;border-radius:10px;font-size:16.5px;font-weight:600;color:var(--deep700);}
.mobile-menu .sheet a.active{color:var(--purple);background:var(--lav050);}
.mobile-menu .sheet a.ext .material-symbols-outlined{font-size:18px;vertical-align:-3px;opacity:.7;}

/* ---------- core service tiles ---------- */
.tiles{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;}
.tile{border-radius:18px;padding:26px 24px;color:#fff;min-height:200px;display:flex;flex-direction:column;
  justify-content:flex-end;position:relative;overflow:hidden;transition:transform .25s ease,box-shadow .25s ease;}
.tile:hover{transform:translateY(-5px);box-shadow:0 18px 38px rgba(69,98,133,.22);}
.tile .ti{position:absolute;top:22px;left:24px;}
.tile .ti .material-symbols-outlined{font-size:38px;opacity:.92;}
.tile h3{font-size:19px;font-weight:800;letter-spacing:.01em;line-height:1.15;margin-bottom:8px;}
.tile p{font-size:14px;line-height:1.5;opacity:.95;}
.tile.t-recruit{background:var(--purple);}
.tile.t-psych{background:var(--deep);}
.tile.t-skills{background:var(--slate);}
.tile.t-culture{background:var(--lav);}

/* ---------- training courses ---------- */
.courses-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;}
.course{background:#fff;border:1px solid var(--lav100);border-radius:18px;padding:28px 26px;display:flex;
  flex-direction:column;transition:transform .25s ease,box-shadow .25s ease;}
.course:hover{transform:translateY(-5px);box-shadow:0 16px 36px rgba(69,98,133,.13);}
.course .badge{display:inline-flex;align-items:center;gap:6px;align-self:flex-start;background:var(--lav050);
  border:1px solid var(--lav100);color:var(--purple);font-size:11px;font-weight:700;letter-spacing:.06em;
  text-transform:uppercase;padding:5px 11px;border-radius:999px;margin-bottom:14px;}
.course .badge .material-symbols-outlined{font-size:14px;}
.course h3{font-size:19px;font-weight:800;margin-bottom:9px;}
.course p{font-size:14.5px;color:var(--deep700);margin-bottom:14px;flex:1;}
.course .for{font-size:13px;color:var(--slate);font-weight:600;border-top:1px solid var(--lav100);padding-top:12px;}
.register-line{display:flex;flex-wrap:wrap;align-items:center;gap:14px;justify-content:center;text-align:center;
  background:var(--lav050);border:1px solid var(--lav100);border-radius:16px;padding:22px 26px;margin-top:30px;}
.register-line .material-symbols-outlined{color:var(--purple);vertical-align:-5px;margin-right:4px;}
.register-line a{color:var(--purple);font-weight:700;}

/* ---------- socials ---------- */
.socials{display:flex;gap:10px;margin-top:18px;}
.socials a{width:40px;height:40px;border-radius:11px;background:rgba(255,255,255,.1);display:flex;
  align-items:center;justify-content:center;color:#fff;transition:background .15s ease,transform .15s ease;}
.socials a:hover{background:var(--purple);transform:translateY(-2px);}
.socials a svg{width:20px;height:20px;fill:currentColor;display:block;}
.socials.light a{background:var(--lav050);border:1px solid var(--lav100);color:var(--purple);}
.socials.light a:hover{background:var(--purple);color:#fff;}

@media (max-width:980px){.tiles{grid-template-columns:1fr 1fr;}}
@media (max-width:860px){.courses-grid{grid-template-columns:1fr;}.tiles{grid-template-columns:1fr 1fr;}}

/* ---------- real imagery ---------- */
.media-img{width:100%;height:360px;object-fit:cover;border-radius:18px;display:block;
  box-shadow:0 16px 38px rgba(69,98,133,.16);}
.cat-logo-card{background:#fff;border-radius:18px;min-height:240px;display:flex;align-items:center;
  justify-content:center;padding:32px;box-shadow:0 12px 30px rgba(0,0,0,.12);}
.cat-logo-card img{max-width:78%;max-height:180px;object-fit:contain;display:block;}
@media (max-width:860px){.media-img{height:260px;}}
