/* ===== OPPORTUNITIES PAGE ===== */

/* --- Page Header --- */
.page-header {
  background: var(--white);
  padding: 40px 0;
  border-bottom: 1.5px solid var(--gray-mid);
}
.page-header-inner {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 24px;
  flex-wrap: wrap;
}
.page-header-actions { display: flex; gap: 10px; align-items: center; flex-shrink: 0; }
.page-header h1 {
  font-family: 'Bebas Neue', Impact, 'Arial Narrow', sans-serif;
  font-size: clamp(2.4rem, 5vw, 4rem);
  color: var(--dark);
  font-weight: 400;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}
.page-header p {
  color: var(--gray-dark);
  margin-top: 6px;
  font-size: .9rem;
}
.page-header p strong { color: var(--dark); }

/* --- Remove old SVG map section styles (using Leaflet now) --- */
.map-wrapper, #africa-svg, .map-continent, .map-country-dot, .map-tooltip { display: none; }

/* --- Layout --- */
.opp-layout {
  display: grid;
  grid-template-columns: 260px 1fr;
  gap: 28px;
  padding: 36px 0 80px;
  align-items: start;
}
.opp-main { min-width: 0; }

/* --- Sidebar --- */
.sidebar {
  position: sticky;
  top: calc(var(--nav-h) + 16px);
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.filter-card {
  background: var(--white);
  border: 2px solid var(--dark);
  border-radius: var(--radius-lg);
  overflow: hidden;
  box-shadow: 3px 3px 0 var(--dark);
}
.filter-card-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 13px 18px;
  border-bottom: 1px solid var(--gray-mid);
}
.filter-card-head h4 {
  font-size: .75rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .09em;
  color: var(--dark);
}
.filter-clear {
  font-size: .72rem;
  font-weight: 600;
  color: var(--gray-dark);
  cursor: pointer;
  border: none;
  background: none;
  padding: 0;
  font-family: inherit;
  transition: color .15s;
}
.filter-clear:hover { color: var(--dark); }
.filter-body { padding: 14px 18px; display: flex; flex-direction: column; gap: 10px; }

/* Search inside sidebar */
.search-input-wrap {
  display: flex;
  align-items: center;
  gap: 8px;
  background: var(--gray-light);
  border: 1.5px solid var(--gray-mid);
  border-radius: 100px;
  padding: 9px 14px;
  transition: border-color .15s;
}
.search-input-wrap:focus-within { border-color: var(--dark); }
.search-input-wrap svg { flex-shrink: 0; color: var(--gray-dark); }
.filter-search-input {
  border: none;
  outline: none;
  background: transparent;
  font-family: inherit;
  font-size: .85rem;
  color: var(--dark);
  width: 100%;
}
.filter-search-input::placeholder { color: var(--gray-dark); }

/* Checkboxes */
.filter-check {
  display: flex;
  align-items: center;
  gap: 9px;
  cursor: pointer;
  user-select: none;
  padding: 2px 0;
}
.filter-check input[type="checkbox"] {
  appearance: none;
  width: 17px;
  height: 17px;
  border: 1.5px solid var(--gray-mid);
  border-radius: 5px;
  cursor: pointer;
  transition: all .15s;
  flex-shrink: 0;
  position: relative;
}
.filter-check input[type="checkbox"]:checked {
  background: var(--dark);
  border-color: var(--dark);
}
.filter-check input[type="checkbox"]:checked::after {
  content: '';
  position: absolute;
  inset: 2px;
  background: url("data:image/svg+xml,%3Csvg viewBox='0 0 10 8' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 4L3.5 6.5L9 1' stroke='white' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") center/contain no-repeat;
}
.filter-check-label {
  font-size: .85rem;
  font-weight: 500;
  color: var(--dark);
  display: flex;
  align-items: center;
  gap: 7px;
  flex: 1;
}
.type-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  flex-shrink: 0;
}
.filter-check-count {
  font-size: .7rem;
  font-weight: 700;
  color: var(--gray-dark);
  background: var(--gray-light);
  padding: 2px 7px;
  border-radius: 100px;
  margin-left: auto;
}

