/* ============================================================
   WorkHive Homepage — Scoped under .fmp-home
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&family=Plus+Jakarta+Sans:wght@700;800&display=swap');

.fmp-home {
  --h-brand:  #5b3ef5;
  --h-brand-d:#4428d4;
  --h-brand-l:#ede9ff;
  --h-accent: #0ea5e9;
  --h-900: #0f0e17;
  --h-800: #1e1b2e;
  --h-700: #2d2a45;
  --h-600: #4a4668;
  --h-400: #8b87a8;
  --h-300: #b8b5ce;
  --h-200: #e2e0ee;
  --h-100: #f1f0f8;
  --h-50:  #f8f7fc;
  --h-ok:  #059669;
  --h-ok-bg:#d1fae5;
  --h-warn:#d97706;
  --h-warn-bg:#fef3c7;
  --h-danger:#dc2626;
  --h-surface:#ffffff;
  --h-bg: #f6f5fb;
  --h-border: rgba(91,62,245,.12);
  --h-border2:rgba(91,62,245,.22);
  --h-shadow: 0 4px 16px rgba(15,14,23,.08),0 2px 6px rgba(15,14,23,.04);
  --h-shadow-sm:0 1px 3px rgba(15,14,23,.06);
  --h-r:  10px;
  --h-rl: 16px;
  --h-rx: 24px;
  --h-font:'Inter',-apple-system,sans-serif;
  --h-fontd:'Plus Jakarta Sans','Inter',sans-serif;

  font-family: var(--h-font) !important;
  color: var(--h-900);
  background: var(--h-bg);
  width: 100%;
}

.fmp-home *, .fmp-home *::before, .fmp-home *::after {
  box-sizing: border-box !important;
}

/* ── Hero ──────────────────────────────────────────────────── */
.fmph-hero {
  position: relative;
  background: #1e1b2e !important;
  border-radius: var(--h-rx) !important;
  padding: 72px 56px !important;
  margin-bottom: 28px !important;
  overflow: hidden !important;
  min-height: 340px;
  display: flex;
  align-items: center;
}
.fmph-hero__orb {
  position: absolute;
  border-radius: 50%;
  pointer-events: none;
}
.fmph-hero__orb--1 {
  width: 500px; height: 500px;
  top: -100px; right: -80px;
  background: radial-gradient(circle, rgba(91,62,245,.45) 0%, transparent 65%);
}
.fmph-hero__orb--2 {
  width: 320px; height: 320px;
  bottom: -80px; right: 60px;
  background: rgba(91,62,245,.14);
}
.fmph-hero__inner { position: relative; z-index: 2; max-width: 600px; }
.fmph-hero__label {
  display: inline-block;
  background: rgba(91,62,245,.35);
  color: rgba(255,255,255,.85);
  border: 1px solid rgba(91,62,245,.5);
  border-radius: 999px;
  padding: 5px 14px;
  font-size: .75rem;
  font-weight: 700;
  letter-spacing: .04em;
  text-transform: uppercase;
  margin-bottom: 18px;
}
.fmph-hero__title {
  font-family: var(--h-fontd) !important;
  font-size: 2.8rem !important;
  font-weight: 800 !important;
  line-height: 1.1 !important;
  color: #fff !important;
  margin: 0 0 16px !important;
  padding: 0 !important;
  border: none !important;
  letter-spacing: -.03em !important;
}
.fmph-hero__sub {
  font-size: 1.05rem !important;
  color: rgba(255,255,255,.75) !important;
  margin: 0 0 28px !important;
  padding: 0 !important;
  max-width: 460px;
  line-height: 1.6;
}
.fmph-hero__btns { display: flex !important; gap: 12px !important; flex-wrap: wrap !important; }
.fmph-hero__scroll {
  position: absolute;
  bottom: 20px; left: 50%;
  transform: translateX(-50%);
  z-index: 2;
  width: 36px; height: 36px;
  background: rgba(255,255,255,.1);
  border: 1px solid rgba(255,255,255,.2);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  color: rgba(255,255,255,.7);
}

