/* ============================================================
   PERFORM RECRUITMENT — v2 Stylesheet
   Theme: Light Blue + Amber | Blue: #1B6CA8 | Amber: #F5A623
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap');
:root {
  --amber:#F5A623;--amber-dark:#C4841A;--amber-light:#FFF3DC;
  --blue:#2563EB;--blue-dark:#0A1628;--blue-mid:#1B2B4B;
  --blue-light:#EEF2FF;--blue-xlight:#F8F9FB;
  --black:#0D1B2E;--dark:#1A2E42;--mid:#4A5568;--muted:#718096;
  --light:#F8F9FB;--white:#FFFFFF;--border:#E2E8F0;--border-mid:#CBD5E0;
  --font:'Inter','Segoe UI',system-ui,Arial,sans-serif;
  --radius:10px;--radius-lg:16px;
  --shadow:0 4px 24px rgba(10,22,40,.12);--shadow-sm:0 2px 8px rgba(10,22,40,.08);
  --transition:.2s ease;--max-w:1160px;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--font);font-size:16px;color:var(--dark);line-height:1.7;background:var(--white)}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
ul{list-style:none}
.container{max-width:var(--max-w);margin:0 auto;padding:0 24px}

/* TYPOGRAPHY */
h1{font-size:clamp(2rem,4vw,3rem);font-weight:700;line-height:1.15;color:var(--black)}
h2{font-size:clamp(1.5rem,3vw,2.1rem);font-weight:700;line-height:1.2;color:var(--black)}
h3{font-size:clamp(1.1rem,2vw,1.35rem);font-weight:700;color:var(--black)}
h4{font-size:1.05rem;font-weight:700;color:var(--black)}
p{margin-bottom:1rem;color:var(--mid)}
p:last-child{margin-bottom:0}
.text-amber{color:var(--amber)}
.text-blue{color:var(--blue)}
.text-muted{color:var(--muted)}
.text-center{text-align:center}
.section-tag{display:inline-block;font-size:.72rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:#1B2B4B;background:#EEF2FF;border-radius:999px;padding:4px 14px;margin-bottom:14px}

/* BUTTONS */
.btn{display:inline-flex;align-items:center;gap:8px;padding:13px 28px;border-radius:var(--radius);font-size:.95rem;font-weight:600;cursor:pointer;border:2px solid transparent;transition:var(--transition);white-space:nowrap;font-family:var(--font)}
.btn-primary{background:var(--amber);color:var(--black);border-color:var(--amber)}
.btn-primary:hover{background:var(--amber-dark);border-color:var(--amber-dark)}
.btn-blue{background:var(--blue);color:var(--white);border-color:var(--blue)}
.btn-blue:hover{background:var(--blue-dark);border-color:var(--blue-dark)}
.btn-outline{background:transparent;color:var(--white);border-color:rgba(255,255,255,.6)}
.btn-outline:hover{background:rgba(255,255,255,.12);border-color:var(--white)}
.btn-outline-dark{background:transparent;color:var(--blue-dark);border-color:var(--border-mid)}
.btn-outline-dark:hover{border-color:var(--blue);color:var(--blue)}
.btn-sm{padding:9px 20px;font-size:.88rem}

/* NAV */
.nav{position:sticky;top:0;z-index:100;background:var(--white);border-bottom:1px solid var(--border);box-shadow:0 2px 12px rgba(10,22,40,.10)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:84px}
.nav-logo img{height:72px;width:auto}
.nav-links{display:flex;align-items:center;gap:2px}
.nav-links a{font-size:.87rem;font-weight:500;color:var(--mid);padding:7px 11px;border-radius:var(--radius);transition:var(--transition)}
.nav-links a:hover,.nav-links a.active{color:var(--blue);background:var(--blue-light)}
.nav-links .nav-cta{background:var(--amber);color:var(--black);font-weight:700;margin-left:8px;padding:9px 20px}
.nav-links .nav-cta:hover{background:var(--amber-dark)}
.nav-toggle{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:8px;background:none;border:none}
.nav-toggle span{display:block;width:24px;height:2px;background:var(--black);border-radius:2px;transition:var(--transition)}

/* HERO */
.hero{background:linear-gradient(135deg,#0A1628 0%,#1B2B4B 55%,#243860 100%);position:relative;overflow:hidden;padding:100px 0 84px}
.hero::before{content:'';position:absolute;top:-80px;right:-80px;width:420px;height:420px;border:70px solid rgba(255,255,255,.05);border-radius:50%}
.hero::after{content:'';position:absolute;bottom:-100px;left:-60px;width:280px;height:280px;border:40px solid rgba(245,166,35,.10);border-radius:50%}
.hero-left-bar{display:none;}
.hero-graphic{position:absolute;right:0;top:0;bottom:0;width:40%;background:rgba(255,255,255,.03);clip-path:polygon(18% 0,100% 0,100% 100%,0% 100%);pointer-events:none}
.hero-icons{position:absolute;right:60px;top:50%;transform:translateY(-50%);display:grid;grid-template-columns:1fr 1fr;gap:18px;pointer-events:none}
.hero-icon-box{width:96px;height:96px;background:rgba(255,255,255,.10);border:1px solid rgba(255,255,255,.15);border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;font-size:38px;backdrop-filter:blur(4px)}
.hero-inner{position:relative;z-index:1;max-width:640px}
.hero-tag{display:inline-block;font-size:.72rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--amber);background:rgba(245,166,35,.15);padding:5px 14px;border-radius:999px;margin-bottom:20px}
.hero h1{color:var(--white);margin-bottom:22px}
.hero h1 span{color:var(--amber)}
.hero p{color:rgba(255,255,255,.80);font-size:1.08rem;max-width:580px;margin-bottom:36px}
.hero-btns{display:flex;gap:14px;flex-wrap:wrap}
.feature-strip{display:flex;gap:0;flex-wrap:wrap;margin-top:52px;padding-top:40px;border-top:1px solid rgba(255,255,255,.14)}
.feature-strip-item{flex:1;min-width:180px;display:flex;align-items:center;gap:12px;padding:0 24px 0 0}
.feature-strip-icon{width:42px;height:42px;background:rgba(245,166,35,.18);border-radius:var(--radius);display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}
.feature-strip-text strong{display:block;color:var(--white);font-size:.92rem}
.feature-strip-text span{font-size:.78rem;color:rgba(255,255,255,.5)}

/* SECTIONS */
.section{padding:80px 0}
.section-sm{padding:56px 0}
.section-dark{background:#0A1628}
.section-dark h2,.section-dark h3,.section-dark h4{color:var(--white)}
.section-dark p{color:rgba(255,255,255,.70)}
.section-light{background:var(--light)}
.section-blue{background:var(--blue-light)}
.section-header{margin-bottom:52px}
.section-header.center{text-align:center}
.section-header p{font-size:1.05rem;max-width:600px}
.section-header.center p{margin-left:auto;margin-right:auto}

/* SECTOR CARDS */
.sector-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:20px}
.sector-card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius-lg);padding:32px 28px;transition:var(--transition);position:relative;overflow:hidden}
.sector-card::before{content:'';position:absolute;left:0;top:0;width:4px;height:100%;background:var(--blue);transform:scaleY(0);transform-origin:bottom;transition:transform .25s ease}
.sector-card:hover{border-color:var(--blue);box-shadow:var(--shadow);transform:translateY(-2px)}
.sector-card:hover::before{transform:scaleY(1)}
.sector-icon{width:52px;height:52px;background:var(--blue-light);border-radius:var(--radius);display:flex;align-items:center;justify-content:center;margin-bottom:20px;font-size:24px}
.sector-card h3{margin-bottom:10px}
.sector-card p{font-size:.9rem;margin-bottom:18px}
.sector-card a{font-size:.88rem;font-weight:600;color:var(--blue);display:inline-flex;align-items:center;gap:5px}
.sector-card a:hover{gap:8px;color:var(--blue-dark)}