/* --- Results header --- */
.results-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 18px;
  gap: 12px;
  flex-wrap: wrap;
}
.results-count { font-size: .875rem; font-weight: 600; color: var(--gray-dark); }
.results-count strong { color: var(--dark); }
.sort-select {
  padding: 8px 36px 8px 16px;
  font-family: inherit;
  font-size: .82rem;
  font-weight: 600;
  border: 1.5px solid var(--gray-mid);
  border-radius: 100px;
  background: var(--white) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='10' fill='%231C1D1C' viewBox='0 0 16 16'%3E%3Cpath d='M7.247 11.14 2.451 5.658C1.885 5.013 2.345 4 3.204 4h9.592a1 1 0 0 1 .753 1.659l-4.796 5.48a1 1 0 0 1-1.506 0z'/%3E%3C/svg%3E") no-repeat right 14px center;
  appearance: none;
  cursor: pointer;
  outline: none;
  color: var(--dark);
  transition: border-color .15s;
}
.sort-select:focus { border-color: var(--dark); }

/* --- Active filters --- */
.active-filters {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
  margin-bottom: 16px;
}
.active-filters-label { font-size: .75rem; font-weight: 600; color: var(--gray-dark); }
.active-filter-tag {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 4px 12px;
  background: var(--dark);
  color: var(--white);
  font-size: .72rem;
  font-weight: 600;
  border-radius: 100px;
  cursor: pointer;
  transition: background .15s;
}
.active-filter-tag:hover { background: var(--dark-2); }
.active-filter-tag svg { width: 9px; height: 9px; }

/* --- Bookmark / save button on job cards --- */
.bookmark-btn {
  background: none; border: 2px solid var(--gray-mid);
  border-radius: 100px; cursor: pointer; padding: 5px 10px;
  display: flex; align-items: center; gap: 5px;
  font-family: inherit; font-size: .72rem; font-weight: 700;
  color: var(--gray-dark); transition: all .15s;
  flex-shrink: 0;
}
.bookmark-btn:hover { border-color: var(--orange); color: var(--orange); }
.bookmark-btn.saved { border-color: var(--orange); background: rgba(253,105,37,.08); color: var(--orange); }
.bookmark-btn.saved svg path { fill: var(--orange); }

/* Leaflet marker — shared with homepage */
.lmap-marker {
  background: var(--yellow); border: 2.5px solid var(--dark);
  border-radius: 50%; display: flex; align-items: center; justify-content: center;
  font-family: 'Inter', sans-serif; font-weight: 800; color: var(--dark);
  cursor: pointer; box-shadow: 3px 3px 0 var(--dark);
  transition: transform .12s, box-shadow .12s; line-height: 1;
}
.lmap-marker:hover { transform: translate(-1px,-1px); box-shadow: 4px 4px 0 var(--dark); }
.leaflet-tooltip {
  font-family: 'Inter', sans-serif !important; font-size: 12px !important;
  font-weight: 700 !important; border-radius: 100px !important;
  border: 2px solid var(--dark) !important; box-shadow: 3px 3px 0 var(--dark) !important;
  padding: 6px 14px !important; color: var(--dark) !important;
}

/* --- Africa Map --- */
.map-section {
  background: var(--white);
  border-radius: var(--radius-lg);
  overflow: hidden;
  margin-bottom: 24px;
}
.map-header {
  padding: 12px 4px 10px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
}
.map-header h4 { font-size: .78rem; font-weight: 800; text-transform: uppercase; letter-spacing: .12em; color: var(--gray-dark); }
.map-header p  { font-size: .75rem; color: var(--gray-dark); margin-top: 2px; }
.map-legend { display: flex; gap: 14px; }
.map-legend-item { display: flex; align-items: center; gap: 5px; font-size: .7rem; color: var(--gray-dark); }
.map-legend-dot { width: 9px; height: 9px; border-radius: 50%; }
.map-wrapper {
  padding: 16px;
  display: flex;
  justify-content: center;
  background: var(--gray-light);
  position: relative;
  min-height: 220px;
}
#africa-svg { width: 100%; max-width: 480px; height: auto; display: block; }
.map-continent { fill: var(--gray-mid); stroke: var(--white); stroke-width: 1.5; }
.map-country-dot { cursor: pointer; transition: all .2s; }
.map-country-dot:hover circle { filter: brightness(1.1); }
.map-country-dot.active circle { stroke: var(--dark); stroke-width: 3; }

