/* ============================================================
   Mansons Job Portal v4.0 — Brand Stylesheet
   Yellow #FFD800 | Red #E30613 | Dark #1A1A1A
   Fonts: Barlow Condensed (headings) | Barlow (body)
============================================================ */

/* ── Variables ── */
:root {
  --mj-y:    #FFD800;
  --mj-r:    #E30613;
  --mj-r1:   #000000;
  --mj-dk:   #1A1A1A;
  --mj-dks:  #2D2D2D;
  --mj-gy:   #000000;
  --mj-gyl:  #000;
  --mj-bd:   #DDDDD5;
  --mj-bg:   #ECEADE;
  --mj-wh:   #FFFFFF;
  --mj-card: #FFFFFF;
  --mj-sh:   0 2px 10px rgba(0,0,0,.08);
  --mj-shh:  0 6px 20px rgba(0,0,0,.14);
  --mj-br:   8px;
  --mj-fh:   'Saira', sans-serif;
  --mj-fb:   'Roboto';
}

/* ═══════════════════════════════════════════════════════
   HERO — shared by listing page AND single job page
═══════════════════════════════════════════════════════ */

.mj-hero {
  width: 100%;
  background-color: var(--mj-y);          /* fallback if image fails */
  background-size: cover;
  background-position: left center;
  background-repeat: no-repeat;
  text-transform: uppercase;
  padding: 52px 263px 44px;
  border-bottom: 4px solid var(--mj-r);
  box-sizing: border-box;
  margin-top: -40px;
}

.mj-hero-in {
  max-width: 100%;
  margin: 0 auto;
  padding: 0 40px;
  box-sizing: border-box;
}

/* Breadcrumb */
.mj-bc {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 6px;
  font-size: 13px;
  color: var(--mj-dks);
  margin-bottom: 20px;
}
.mj-bc a {
  color: var(--mj-dk);
  font-weight: 500;
  text-decoration: none;
}
.mj-bc a:hover { text-decoration: underline; }

/* Eyebrow */
.mj-eyebrow {
  font-family: var(--mj-fh);
  font-size: 13px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 2.5px;
  color: var(--mj-r);
  margin: 0 0 2px;
}

/* Hero title */
.mj-hero-title {
  font-family: var(--mj-fh) !important;
  font-size: clamp(30px, 5vw, 58px) !important;
  font-weight: 800 !important;
  color: var(--mj-dk) !important;
  margin: 0 0 -14px !important;
  line-height: 1.05 !important;
  text-decoration: none !important;
  border-bottom: none !important;
  box-shadow: none !important;
}
.mj-hero-title::before,
.mj-hero-title::after { display: none !important; content: none !important; }

/* Red accent bar */
.mj-rbar {
  border-radius: 2px;
  margin-bottom: 10px;
}
.mj-rbar-sm { margin-bottom: 16px; }

/* Hero blockquote (listing page subtitle) */
.mj-hero-desc {
  border-left: 3px solid var(--mj-r);
  margin: 20px 0 0;
  padding: 4px 0 4px 16px;
  font-family: var(--mj-fb);
  font-size: 15px;
  line-height: 1.65;
  color: var(--mj-dks);
  max-width: 560px;
}

/* Hero meta (single job) */
.mj-hero-meta {
  display: flex;
  align-items: center;
  gap: 20px;
  flex-wrap: wrap;
  margin-bottom: 28px;
}

/* Hero buttons */
.mj-hero-actions { display: flex; align-items: center; gap: 10px; }

/* ─── APPLY NOW button ─── */
.mj-btn-apply {
  display: inline-block;
  padding: 11px 28px;
  background: var(--mj-dk) !important;
  color: var(--mj-wh) !important;
  border: 2px solid var(--mj-dk) !important;
  border-radius: var(--mj-br);
  font-family: var(--mj-fh);
  font-size: 14px;
  font-weight: 700;
  letter-spacing: 1px;
  text-transform: uppercase;
  text-decoration: none !important;
  cursor: pointer;
  transition: background .18s, border-color .18s;
  white-space: nowrap;
}
.mj-btn-apply:hover,
a.mj-btn-apply:hover {
  background: var(--mj-r) !important;
  border-color: var(--mj-r) !important;
  color: var(--mj-wh) !important;
}