/* ── Buttons ───────────────────────────────────────────────── */
.fmph-btn {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 6px !important;
  padding: 11px 22px !important;
  border-radius: var(--h-r) !important;
  font-size: .875rem !important;
  font-weight: 700 !important;
  font-family: var(--h-font) !important;
  cursor: pointer !important;
  text-decoration: none !important;
  border: 1.5px solid transparent !important;
  white-space: nowrap !important;
  transition: all .18s !important;
  letter-spacing: -.01em !important;
  line-height: 1 !important;
  box-shadow: none !important;
}
.fmph-btn--primary { background: var(--h-brand) !important; color: #fff !important; border-color: var(--h-brand) !important; }
.fmph-btn--primary:hover { background: var(--h-brand-d) !important; border-color: var(--h-brand-d) !important; transform: translateY(-1px) !important; box-shadow: 0 4px 14px rgba(91,62,245,.35) !important; color: #fff !important; }
.fmph-btn--outline { background: transparent !important; color: var(--h-600) !important; border-color: var(--h-border2) !important; }
.fmph-btn--outline:hover { border-color: var(--h-brand) !important; color: var(--h-brand) !important; background: var(--h-brand-l) !important; }
.fmph-hero .fmph-btn--outline { background: rgba(255,255,255,.1) !important; color: #fff !important; border-color: rgba(255,255,255,.75) !important; }
.fmph-hero .fmph-btn--outline:hover { background: rgba(255,255,255,.22) !important; border-color: #fff !important; color: #fff !important; }
.fmph-btn--ghost { background: var(--h-surface) !important; color: var(--h-600) !important; border-color: var(--h-border) !important; }
.fmph-btn--ghost:hover { color: var(--h-brand) !important; border-color: var(--h-brand) !important; }
.fmph-btn--ghost-brand { color: var(--h-brand) !important; border-color: var(--h-brand) !important; background: var(--h-brand-l) !important; }
.fmph-btn--white { background: #fff !important; color: var(--h-brand) !important; border-color: #fff !important; }
.fmph-btn--white:hover { background: var(--h-brand-l) !important; }
.fmph-btn--outline-white { background: rgba(255,255,255,.12) !important; color: #fff !important; border-color: rgba(255,255,255,.75) !important; }
.fmph-btn--outline-white:hover { background: rgba(255,255,255,.22) !important; border-color: #fff !important; }
.fmph-btn--sm { padding: 7px 15px !important; font-size: .8rem !important; border-radius: 8px !important; }
.fmph-btn--flex { flex: 1 !important; }

/* ── Stats ─────────────────────────────────────────────────── */
.fmph-stats {
  display: grid !important;
  grid-template-columns: repeat(4,1fr) !important;
  gap: 14px !important;
  margin-bottom: 40px !important;
}
.fmph-stat {
  background: var(--h-surface) !important;
  border: 1px solid var(--h-border) !important;
  border-radius: var(--h-rl) !important;
  padding: 22px 18px !important;
  text-align: center !important;
  position: relative;
  overflow: hidden;
}
.fmph-stat::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  background: var(--h-brand);
  border-radius: var(--h-rl) var(--h-rl) 0 0;
}
.fmph-stat:last-child::before { background: linear-gradient(90deg,var(--h-brand),var(--h-accent)); }
.fmph-stat__n {
  display: block !important;
  font-family: var(--h-fontd) !important;
  font-size: 1.8rem !important;
  font-weight: 800 !important;
  color: var(--h-900) !important;
  letter-spacing: -.04em !important;
  line-height: 1 !important;
  margin-bottom: 5px !important;
}
.fmph-stat__l {
  display: block !important;
  font-size: .72rem !important;
  color: var(--h-400) !important;
  font-weight: 600 !important;
  text-transform: uppercase !important;
  letter-spacing: .06em !important;
}

/* ── Section Layout ────────────────────────────────────────── */
.fmph-section { margin-bottom: 48px !important; }
.fmph-section__head {
  display: flex !important;
  align-items: flex-end !important;
  justify-content: space-between !important;
  margin-bottom: 20px !important;
}
.fmph-section__title {
  font-family: var(--h-fontd) !important;
  font-size: 1.35rem !important;
  font-weight: 800 !important;
  color: var(--h-900) !important;
  letter-spacing: -.03em !important;
  margin: 0 0 3px !important;
  padding: 0 !important;
  border: none !important;
}
.fmph-section__sub {
  font-size: .82rem !important;
  color: var(--h-400) !important;
  margin: 0 !important;
  padding: 0 !important;
}

/* ── Filter ────────────────────────────────────────────────── */
.fmph-filter {
  display: flex !important;
  gap: 10px !important;
  align-items: center !important;
  flex-wrap: wrap !important;
  background: var(--h-surface) !important;
  border: 1.5px solid var(--h-border) !important;
  border-radius: var(--h-rl) !important;
  padding: 13px 16px !important;
  margin-bottom: 22px !important;
  box-shadow: var(--h-shadow-sm) !important;
}
.fmph-filter__form {
  display: flex !important;
  flex-direction: row !important;
  gap: 10px !important;
  flex: 1 !important;
  align-items: center !important;
  flex-wrap: wrap !important;
}
.fmph-filter__input,
.fmph-filter__select {
  padding: 9px 13px !important;
  border: 1.5px solid var(--h-border) !important;
  border-radius: var(--h-r) !important;
  font-size: .875rem !important;
  font-family: var(--h-font) !important;
  color: var(--h-900) !important;
  background: var(--h-50) !important;
  outline: none !important;
  transition: border-color .15s !important;
  margin: 0 !important;
  height: auto !important;
  box-shadow: none !important;
}
.fmph-filter__input { flex: 1 !important; min-width: 180px !important; }
.fmph-filter__select { min-width: 145px !important; }
.fmph-filter__input:focus,.fmph-filter__select:focus {
  border-color: var(--h-brand) !important;
  box-shadow: 0 0 0 3px rgba(91,62,245,.1) !important;
  background: #fff !important;
}

/* ── Job Grid ──────────────────────────────────────────────── */
.fmph-job-grid {
  display: grid !important;
  grid-template-columns: repeat(3,1fr) !important;
  gap: 18px !important;
}
.fmph-job-card {
  background: var(--h-surface) !important;
  border: 1px solid var(--h-border) !important;
  border-radius: var(--h-rl) !important;
  padding: 22px !important;
  display: flex !important;
  flex-direction: column !important;
  transition: box-shadow .2s, transform .2s, border-color .2s !important;
  box-shadow: var(--h-shadow-sm) !important;
}
.fmph-job-card:hover { box-shadow: var(--h-shadow) !important; transform: translateY(-2px) !important; border-color: var(--h-border2) !important; }
.fmph-job-card__badges { display: flex !important; gap: 6px !important; margin-bottom: 12px !important; }
.fmph-badge {
  display: inline-flex !important;
  align-items: center !important;
  gap: 4px !important;
  padding: 3px 10px !important;
  border-radius: 999px !important;
  font-size: .7rem !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  letter-spacing: .04em !important;
  border: none !important;
}
.fmph-badge__dot { width: 5px !important; height: 5px !important; border-radius: 50% !important; background: currentColor !important; display: inline-block !important; flex-shrink: 0 !important; }
.fmph-badge--open { background: var(--h-ok-bg) !important; color: #065f46 !important; }
.fmph-badge--in_progress,.fmph-badge--active { background: #dbeafe !important; color: #1e40af !important; }
.fmph-badge--completed { background: var(--h-brand-l) !important; color: #3730a3 !important; }
.fmph-badge--cancelled { background: #fee2e2 !important; color: #991b1b !important; }
.fmph-badge--pending   { background: var(--h-warn-bg) !important; color: #92400e !important; }
.fmph-badge--type { background: var(--h-brand-l) !important; color: #4338ca !important; }
.fmph-job-card__title {
  font-size: .98rem !important;
  font-weight: 700 !important;
  margin: 0 0 8px !important;
  padding: 0 !important;
  border: none !important;
  line-height: 1.35 !important;
  letter-spacing: -.02em !important;
}
.fmph-job-card__title a { color: var(--h-900) !important; text-decoration: none !important; }
.fmph-job-card__title a:hover { color: var(--h-brand) !important; }
.fmph-job-card__excerpt { color: var(--h-600) !important; font-size: .83rem !important; margin: 0 0 13px !important; flex: 1 !important; line-height: 1.6 !important; }
.fmph-job-card__meta { display: flex !important; flex-wrap: wrap !important; gap: 8px !important; margin-bottom: 12px !important; }
.fmph-meta { font-size: .78rem !important; color: var(--h-600) !important; }
.fmph-meta--money { color: var(--h-brand) !important; font-weight: 700 !important; font-size: .83rem !important; }
.fmph-meta--avail { color: var(--h-ok) !important; font-weight: 700 !important; }
.fmph-job-card__skills,.fmph-fl-skills { display: flex !important; flex-wrap: wrap !important; gap: 4px !important; margin-bottom: 14px !important; }
.fmph-skill {
  display: inline-block !important;
  background: var(--h-brand-l) !important;
  color: var(--h-brand-d) !important;
  border-radius: 5px !important;
  padding: 3px 9px !important;
  font-size: .72rem !important;
  font-weight: 700 !important;
  border: none !important;
  margin: 0 !important;
}
.fmph-skill--more { background: var(--h-100) !important; color: var(--h-400) !important; }
.fmph-job-card__footer {
  display: flex !important;
  justify-content: space-between !important;
  align-items: center !important;
  border-top: 1px solid var(--h-border) !important;
  padding-top: 13px !important;
  margin-top: auto !important;
}
.fmph-author { display: flex !important; align-items: center !important; gap: 7px !important; font-size: .78rem !important; color: var(--h-300) !important; }
.fmph-initials {
  width: 26px; height: 26px;
  border-radius: 50%;
  background: var(--h-brand-l);
  color: var(--h-brand-d);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: .65rem;
  font-weight: 800;
  flex-shrink: 0;
}

/* ── Freelancer Grid ───────────────────────────────────────── */
.fmph-fl-grid {
  display: grid !important;
  grid-template-columns: repeat(3,1fr) !important;
  gap: 18px !important;
}
.fmph-fl-card {
  background: var(--h-surface) !important;
  border: 1px solid var(--h-border) !important;
  border-radius: var(--h-rl) !important;
  padding: 22px !important;
  display: flex !important;
  flex-direction: column !important;
  transition: box-shadow .2s, transform .2s !important;
  box-shadow: var(--h-shadow-sm) !important;
}
.fmph-fl-card:hover { box-shadow: var(--h-shadow) !important; transform: translateY(-2px) !important; }
.fmph-fl-card__top { display: flex !important; gap: 13px !important; margin-bottom: 12px !important; align-items: flex-start !important; }
.fmph-fl-av { position: relative !important; flex-shrink: 0 !important; }
.fmph-fl-av img { width: 60px !important; height: 60px !important; border-radius: 50% !important; display: block !important; border: 2px solid var(--h-border) !important; }
.fmph-fl-av__initials {
  width: 60px; height: 60px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--h-fontd);
  font-weight: 800;
  font-size: 1.1rem;
  color: #fff;
}
.fmph-fl-av__dot {
  position: absolute !important;
  bottom: 1px !important; right: 1px !important;
  width: 13px !important; height: 13px !important;
  border-radius: 50% !important;
  border: 2px solid #fff !important;
}
.fmph-fl-av__dot--on   { background: var(--h-ok) !important; }
.fmph-fl-av__dot--part { background: var(--h-warn) !important; }
.fmph-fl-info { flex: 1 !important; min-width: 0 !important; }
.fmph-fl-info h3 { font-size: .95rem !important; font-weight: 700 !important; margin: 0 0 3px !important; padding: 0 !important; border: none !important; letter-spacing: -.02em !important; }
.fmph-fl-info h3 a { color: var(--h-900) !important; text-decoration: none !important; }
.fmph-fl-info h3 a:hover { color: var(--h-brand) !important; }
.fmph-fl-tagline { font-size: .78rem !important; color: var(--h-600) !important; margin: 0 0 6px !important; }
.fmph-stars { display: flex !important; align-items: center !important; gap: 1px !important; }
.fmph-star { font-size: .82rem !important; color: var(--h-200) !important; }
.fmph-star--on { color: #f59e0b !important; }
.fmph-star-n { font-size: .74rem !important; color: var(--h-400) !important; margin-left: 4px !important; }
.fmph-fl-bio { font-size: .83rem !important; color: var(--h-600) !important; margin: 0 0 12px !important; flex: 1 !important; line-height: 1.6 !important; }
.fmph-fl-meta { display: flex !important; flex-wrap: wrap !important; gap: 8px !important; margin-bottom: 12px !important; }
.fmph-fl-actions {
  display: flex !important;
  gap: 8px !important;
  margin-top: auto !important;
  padding-top: 13px !important;
  border-top: 1px solid var(--h-border) !important;
}

/* ── Dashboard ─────────────────────────────────────────────── */
.fmph-dash {
  display: grid !important;
  grid-template-columns: 230px 1fr !important;
  border: 1px solid var(--h-border) !important;
  border-radius: var(--h-rx) !important;
  overflow: hidden !important;
  background: var(--h-surface) !important;
  box-shadow: var(--h-shadow) !important;
  min-height: 420px;
}
.fmph-dash__side {
  background: var(--h-50) !important;
  border-right: 1px solid var(--h-border) !important;
  padding: 22px 16px !important;
}
.fmph-dash__logo {
  font-family: var(--h-fontd) !important;
  font-weight: 800 !important;
  font-size: 1.1rem !important;
  color: var(--h-brand) !important;
  letter-spacing: -.03em !important;
  margin-bottom: 22px !important;
}
.fmph-dash__nav { display: flex !important; flex-direction: column !important; gap: 2px !important; }
.fmph-dash__nav-item {
  display: flex !important;
  align-items: center !important;
  gap: 9px !important;
  padding: 9px 11px !important;
  border-radius: var(--h-r) !important;
  font-size: .83rem !important;
  font-weight: 600 !important;
  color: var(--h-400) !important;
  text-decoration: none !important;
  transition: all .12s !important;
  position: relative !important;
}
.fmph-dash__nav-item:hover { background: var(--h-brand-l) !important; color: var(--h-brand) !important; }
.fmph-dash__nav-item--active { background: var(--h-brand-l) !important; color: var(--h-brand) !important; }
.fmph-dash__nav-item svg { flex-shrink: 0 !important; opacity: .7 !important; }
.fmph-dash__nav-item--active svg { opacity: 1 !important; }
.fmph-nav-badge {
  background: var(--h-danger) !important;
  color: #fff !important;
  border-radius: 999px !important;
  padding: 1px 6px !important;
  font-size: .65rem !important;
  font-weight: 700 !important;
  margin-left: auto !important;
}
.fmph-dash__main { padding: 24px !important; display: flex !important; flex-direction: column !important; }
.fmph-dash__greeting {
  display: flex !important;
  align-items: center !important;
  gap: 13px !important;
  margin-bottom: 20px !important;
  flex-wrap: wrap !important;
}
.fmph-dash__av {
  width: 46px; height: 46px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--h-fontd);
  font-weight: 800;
  font-size: .95rem;
  color: #fff;
  flex-shrink: 0;
}
.fmph-dash__greeting h3 {
  font-family: var(--h-fontd) !important;
  font-size: 1.05rem !important;
  font-weight: 800 !important;
  letter-spacing: -.03em !important;
  margin: 0 0 4px !important;
  padding: 0 !important;
  border: none !important;
  color: var(--h-900) !important;
}
.fmph-role-pill {
  display: inline-block !important;
  background: #e0f2fe !important;
  color: #075985 !important;
  border-radius: 999px !important;
  padding: 2px 10px !important;
  font-size: .68rem !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  letter-spacing: .05em !important;
  border: none !important;
}
.fmph-mini-stats {
  display: grid !important;
  grid-template-columns: repeat(3,1fr) !important;
  gap: 10px !important;
  margin-bottom: 18px !important;
}
.fmph-mini-stat {
  background: var(--h-50) !important;
  border-radius: var(--h-r) !important;
  padding: 14px 12px !important;
  border-top: 2.5px solid var(--h-brand) !important;
}
.fmph-mini-stat--rev { border-top-color: var(--h-accent) !important; }
.fmph-mini-n {
  display: block !important;
  font-family: var(--h-fontd) !important;
  font-size: 1.3rem !important;
  font-weight: 800 !important;
  letter-spacing: -.04em !important;
  color: var(--h-900) !important;
  margin-bottom: 3px !important;
}
.fmph-mini-l {
  display: block !important;
  font-size: .68rem !important;
  color: var(--h-400) !important;
  text-transform: uppercase !important;
  letter-spacing: .06em !important;
  font-weight: 600 !important;
}
.fmph-dash__tabs-bar {
  display: flex !important;
  gap: 2px !important;
  background: var(--h-100) !important;
  border-radius: var(--h-r) !important;
  padding: 3px !important;
  width: fit-content !important;
  margin-bottom: 14px !important;
}
.fmph-dash__tab {
  padding: 7px 16px !important;
  border-radius: 8px !important;
  font-size: .78rem !important;
  font-weight: 700 !important;
  color: var(--h-400) !important;
  cursor: pointer !important;
}
.fmph-dash__tab--active {
  background: var(--h-surface) !important;
  color: var(--h-brand) !important;
  box-shadow: var(--h-shadow-sm) !important;
}
.fmph-dash__prop-label {
  font-size: .72rem !important;
  text-transform: uppercase !important;
  letter-spacing: .08em !important;
  color: var(--h-400) !important;
  font-weight: 700 !important;
  margin: 0 0 10px !important;
  padding: 0 !important;
}
.fmph-prop-row {
  display: flex !important;
  align-items: center !important;
  gap: 12px !important;
  padding: 13px 14px !important;
  background: var(--h-50) !important;
  border: 1px solid var(--h-border) !important;
  border-radius: var(--h-r) !important;
  margin-bottom: 8px !important;
  transition: border-color .15s !important;
}
.fmph-prop-row:hover { border-color: var(--h-border2) !important; }
.fmph-prop-av {
  width: 38px; height: 38px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 800;
  color: #fff;
  font-size: .72rem;
  font-family: var(--h-fontd);
  flex-shrink: 0;
}
.fmph-prop-info { flex: 1 !important; font-size: .83rem !important; }
.fmph-prop-info strong { display: block !important; font-weight: 700 !important; margin-bottom: 2px !important; color: var(--h-900) !important; }
.fmph-prop-info p { color: var(--h-600) !important; margin: 0 0 2px !important; font-size: .78rem !important; }
.fmph-prop-info small { color: var(--h-brand) !important; font-weight: 700 !important; font-size: .74rem !important; }
.fmph-mini-rating {
  background: var(--h-warn-bg) !important;
  color: #92400e !important;
  border-radius: 4px !important;
  padding: 1px 6px !important;
  font-size: .66rem !important;
  font-weight: 700 !important;
  margin-left: 5px !important;
}
.fmph-prop-btns { display: flex !important; gap: 6px !important; flex-shrink: 0 !important; }
.fmph-prop-accept {
  background: var(--h-ok) !important;
  color: #fff !important;
  border: none !important;
  border-radius: 7px !important;
  padding: 6px 13px !important;
  font-size: .75rem !important;
  font-weight: 700 !important;
  cursor: pointer !important;
  font-family: var(--h-font) !important;
}
.fmph-prop-decline {
  background: transparent !important;
  color: var(--h-400) !important;
  border: 1px solid var(--h-border2) !important;
  border-radius: 7px !important;
  padding: 6px 11px !important;
  font-size: .75rem !important;
  font-weight: 600 !important;
  cursor: pointer !important;
  font-family: var(--h-font) !important;
}
.fmph-dash__empty { background: var(--h-50) !important; border: 1.5px dashed rgba(91,62,245,.2) !important; border-radius: var(--h-r) !important; padding: 24px !important; text-align: center !important; color: var(--h-400) !important; font-size: .85rem !important; }
.fmph-dash__empty a { color: var(--h-brand) !important; font-weight: 700 !important; text-decoration: none !important; }

/* ── CTA ───────────────────────────────────────────────────── */
.fmph-cta {
  background: var(--h-800) !important;
  border-radius: var(--h-rx) !important;
  padding: 56px !important;
  text-align: center !important;
  position: relative !important;
  overflow: hidden !important;
  margin-top: 12px !important;
}
.fmph-cta__orb {
  position: absolute;
  width: 400px; height: 400px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(91,62,245,.4) 0%, transparent 65%);
  top: -150px; left: 50%;
  transform: translateX(-50%);
  pointer-events: none;
}
.fmph-cta h2 {
  font-family: var(--h-fontd) !important;
  font-size: 1.9rem !important;
  font-weight: 800 !important;
  color: #fff !important;
  letter-spacing: -.03em !important;
  margin: 0 0 10px !important;
  padding: 0 !important;
  border: none !important;
  position: relative !important;
  z-index: 1 !important;
}
.fmph-cta p {
  color: rgba(255,255,255,.7) !important;
  font-size: .95rem !important;
  margin: 0 0 24px !important;
  position: relative !important;
  z-index: 1 !important;
}
.fmph-cta__btns { display: flex !important; gap: 12px !important; justify-content: center !important; position: relative !important; z-index: 1 !important; }

/* ── Empty ─────────────────────────────────────────────────── */
.fmph-empty {
  grid-column: 1/-1 !important;
  background: var(--h-surface) !important;
  border: 2px dashed rgba(91,62,245,.2) !important;
  border-radius: var(--h-rl) !important;
  padding: 48px !important;
  text-align: center !important;
  color: var(--h-400) !important;
}
.fmph-empty p { margin: 0 !important; font-size: .9rem !important; }
.fmph-empty a { color: var(--h-brand) !important; font-weight: 700 !important; text-decoration: none !important; }

/* ── Responsive ────────────────────────────────────────────── */
@media (max-width: 900px) {
  .fmph-job-grid, .fmph-fl-grid { grid-template-columns: repeat(2,1fr) !important; }
  .fmph-stats { grid-template-columns: repeat(2,1fr) !important; }
  .fmph-dash { grid-template-columns: 1fr !important; }
  .fmph-dash__side { display: none !important; }
}
@media (max-width: 600px) {
  .fmph-hero { padding: 44px 24px !important; }
  .fmph-hero__title { font-size: 1.9rem !important; }
  .fmph-job-grid, .fmph-fl-grid { grid-template-columns: 1fr !important; }
  .fmph-stats { grid-template-columns: repeat(2,1fr) !important; }
  .fmph-section__head { flex-direction: column !important; align-items: flex-start !important; gap: 10px !important; }
  .fmph-mini-stats { grid-template-columns: repeat(2,1fr) !important; }
  .fmph-cta { padding: 36px 24px !important; }
}