/* Map tooltip */
.map-tooltip {
  position: absolute;
  background: var(--dark);
  color: var(--white);
  padding: 8px 14px;
  border-radius: 100px;
  font-size: .78rem;
  font-weight: 600;
  pointer-events: none;
  opacity: 0;
  transition: opacity .15s;
  white-space: nowrap;
  z-index: 10;
  box-shadow: var(--shadow-md);
}
.map-tooltip.visible { opacity: 1; }
.map-tooltip span { color: var(--yellow); }
.map-reset-btn {
  position: absolute;
  bottom: 16px;
  right: 16px;
  font-size: .7rem;
  font-weight: 600;
  padding: 5px 12px;
  background: var(--white);
  border: 1.5px solid var(--gray-mid);
  border-radius: 100px;
  cursor: pointer;
  font-family: inherit;
  color: var(--gray-dark);
  transition: all .15s;
  display: none;
}
.map-reset-btn:hover { border-color: var(--dark); color: var(--dark); }
.map-reset-btn.visible { display: block; }

/* --- Job Cards --- */
.jobs-list { display: flex; flex-direction: column; gap: 14px; }
.job-card {
  background: var(--white);
  border: 2.5px solid var(--dark);
  border-radius: var(--radius-lg);
  padding: 22px 24px 22px 28px;
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 16px;
  align-items: start;
  text-decoration: none;
  color: inherit;
  transition: transform .15s, box-shadow .15s;
  position: relative;
  overflow: hidden;
  cursor: pointer;
  box-shadow: 4px 4px 0 var(--dark);
}
.job-card::before {
  content: '';
  position: absolute;
  left: 0; top: 0; bottom: 0;
  width: 5px;
}
.job-card.type-jobs::before        { background: #DDA63A; }
.job-card.type-internship::before  { background: #26BDE2; }
.job-card.type-consultancy::before { background: #FD6925; }
.job-card.type-capacity::before    { background: #3F7E44; }
.job-card:hover {
  transform: translate(-2px,-2px);
  box-shadow: 6px 6px 0 var(--dark);
}
.job-card-logo-row {
  display: flex; align-items: center; gap: 9px;
  margin-bottom: 6px;
}
.job-card-logo {
  width: 30px; height: 30px; border-radius: 7px;
  border: 1.5px solid var(--gray-mid);
  display: flex; align-items: center; justify-content: center;
  font-size: .58rem; font-weight: 800; flex-shrink: 0;
  color: white; letter-spacing: .02em; overflow: hidden;
}
.job-card-logo img {
  width: 100%; height: 100%; object-fit: contain; border-radius: 5px;
  background: white; display: block;
}
.job-card-logo img.hidden { display: none; }
.job-card-logo .initials { display: none; }
.job-card-logo.logo-fallback .initials { display: block; }
.job-card-logo.logo-fallback img { display: none; }
.job-card-org {
  font-size: .72rem;
  font-weight: 700;
  color: var(--gray-dark);
  text-transform: uppercase;
  letter-spacing: .07em;
}
.job-card h3 {
  font-size: 1rem;
  font-weight: 700;
  color: var(--dark);
  line-height: 1.3;
  margin-bottom: 10px;
}
.job-card-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  font-size: .78rem;
  color: var(--gray-dark);
}
.job-card-meta-item { display: flex; align-items: center; gap: 4px; }
.job-card-meta-item svg { opacity: .55; flex-shrink: 0; }
.job-card-tags { display: flex; gap: 7px; flex-wrap: wrap; margin-top: 12px; }

.job-card-right {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 8px;
  flex-shrink: 0;
}
.deadline-pill {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: .72rem;
  font-weight: 700;
  padding: 4px 10px;
  border-radius: 100px;
}
.deadline-pill.urgent { background: rgba(229,62,62,.08); color: #c0392b; }
.deadline-pill.normal { background: var(--gray-light); color: var(--gray-dark); }
.posted-date { font-size: .7rem; color: var(--gray-dark); }

/* --- No results --- */
.no-results {
  text-align: center;
  padding: 72px 24px;
  color: var(--gray-dark);
}
.no-results svg { opacity: .25; margin-bottom: 16px; }
.no-results h3 { color: var(--dark); margin-bottom: 8px; }
.no-results p { font-size: .875rem; }

/* --- Modal --- */
.modal-backdrop {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,.6);
  z-index: 1000;
  display: none;
  align-items: center;
  justify-content: center;
  padding: 24px;
}
.modal-backdrop.open { display: flex; }
.modal {
  background: var(--white);
  border-radius: var(--radius-xl);
  max-width: 660px;
  width: 100%;
  max-height: 90vh;
  overflow-y: auto;
  position: relative;
  box-shadow: 0 24px 80px rgba(0,0,0,.25);
  animation: modal-in .2s ease-out;
}
@keyframes modal-in {
  from { opacity: 0; transform: scale(.96) translateY(8px); }
  to   { opacity: 1; transform: scale(1)   translateY(0); }
}
.modal-header {
  position: sticky;
  top: 0;
  background: var(--white);
  border-bottom: 1px solid var(--gray-mid);
  padding: 18px 24px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  z-index: 1;
}
.modal-close {
  width: 34px;
  height: 34px;
  border-radius: 50%;
  border: 1.5px solid var(--gray-mid);
  background: transparent;
  cursor: pointer;
  display: grid;
  place-items: center;
  transition: all .15s;
  font-size: 16px;
  color: var(--dark);
  font-family: inherit;
}
.modal-close:hover { background: var(--gray-light); border-color: var(--dark); }
.modal-body { padding: 24px; }
.modal-org {
  font-size: .72rem;
  font-weight: 700;
  color: var(--gray-dark);
  text-transform: uppercase;
  letter-spacing: .07em;
  margin-bottom: 4px;
}
.modal-title { font-size: 1.4rem; font-weight: 800; margin-bottom: 20px; line-height: 1.2; }
.modal-meta-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 10px;
  background: var(--gray-light);
  border-radius: var(--radius-md);
  padding: 18px;
  margin-bottom: 22px;
}
.modal-meta-item label {
  font-size: .68rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .1em;
  color: var(--gray-dark);
  display: block;
  margin-bottom: 3px;
}
.modal-meta-item span { font-size: .875rem; font-weight: 600; color: var(--dark); }
.modal-section { margin-bottom: 20px; }
.modal-section h5 {
  font-size: .72rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .1em;
  margin-bottom: 8px;
  color: var(--gray-dark);
}
.modal-section p  { font-size: .9rem; line-height: 1.75; color: #444; }
.modal-section ul { padding-left: 0; list-style: none; margin: 0; }
.modal-section ul li {
  font-size: .9rem;
  line-height: 1.75;
  color: #444;
  padding: 4px 0 4px 20px;
  position: relative;
}
.modal-section ul li::before {
  content: '→';
  position: absolute;
  left: 0;
  color: var(--green);
  font-weight: 600;
}
.modal-disclaimer {
  margin-top: 20px;
  padding: 12px 16px;
  background: #f8f9fa;
  border-left: 3px solid var(--gray-mid);
  border-radius: 4px;
  font-size: .78rem;
  color: var(--gray-dark);
  line-height: 1.6;
  font-style: italic;
}
.modal-footer {
  padding: 18px 24px;
  border-top: 1px solid var(--gray-mid);
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
}

/* ===== DARK MODE ===== */
  /* dark SDG 9 */



































/* ===== RESPONSIVE ===== */
@media (max-width: 960px) {
  .opp-layout { grid-template-columns: 1fr; }
  .sidebar { position: static; flex-direction: row; flex-wrap: wrap; }
  .filter-card { flex: 1; min-width: 220px; }
  .map-wrapper { max-height: 320px; overflow: hidden; }
}
@media (max-width: 640px) {
  .page-header-inner { flex-direction: column; align-items: flex-start; }
  .job-card { grid-template-columns: 1fr; }
  .job-card-right { align-items: flex-start; flex-direction: row; flex-wrap: wrap; }
  .modal-meta-grid { grid-template-columns: 1fr; }
  .sidebar { flex-direction: column; }
  .filter-card { min-width: 0; width: 100%; }
}