/* CARDS */
.card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius-lg);padding:28px}
.card-grid-2{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:20px}
.card-grid-3{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:20px}

/* STEPS */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.step{text-align:center;padding:28px 20px;display:flex;flex-direction:column;align-items:center}
.step-num{width:52px;height:52px;background:var(--amber);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.1rem;font-weight:700;color:var(--black);margin:0 auto 20px;flex-shrink:0}
.step h4{margin-bottom:8px}
.step p{font-size:.88rem}

/* TESTIMONIALS */
.testimonial-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:24px}
.testimonial{background:var(--white);border:1px solid var(--border);border-radius:var(--radius-lg);padding:32px;position:relative}
.testimonial.candidate-story{background:var(--blue-xlight);border-color:var(--border)}
.testimonial::before{content:'\201C';font-size:5rem;line-height:1;color:var(--blue-light);position:absolute;top:12px;left:24px;font-family:Georgia,serif}
.testimonial blockquote{font-size:.98rem;color:var(--dark);font-style:italic;line-height:1.7;margin-bottom:20px;padding-top:20px}
.testimonial cite{font-size:.88rem;font-weight:700;color:var(--black);font-style:normal;display:flex;align-items:flex-start;gap:10px;flex-direction:column}
.cite-badge{display:inline-block;font-size:.72rem;font-weight:600;padding:2px 10px;border-radius:999px;background:var(--blue-light);color:var(--blue-dark)}
.cite-badge.candidate{background:var(--amber-light);color:var(--amber-dark)}
.cite-sub{font-weight:400;color:var(--muted);font-size:.82rem}