/* Bookmark on hero */
.mj-bm-hero {
  width: 40px; height: 40px;
  border: 1px solid rgba(26,26,26,.3);
  border-radius: var(--mj-br);
  background: rgba(255,255,255,.45);
  cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  color: var(--mj-dk); padding: 0;
  transition: background .2s, border-color .2s;
  flex-shrink: 0;
}
.mj-bm-hero:hover {
  background: rgba(255,255,255,.9) !important;
  border-color: var(--mj-dk) !important;
}
.mj-bm-hero svg { width: 16px; height: 16px; }

/* ═══════════════════════════════════════════════════════
   LISTING PAGE BODY
═══════════════════════════════════════════════════════ */

.mj-listing-body { background: var(--mj-bg); }

.mj-listing-in {
  margin: 0 auto;
  padding: 40px 24px 64px;
  box-sizing: border-box;
}

/* ─── Filter bar ─── */
.mj-filter-wrap {
  background: var(--mj-wh);
  border: 1px solid var(--mj-bd);
  border-radius: var(--mj-br);
  padding: 14px 18px;
  margin-bottom: 20px;
  box-shadow: var(--mj-sh);
}
.mj-filter-form {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}
.mj-search-field {
  position: relative;
  flex: 1;
  min-width: 180px;
}
.mj-search-field svg {
  position: absolute; left: 293px; top: 50%;
  transform: translateY(-50%);
  width: 14px; height: 14px;
  color: var(--mj-gyl); pointer-events: none;
}
.mj-search-input {
  width: 100%;
  padding: 9px 12px 9px 32px;
  border: 1px solid var(--mj-bd);
  border-radius: var(--mj-br);
  font-family: var(--mj-fb);
  font-size: 14px;
  color: var(--mj-dk);
  background: #FAFAF8;
  box-sizing: border-box;
  transition: border-color .2s;
  -webkit-appearance: none;
}
.mj-search-input:focus { outline: none; border-color: var(--mj-dk); }
.mj-sel-wrap { position: relative; min-width: 170px; }
.mj-dept-select {
  -webkit-appearance: none; appearance: none;
  width: 100%;
  padding: 9px 28px 9px 12px;
  border: 1px solid var(--mj-bd);
  border-radius: var(--mj-br);
  font-family: var(--mj-fb);
  font-size: 14px;
  color: var(--mj-dk);
  background: #FAFAF8;
  cursor: pointer; transition: border-color .2s;
}
.mj-dept-select:focus { outline: none; border-color: var(--mj-dk); }
.mj-sel-arr {
  position: absolute; right: 9px; top: 50%;
  transform: translateY(-50%);
  font-size: 11px; color: var(--mj-gy); pointer-events: none;
}

/* ─── SEARCH button ─── */
.mj-btn-search {
  padding: 9px 22px;
  background: var(--mj-dk);
  color: var(--mj-wh) !important;
  border: 2px solid var(--mj-dk);
  border-radius: var(--mj-br);
  font-family: var(--mj-fh);
  font-size: 14px; font-weight: 700;
  letter-spacing: .8px; text-transform: uppercase;
  cursor: pointer;
  transition: background .18s, border-color .18s;
  white-space: nowrap;
}
.mj-btn-search:hover {
  background: var(--mj-r) !important;
  border-color: var(--mj-r) !important;
  color: var(--mj-wh) !important;
}
.mj-btn-clear {
  font-size: 13px; color: var(--mj-gy);
  text-decoration: none; white-space: nowrap;
  transition: color .2s;
}
.mj-btn-clear:hover { color: var(--mj-r); }

/* Count */
.mj-count { font-size: 14px; color: var(--mj-gy); margin: 0 0 18px; }

/* ─── Job Cards ─── */
.mj-card-list { display: flex; flex-direction: column; gap: 14px; }
.mj-list-wrap { width: 100%; }