/* CTA BANNER */
.cta-banner{background:#0A1628;border-radius:var(--radius-lg);padding:56px 48px;display:grid;grid-template-columns:1fr auto 1fr;gap:0;position:relative;overflow:hidden}
.cta-banner::before{content:'';position:absolute;right:-60px;top:-60px;width:250px;height:250px;border:40px solid rgba(255,255,255,.05);border-radius:50%}
.cta-block h3{color:var(--white);margin-bottom:10px}
.cta-block p{color:rgba(255,255,255,.65);margin-bottom:22px;font-size:.95rem}
.cta-divider{width:1px;background:rgba(255,255,255,.15);margin:0 40px;align-self:stretch}

/* FORM */
.form-group{margin-bottom:18px}
.form-group label{display:block;font-size:.88rem;font-weight:600;color:var(--black);margin-bottom:6px}
.form-group input,.form-group select,.form-group textarea{width:100%;padding:12px 16px;border:1px solid var(--border);border-radius:var(--radius);font-size:.95rem;font-family:var(--font);color:var(--dark);background:var(--white);transition:border-color var(--transition);appearance:none}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px rgba(27,108,168,.12)}
.form-group textarea{resize:vertical;min-height:120px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.form-success{background:#EAF3DE;border:1px solid #97C459;border-radius:var(--radius);padding:16px 20px;color:#27500A;font-size:.95rem;display:none;margin-top:16px}
.dark-form input,.dark-form select,.dark-form textarea{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.15);color:var(--white)}
.dark-form input::placeholder,.dark-form textarea::placeholder{color:rgba(255,255,255,.35)}
.dark-form input:focus,.dark-form select:focus,.dark-form textarea:focus{border-color:var(--amber);box-shadow:0 0 0 3px rgba(245,166,35,.15);background:rgba(255,255,255,.12)}
.dark-form select option{background:var(--blue-dark);color:var(--white)}
.dark-form label{color:rgba(255,255,255,.80)!important}

/* CHECK LIST */
.check-list{list-style:none}
.check-list li{padding:8px 0;padding-left:28px;position:relative;font-size:.95rem;color:var(--mid);border-bottom:1px solid var(--border)}
.check-list li:last-child{border-bottom:none}
.check-list li::before{content:'';position:absolute;left:0;top:14px;width:14px;height:14px;background:var(--blue);border-radius:50%;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 12'%3E%3Cpath d='M2 6l3 3 5-5' stroke='%23fff' stroke-width='1.8' fill='none' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-size:10px;background-position:center;background-repeat:no-repeat}

/* PAGE HEADER */
.page-header{background:linear-gradient(135deg,#0A1628 0%,#1B2B4B 100%);padding:64px 0 56px;position:relative;overflow:hidden}
.page-header::before{content:'';position:absolute;right:-80px;top:-80px;width:320px;height:320px;border:50px solid rgba(255,255,255,.06);border-radius:50%}
.page-header::after{content:'';position:absolute;left:-40px;bottom:-40px;width:180px;height:180px;border:30px solid rgba(245,166,35,.10);border-radius:50%}
.page-header-bar{display:none;}
.page-header-inner{position:relative;z-index:1}
.page-header .breadcrumb{font-size:.82rem;color:rgba(255,255,255,.45);margin-bottom:14px}
.page-header .breadcrumb a{color:rgba(255,255,255,.45)}
.page-header .breadcrumb a:hover{color:var(--amber)}
.page-header .breadcrumb span{color:var(--amber)}
.page-header h1{color:var(--white);margin-bottom:14px}
.page-header p{color:rgba(255,255,255,.72);font-size:1.05rem;max-width:620px;margin:0}

/* BLOG */
.blog-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:24px}
.blog-card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;transition:var(--transition)}
.blog-card:hover{box-shadow:var(--shadow);border-color:var(--blue-mid);transform:translateY(-2px)}
.blog-card-img{background:linear-gradient(135deg,var(--blue-dark),var(--blue));height:180px;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}
.blog-card-img-inner{font-size:3.5rem;opacity:.5}
.blog-card-body{padding:24px}
.blog-card-meta{font-size:.78rem;color:var(--muted);margin-bottom:10px}
.blog-card-meta span{color:var(--blue);font-weight:600}
.blog-card h3{font-size:1.05rem;margin-bottom:10px}
.blog-card p{font-size:.88rem;margin-bottom:18px}
.blog-card a.read-more{font-size:.85rem;font-weight:600;color:var(--blue);display:inline-flex;align-items:center;gap:5px}

/* CONTACT */
.contact-offices{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.office-card{background:var(--blue-light);border:1px solid var(--border);border-radius:var(--radius-lg);padding:28px}
.office-card h4{margin-bottom:16px;display:flex;align-items:center;gap:8px}
.office-card p{font-size:.9rem;margin-bottom:6px}
.office-card a{color:var(--blue);font-weight:500}

/* ACCORDION */
.accordion{border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden}
.accordion-item{border-bottom:1px solid var(--border)}
.accordion-item:last-child{border-bottom:none}
.accordion-btn{width:100%;text-align:left;padding:20px 24px;background:none;border:none;cursor:pointer;font-size:.98rem;font-weight:600;color:var(--black);display:flex;justify-content:space-between;align-items:center;gap:12px;transition:background var(--transition);font-family:var(--font)}
.accordion-btn:hover{background:var(--blue-xlight)}
.accordion-btn.open{background:var(--blue-light);color:var(--blue-dark)}
.accordion-btn .chevron{width:20px;height:20px;flex-shrink:0;transition:transform .25s ease}
.accordion-btn.open .chevron{transform:rotate(180deg)}
.accordion-body{padding:0 24px;max-height:0;overflow:hidden;transition:max-height .35s ease,padding .25s ease}
.accordion-body.open{max-height:1200px;padding:20px 24px 28px}
.accordion-body p,.accordion-body li{font-size:.92rem}
.accordion-body ul{padding-left:20px;list-style:disc}
.accordion-body ul li{margin-bottom:6px;color:var(--mid)}

/* INFO BOXES */
.info-box{background:var(--blue-light);border-left:4px solid var(--blue);border-radius:0 var(--radius) var(--radius) 0;padding:20px 24px}
.amber-box{background:var(--amber-light);border-left:4px solid var(--amber);border-radius:0 var(--radius) var(--radius) 0;padding:20px 24px}

/* FOOTER */
.footer{background:#060E1C;color:rgba(255,255,255,.6);padding:64px 0 32px}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:40px;margin-bottom:48px}
.footer-logo{margin-bottom:16px}
.footer-logo img{height:60px;width:auto;opacity:1;border-radius:8px}
.footer-desc{font-size:.88rem;line-height:1.7;margin-bottom:20px}
.footer-socials{display:flex;gap:10px}
.footer-social{width:36px;height:36px;background:rgba(255,255,255,.08);border-radius:var(--radius);display:flex;align-items:center;justify-content:center;font-size:14px;transition:background var(--transition);color:rgba(255,255,255,.7);font-weight:700}
.footer-social:hover{background:var(--amber);color:var(--black)}
.footer-col h5{color:var(--white);font-size:.9rem;margin-bottom:16px;font-weight:700;letter-spacing:.04em}
.footer-col ul li{margin-bottom:8px}
.footer-col ul li a{font-size:.88rem;color:rgba(255,255,255,.55);transition:color var(--transition)}
.footer-col ul li a:hover{color:var(--amber)}
.footer-bottom{border-top:1px solid rgba(255,255,255,.08);padding-top:28px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px;font-size:.82rem}
.footer-bottom a{color:rgba(255,255,255,.4)}
.footer-bottom a:hover{color:var(--amber)}

/* RESPONSIVE */
@media(max-width:1000px){.hero-icons{display:none}.hero-graphic{display:none}.hero-inner{max-width:100%}}
@media(max-width:900px){.steps{grid-template-columns:repeat(2,1fr)}.cta-banner{grid-template-columns:1fr}.cta-divider{display:none}.footer-grid{grid-template-columns:1fr 1fr}.contact-offices{grid-template-columns:1fr}}
@media(max-width:640px){.steps{grid-template-columns:1fr}.nav-links{display:none;flex-direction:column;position:absolute;top:84px;left:0;right:0;background:var(--white);border-bottom:1px solid var(--border);padding:16px;gap:4px;box-shadow:var(--shadow)}.nav-links.open{display:flex}.nav-toggle{display:flex}.nav{position:relative}h1{font-size:1.8rem}h2{font-size:1.4rem}.hero{padding:56px 0 48px}.section{padding:56px 0}.footer-grid{grid-template-columns:1fr;gap:32px}.footer-bottom{flex-direction:column;text-align:center}.form-row{grid-template-columns:1fr}.cta-banner{padding:36px 24px}}

/* ── HERO LAYOUT (illustration split) ──────────────────── */
.hero-layout {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 48px;
  align-items: center;
}
.hero-visual {
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  z-index: 1;
}
.hero-svg {
  width: 100%;
  max-width: 500px;
  height: auto;
  filter: drop-shadow(0 8px 32px rgba(0,0,0,0.25));
}
/* Keep the old graphic/icons hidden now we have the SVG */
.hero-graphic, .hero-icons { display: none !important; }

/* ── FOOTER DESC VISIBILITY FIX ─────────────────────────── */
.footer-desc {
  color: rgba(255,255,255,0.85) !important;
  font-size: .9rem;
}

/* ── JOBS PAGE ───────────────────────────────────────────── */
.jobs-filter-bar {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 20px 24px;
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  align-items: center;
  margin-bottom: 28px;
  box-shadow: var(--shadow-sm);
}
.jobs-filter-bar select, .jobs-filter-bar input {
  padding: 9px 14px;
  border: 1px solid var(--border);
  border-radius: var(--radius);
  font-size: .9rem;
  font-family: var(--font);
  color: var(--dark);
  background: var(--white);
  flex: 1;
  min-width: 160px;
}
.jobs-filter-bar select:focus, .jobs-filter-bar input:focus {
  outline: none;
  border-color: var(--blue);
}
.jobs-filter-bar .btn { flex-shrink: 0; }
.job-listing {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 24px 28px;
  margin-bottom: 14px;
  transition: var(--transition);
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 16px;
  align-items: center;
}
.job-listing:hover { border-color: var(--blue); box-shadow: var(--shadow); transform: translateY(-1px); }
.job-listing-left {}
.job-listing-title { font-size: 1.05rem; font-weight: 700; color: var(--black); margin-bottom: 6px; }
.job-listing-meta { display: flex; gap: 14px; flex-wrap: wrap; font-size: .84rem; color: var(--muted); margin-bottom: 10px; }
.job-listing-meta span { display: flex; align-items: center; gap: 4px; }
.job-listing-desc { font-size: .9rem; color: var(--mid); line-height: 1.6; }
.job-listing-tags { display: flex; gap: 6px; flex-wrap: wrap; margin-top: 10px; }
.job-tag { display: inline-block; font-size: .75rem; font-weight: 600; padding: 3px 10px; border-radius: 999px; background: var(--blue-light); color: var(--blue-dark); }
.job-tag.amber { background: var(--amber-light); color: var(--amber-dark); }
.job-listing-right { text-align: right; flex-shrink: 0; }
.job-listing-apply { display: inline-block; padding: 10px 22px; background: var(--amber); color: var(--black); font-weight: 700; font-size: .88rem; border-radius: var(--radius); transition: var(--transition); }
.job-listing-apply:hover { background: var(--amber-dark); }
.job-listing-date { font-size: .78rem; color: var(--muted); margin-top: 8px; }
.jobs-empty { text-align: center; padding: 60px 20px; color: var(--muted); }
.jobs-empty h3 { color: var(--dark); margin-bottom: 8px; }
.jobs-count { font-size: .88rem; color: var(--muted); margin-bottom: 20px; }
.jobs-count span { font-weight: 600; color: var(--blue); }

/* ADMIN PANEL */
.admin-section { background: var(--blue-xlight); border: 1px solid var(--border); border-radius: var(--radius-lg); padding: 28px; margin-bottom: 24px; }
.admin-section h3 { margin-bottom: 18px; color: var(--blue-dark); }
.admin-badge { display: inline-block; background: var(--amber); color: var(--black); font-size: .72rem; font-weight: 700; padding: 3px 10px; border-radius: 999px; margin-left: 8px; vertical-align: middle; }

@media(max-width:900px) {
  .hero-layout { grid-template-columns: 1fr; }
  .hero-visual { display: none; }
  .job-listing { grid-template-columns: 1fr; }
  .job-listing-right { text-align: left; }
}

/* ── PROCESS STEPS — LEFT-ALIGNED ROW LAYOUT ────────────── */
.steps-list { display: flex; flex-direction: column; gap: 12px; }
.step-row {
  display: flex;
  align-items: flex-start;
  gap: 16px;
  padding: 18px 22px;
  background: var(--light);
  border-radius: var(--radius-lg);
  border-left: 3px solid var(--blue-light);
  transition: border-color var(--transition);
}
.step-row:hover { border-left-color: var(--amber); }
.step-row .step-num {
  flex-shrink: 0;
  width: 38px;
  height: 38px;
  font-size: 0.95rem;
  margin: 0;
  /* override default margin:auto from .step .step-num */
  align-self: flex-start;
}
.step-row .step-body { flex: 1; }
.step-row .step-body h4 { margin-bottom: 4px; font-size: 0.98rem; }
.step-row .step-body p { margin: 0; font-size: 0.90rem; color: var(--mid); line-height: 1.55; }

/* Homepage horizontal steps — keep circles in one line */
.steps-horizontal {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 24px;
}
.steps-horizontal .step { text-align: center; padding: 28px 16px; }
.steps-horizontal .step .step-num { margin: 0 auto 16px; }
@media(max-width:800px) {
  .steps-horizontal { grid-template-columns: 1fr 1fr; }
}
@media(max-width:480px) {
  .steps-horizontal { grid-template-columns: 1fr; }
}

/* ── HERO PHOTO ─────────────────────────────────────────── */
.hero-photo-wrap {
  position: relative;
  border-radius: var(--radius-lg);
  overflow: hidden;
  box-shadow: 0 24px 60px rgba(0,0,0,0.35);
}
.hero-photo {
  width: 100%;
  height: 440px;
  object-fit: cover;
  display: block;
  border-radius: var(--radius-lg);
}
.hero-photo-badge {
  position: absolute;
  bottom: 20px;
  left: 20px;
  background: rgba(255,255,255,0.96);
  border-radius: var(--radius-lg);
  padding: 12px 18px;
  display: flex;
  align-items: center;
  gap: 12px;
  box-shadow: 0 4px 20px rgba(0,0,0,0.15);
}
.hero-photo-badge-icon { font-size: 28px; }
.hero-photo-badge strong {
  display: block;
  font-size: 0.92rem;
  font-weight: 700;
  color: var(--black);
}
.hero-photo-badge span {
  display: block;
  font-size: 0.78rem;
  color: var(--muted);
}

/* ── CTA BANNER FIX ─────────────────────────────────────── */
.cta-icon{font-size:2rem;margin-bottom:14px;display:block}.cta-banner .cta-block{padding:8px 0}

/* ── CAREERS HEADER ─────────────────────────────────────── */
@media(max-width:768px){
  .careers-split{grid-template-columns:1fr !important;}
  .careers-split .careers-photo{display:none;}
}

/* ════════════════════════════════════════════════════════
   COMPREHENSIVE MOBILE FIXES
   ════════════════════════════════════════════════════════ */

/* All inline grid layouts on pages collapse at 768px */
@media(max-width: 768px) {

  /* Page sections using display:grid via inline style */
  [style*="grid-template-columns:3fr 2fr"],
  [style*="grid-template-columns: 3fr 2fr"] {
    display: block !important;
  }

  [style*="grid-template-columns:1fr 1fr"],
  [style*="grid-template-columns: 1fr 1fr"] {
    display: block !important;
  }

  [style*="grid-template-columns:2fr 1fr"],
  [style*="grid-template-columns: 2fr 1fr"] {
    display: block !important;
  }

  /* Sticky sidebars become normal on mobile */
  [style*="position:sticky"],
  [style*="position: sticky"] {
    position: relative !important;
    top: auto !important;
    margin-top: 32px;
  }

  /* Careers split header photo hidden on mobile — text only */
  header > div[style*="grid-template-columns:1fr 1fr"] {
    grid-template-columns: 1fr !important;
  }
  header > div > div:last-child img {
    display: none;
  }

  /* Steps horizontal — single column on small mobile */
  .steps-horizontal {
    grid-template-columns: 1fr !important;
  }

  /* About page full-width photo section text padding */
  [style*="padding:0 60px"] {
    padding: 0 24px !important;
  }

  /* CTA banner stack nicely */
  .cta-banner {
    grid-template-columns: 1fr !important;
    padding: 36px 24px !important;
  }
  .cta-divider { display: none !important; }

  /* Hero layout — single column, hide photo */
  .hero-layout {
    grid-template-columns: 1fr !important;
  }
  .hero-visual { display: none !important; }

  /* Jobs filter — stack filters vertically */
  .jobs-filter-bar {
    flex-direction: column;
    align-items: stretch;
  }
  .jobs-filter-bar select,
  .jobs-filter-bar input { min-width: unset; }

  /* Job listing — stack apply button below text */
  .job-listing {
    grid-template-columns: 1fr !important;
  }
  .job-listing-right {
    text-align: left;
  }
  .job-listing-apply { display: inline-block; }

  /* Form rows — single column */
  .form-row {
    grid-template-columns: 1fr !important;
  }

  /* Footer grid */
  .footer-grid {
    grid-template-columns: 1fr !important;
    gap: 28px !important;
  }

  /* Contact offices */
  .contact-offices {
    grid-template-columns: 1fr !important;
  }

  /* About page office photo section */
  .section[style*="padding:0"] [style*="height:420px"] {
    height: 280px !important;
  }
  .section[style*="padding:0"] [style*="padding:0 60px"] {
    padding: 20px 24px !important;
  }

  /* Accordion button text wrapping */
  .accordion-btn {
    font-size: 0.88rem !important;
    padding: 16px 18px !important;
  }

  /* Page headers */
  .page-header { padding: 40px 0 36px !important; }
  .page-header h1 { font-size: 1.7rem !important; }

  /* Hero section */
  .hero { padding: 52px 0 44px !important; }
  .hero h1 { font-size: 1.9rem !important; }
  .hero p { font-size: 0.97rem !important; }
  .hero-btns { flex-direction: column; gap: 10px; }
  .hero-btns .btn { width: 100%; justify-content: center; }

  /* Sector grid on mobile */
  .sector-grid {
    grid-template-columns: 1fr !important;
  }

  /* Card grids */
  .card-grid-2,
  .card-grid-3 {
    grid-template-columns: 1fr !important;
  }

  /* Inline style grid on RPO page */
  [style*="grid-template-columns:3fr 2fr"] > div,
  [style*="grid-template-columns: 3fr 2fr"] > div {
    width: 100%;
  }
}

/* Small phones 375px and under */
@media(max-width: 375px) {
  .container { padding: 0 16px; }
  h1 { font-size: 1.6rem !important; }
  h2 { font-size: 1.25rem !important; }
  .btn { padding: 12px 20px; font-size: 0.88rem; }
}

/* ── SECTOR ICON SVG ─────────────────────────────────────── */
.sector-icon svg { display: block; }
.sector-icon { width: 56px; height: 56px; }
.cta-icon svg { display: block; }

/* ── SECTOR CARD WITH PHOTO ─────────────────────────────── */
.sector-card-photo {
  width: 100%;
  height: 180px;
  overflow: hidden;
  border-radius: var(--radius) var(--radius) 0 0;
  margin: -32px -28px 20px -28px;
  width: calc(100% + 56px);
}
.sector-card-photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center 20%;
  display: block;
  transition: transform 0.4s ease;
}
.sector-card:hover .sector-card-photo img {
  transform: scale(1.04);
}

/* ── TESTIMONIAL MARQUEE ─────────────────────────────────── */
.testimonial-marquee-outer {
  overflow: hidden;
  width: 100%;
  padding: 16px 0 40px;
  position: relative;
}
/* fade edges */
.testimonial-marquee-outer::before,
.testimonial-marquee-outer::after {
  content: '';
  position: absolute;
  top: 0; bottom: 0;
  width: 80px;
  z-index: 2;
  pointer-events: none;
}
.testimonial-marquee-outer::before {
  left: 0;
  background: linear-gradient(to right, var(--white) 0%, transparent 100%);
}
.testimonial-marquee-outer::after {
  right: 0;
  background: linear-gradient(to left, var(--white) 0%, transparent 100%);
}
.testimonial-marquee-inner {
  display: flex;
  gap: 20px;
  width: max-content;
  animation: marquee-scroll 60s linear infinite;
}
.testimonial-marquee-inner:hover {
  animation-play-state: paused;
}
@keyframes marquee-scroll {
  0%   { transform: translateX(0); }
  100% { transform: translateX(-50%); }
}
.testimonial-card {
  flex: 0 0 340px;
  border-radius: var(--radius-lg);
  padding: 28px;
  display: flex;
  flex-direction: column;
  gap: 16px;
  border: 1px solid var(--border);
  background: var(--white);
  position: relative;
}
.testimonial-card.candidate {
  background: var(--blue-xlight);
  border-color: var(--blue-light);
}
.testimonial-card::before {
  content: '\201C';
  font-size: 4rem;
  line-height: 1;
  color: var(--blue-light);
  position: absolute;
  top: 10px; left: 20px;
  font-family: Georgia, serif;
  opacity: 0.6;
}
.t-quote {
  font-size: 0.92rem;
  color: var(--dark);
  font-style: italic;
  line-height: 1.65;
  padding-top: 24px;
  margin: 0;
}
.t-cite {
  display: flex;
  flex-direction: column;
  gap: 4px;
  margin-top: auto;
}
.t-cite strong {
  font-size: 0.9rem;
  font-weight: 700;
  color: var(--black);
}
.t-badge {
  display: inline-block;
  font-size: 0.72rem;
  font-weight: 700;
  padding: 2px 10px;
  border-radius: 999px;
  width: fit-content;
}
.badge-employer {
  background: var(--blue-light);
  color: var(--blue-dark);
}
.badge-candidate {
  background: var(--amber-light);
  color: var(--amber-dark);
}
.t-sub {
  font-size: 0.78rem;
  color: var(--muted);
}