.mj-card {
  background: var(--mj-card);
  border: 1px solid var(--mj-bd);
  border-radius: var(--mj-br);
  padding: 22px 24px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
  box-shadow: var(--mj-sh);
  transition: box-shadow .2s, border-color .2s;
}
.mj-card:hover { box-shadow: var(--mj-shh); border-color: #C0C0B4; }
.mj-card-left { flex: 1; min-width: 0; }

/* Department badge */
.mj-dept-tag {
  display: inline-block;
  font-family: var(--mj-fh);
  font-size: 11px; font-weight: 700; letter-spacing: .8px;
  background: #D6EAF8; color: #1A5276;
  padding: 3px 10px; border-radius: 20px;
  margin-bottom: 10px;
}

/* Card title — uppercase, no extra underlines */
.mj-card-title {
  font-family: var(--mj-fh) !important;
  font-size: 19px !important;
  font-weight: 700 !important;
  color: var(--mj-dk) !important;
  margin: 0 0 4px !important;
  line-height: 1.2 !important;
  text-decoration: none !important;
  border-bottom: none !important;
  box-shadow: none !important;
}
.mj-card-title::before, .mj-card-title::after { display: none !important; }
.mj-card-title a { color: inherit !important; text-decoration: none !important; }
.mj-card-title a:hover { color: var(--mj-r1) !important; text-decoration: none !important; }

/* Red dash — single, under title */
.mj-reddash {
/*  width: 40px; height: 3px;*/
 /* background: var(--mj-r); border-radius: 2px;*/
 margin: 8px 0 12px;
}

/* Meta row */
.mj-meta-row { display: flex; align-items: center; gap: 16px; flex-wrap: wrap; }
.mj-meta-item {
  display: flex; align-items: center; gap: 4px;
  font-size: 15px; color: var(--mj-gy);
  font-family: var(--mj-fb);
}
.mj-meta-item svg { width: 13px; height: 13px; flex-shrink: 0; }

/* Card action area */
.mj-card-right { display: flex; align-items: center; gap: 8px; flex-shrink: 0; }

/* ─── VIEW & APPLY button ─── */
.mj-btn-view {
  display: inline-block;
  padding: 9px 18px;
  border: 2px solid var(--mj-dk);
  border-radius: var(--mj-br);
  color: var(--mj-dk) !important;
  font-family: var(--mj-fh);
  font-size: 13px; font-weight: 700;
  letter-spacing: .8px; text-transform: uppercase;
  text-decoration: none !important;
  background: transparent;
  cursor: pointer;
  transition: background .18s, color .18s, border-color .18s;
  white-space: nowrap;
}
.mj-btn-view:hover,
a.mj-btn-view:hover {
  background: var(--mj-r) !important;
  border-color: var(--mj-r) !important;
  color: var(--mj-wh) !important;     /* ← White text on hover */
  text-decoration: none !important;
}

/* Bookmark button (card) */
.mj-btn-bm {
  width: 38px; height: 38px;
  border: 1px solid var(--mj-bd);
  border-radius: var(--mj-br);
  background: transparent;
  cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  color: var(--mj-gyl); padding: 0;
  transition: border-color .2s, color .2s;
  flex-shrink: 0;
}
.mj-btn-bm:hover { border-color: var(--mj-dk); color: var(--mj-dk); }
.mj-btn-bm svg { width: 15px; height: 15px; }
.mj-btn-bm.mj-saved { color: var(--mj-r) !important; border-color: var(--mj-r) !important; }
.mj-btn-bm.mj-saved svg { fill: var(--mj-r) !important; }

/* Empty state */
.mj-empty {
  text-align: center; padding: 64px 24px; color: var(--mj-gy);
}
.mj-empty svg { width: 60px; height: 60px; color: #C5C0B5; margin-bottom: 16px; }
.mj-empty h3 {
  font-family: var(--mj-fh); font-size: 22px; font-weight: 700;
  text-transform: uppercase; color: var(--mj-dk); margin: 0 0 8px;
}
.mj-empty p { font-size: 15px; margin: 0; }
.mj-empty a { color: var(--mj-r); }

/* Pagination */
.mj-pager {
  display: flex; justify-content: center;
  gap: 6px; margin-top: 36px; flex-wrap: wrap;
}
.mj-pager .page-numbers {
  display: inline-block; padding: 8px 14px;
  border: 1px solid var(--mj-bd); border-radius: var(--mj-br);
  font-family: var(--mj-fh); font-size: 14px; font-weight: 600;
  color: var(--mj-dk); text-decoration: none; background: var(--mj-wh);
  transition: all .18s;
}
.mj-pager .page-numbers.current,
.mj-pager .page-numbers:hover {
  background: var(--mj-dk); border-color: var(--mj-dk); color: var(--mj-wh);
}

/* ═══════════════════════════════════════════════════════
   SINGLE JOB DETAIL PAGE
═══════════════════════════════════════════════════════ */

/* Body wrapper */
.mj-single-body-wrap { background: #F5F4EF; width: 100%; }

.mj-single-body {
  max-width: 100%;
  margin: 0 auto;
  padding: 40px 40px 56px;
  display: grid;
  grid-template-columns: 1fr 290px;
  gap: 28px;
  align-items: start;
  box-sizing: border-box;
}

/* Content card */
.mj-content-card {
  background: var(--mj-wh);
  border: 1px solid var(--mj-bd);
  border-radius: var(--mj-br);
  padding: 30px 32px;
  box-shadow: var(--mj-sh);
}
.mj-content-heading {
  font-family: var(--mj-fh) !important;
  font-size: 19px !important; font-weight: 700 !important;
  text-transform: uppercase !important; letter-spacing: 1px !important;
  color: var(--mj-dk) !important;
  margin: 0 0 20px !important;
  padding-bottom: 14px !important;
  border-bottom: 2px solid var(--mj-bd) !important;
  text-decoration: none !important; box-shadow: none !important;
}
.mj-content-heading::before, .mj-content-heading::after { display: none !important; }

/* ─── Job description typography ─── */
.mj-job-description {
  font-family: var(--mj-fb);
  font-weight:400 !important;
  font-size: 17px;
  line-height: 1.75;
  color: #000000;
}

.mj-job-description h1,
.mj-job-description h2 {
  font-family: var(--mj-fh) !important;
  font-size: 18px !important; font-weight: 700 !important;
  text-transform: uppercase !important;
  color: var(--mj-dk) !important;
  margin: 26px 0 10px !important;
  padding-bottom: 8px !important;
  border-bottom: 1px solid var(--mj-bd) !important;
  text-decoration: none !important; box-shadow: none !important;
}
.mj-job-description h1:first-child,
.mj-job-description h2:first-child { margin-top: 0 !important; }

.mj-job-description h3 {
  font-family: var(--mj-fh) !important;
  font-size: 16px !important; font-weight: 700 !important;
  text-transform: uppercase !important;
  color: var(--mj-dk) !important;
  margin: 20px 0 8px !important;
  text-decoration: none !important;
}

.mj-job-description p { margin: 0 0 14px !important; color: #444; }

.mj-job-description strong,
.mj-job-description b { color: var(--mj-dk); font-weight: 400; }

.mj-job-description hr { border: none; border-top: 1px solid var(--mj-bd); margin: 22px 0; }

/* ── LISTS — only ONE red bullet, remove browser black disc ── */
.mj-job-description ul,
.mj-job-description ol {
  margin: 6px 0 16px !important;
  padding-left: 0 !important;
}


.mj-job-description ul ul li::before { color: var(--mj-dks) !important; content: '◦' !important; }

/* Apply CTA */
.mj-apply-cta {
  margin-top: 22px;
  background: #FFF9D6;
  border: 1px solid #EDD900;
  border-left: 4px solid var(--mj-r);
  border-radius: var(--mj-br);
  padding: 24px 28px;
}
.mj-apply-cta h3 {
  font-family: var(--mj-fh); font-size: 20px; font-weight: 700;
  text-transform: uppercase; margin: 0 0 8px; color: var(--mj-dk);
}
.mj-apply-cta p { font-size: 14px; color: #555; margin: 0 0 16px; line-height: 1.65; }
.mj-apply-cta a { color: var(--mj-r); }
.mj-apply-cta .mj-btn-apply { display: inline-block; }

.mj-back-link { margin-top: 22px; font-size: 14px; }
.mj-back-link a { color: var(--mj-gy); text-decoration: none; font-weight: 500; }
.mj-back-link a:hover { color: var(--mj-dk); }

/* ─── Sidebar ─── */
.mj-single-sidebar {
  display: flex; flex-direction: column;
  gap: 18px; position: sticky; top: 24px;
}
.mj-scard {
  border: 1px solid var(--mj-bd);
  border-radius: var(--mj-br);
  padding: 22px 22px 20px;
  box-shadow: var(--mj-sh);
}
.mj-scard-title {
  font-family: var(--mj-fh) !important;
  font-size: 18px !important; font-weight: 600 !important;
  text-transform: uppercase !important; letter-spacing: 1.2px !important;
  color: var(--mj-dk) !important; margin: 0 0 8px !important;
  text-decoration: none !important; border-bottom: none !important;
}
.mj-scard-title::before, .mj-scard-title::after { display: none !important; }

/* Snapshot list */
.mj-snap { margin: 0; padding: 0; display: flex; flex-direction: column; gap: 14px; }
.mj-snap-row { display: flex; flex-direction: column; gap: 3px; }
.mj-snap-row dt {
  font-family: var(--mj-fh);
  font-size: 17px; font-weight: 700;
  text-transform: uppercase; letter-spacing: 1px;
  color: var(--mj-gyl);
}
.mj-snap-row dd {
  font-size: 17px; font-weight: 500;
  color: var(--mj-dk); margin: 0; line-height: 1.4;
}
.mj-pill {
  display: inline-block;
  background: var(--mj-dk); color: var(--mj-y);
  font-family: var(--mj-fh); font-size: 17px; font-weight: 700;
  padding: 1px 11px; border-radius: 4px;
}

/* Share */
.mj-share-row { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.mj-share-btn {
  width: 36px; height: 36px;
  border-radius: 6px;
  display: flex; align-items: center; justify-content: center;
  text-decoration: none;
  transition: opacity .18s, transform .15s;
  border: none; cursor: pointer; flex-shrink: 0;
}
.mj-share-btn:hover { opacity: .8; transform: translateY(-2px); }
.mj-share-btn svg { width: 17px; height: 17px; }
.mj-sli { background: #0A66C2; color: #fff; }
.mj-sfb { background: #1877F2; color: #fff; }
.mj-sem { background: #555;    color: #fff; }
.mj-scp { background: #EBEBEB; color: var(--mj-gy); }

/* ─── Similar Jobs ─── */
.mj-similar-wrap {
  padding: 1px 0 1px;
  width: 100%;
}
.mj-similar-in {
  max-width: 100%;
  margin: 0 auto;
  padding: 0 40px;
  box-sizing: border-box;
}
.mj-similar-hdr {
  display: flex; align-items: flex-end;
  justify-content: space-between;
  margin-bottom: 24px; gap: 16px;
}
.mj-similar-title {
  font-family: var(--mj-fh) !important;
  font-size: clamp(22px, 3vw, 30px) !important;
  font-weight: 800 !important; text-transform: uppercase !important;
  color: var(--mj-dk) !important;
  margin: 0 0 8px !important;
  text-decoration: none !important; border-bottom: none !important;
}
.mj-similar-title::before, .mj-similar-title::after { display: none !important; }
.mj-all-link {
  font-size: 18px; font-weight: 500; color: var(--mj-dk);
  text-decoration: none; white-space: nowrap; padding-bottom: 20px;
}
.mj-all-link:hover { color: var(--mj-r); }
.mj-sim-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(400px, 1fr));
  gap: 16px;
}
.mj-sim-grid .mj-card { flex-direction: column; align-items: flex-start; }
.mj-sim-grid .mj-card-right { margin-top: 14px; align-self: flex-start; }

/* ═══════════════════════════════════════════════════════
   MOBILE — RESPONSIVE
═══════════════════════════════════════════════════════ */

/* Tablet */
@media (max-width: 900px) {
  .mj-single-body {
    grid-template-columns: 1fr;
    padding: 28px 24px 44px;
  }
  .mj-single-sidebar { position: static; }
  .mj-similar-in { padding: 0 24px; }
  .mj-similar-hdr { flex-direction: column; align-items: flex-start; }
  .mj-all-link { padding-bottom: 0; }
  .mj-hero-in { padding: 0 24px; }
}

/* Mobile */
@media (max-width: 600px) {
  /* Hero */
  .mj-hero { padding: 32px 0 28px; }
  .mj-hero-title { font-size: 28px !important; }
  .mj-hero-desc { font-size: 14px; }
  .mj-hero-actions { flex-wrap: wrap; }
  .mj-btn-apply { width: 100%; text-align: center; box-sizing: border-box; }
  .mj-bm-hero { display: none; }

  /* Listing */
  .mj-listing-in { padding: 28px 16px 48px; }
  .mj-filter-form { flex-direction: column; align-items: stretch; }
  .mj-search-field { width: 100%; }
  .mj-sel-wrap { width: 100%; }
  .mj-btn-search { width: 100%; text-align: center; padding: 10px 22px; }

  /* Cards */
  .mj-card { flex-direction: column; align-items: flex-start; padding: 18px 16px; }
  .mj-card-right { margin-top: 14px; width: 100%; justify-content: flex-start; }
  .mj-btn-view { width: 100%; text-align: center; }

  /* Single body */
  .mj-single-body { padding: 20px 16px 36px; gap: 20px; }
  .mj-content-card { padding: 20px 16px; }

  /* Similar */
  .mj-sim-grid { grid-template-columns: 1fr; }
  .mj-similar-wrap { padding: 32px 0 40px; }
  .mj-similar-in { padding: 0 16px; }
  .mj-sim-grid .mj-card { flex-direction: column; align-items: flex-start; }
  .mj-sim-grid .mj-card-right { width: 100%; }
  .mj-sim-grid .mj-btn-view { width: 100%; text-align: center; }
}
