/* ============================================
   EMPLOY JOBS PORTAL — employ.co.il Brand CSS
   Deep Navy · Fiery Orange · RTL Hebrew
   ============================================ */

@import url('https://fonts.googleapis.com/css2?family=Heebo:wght@300;400;500;600;700;800;900&display=swap');

:root {
  --navy:          #0b1f3a;
  --navy-mid:      #142d50;
  --navy-light:    #1e3f6e;
  --orange:        #e8420a;
  --orange-light:  #ff5722;
  --orange-glow:   #ff6b35;
  --orange-pale:   #fff3ee;
  --orange-border: #ffd5c5;
  --sky:           #1565c0;
  --sky-light:     #1e88e5;
  --teal:          #00897b;
  --green:         #2e7d32;
  --green-light:   #e8f5e9;
  --white:    #ffffff;
  --off:      #f7f9fc;
  --gray-50:  #f0f4f9;
  --gray-100: #e1e8f0;
  --gray-200: #c8d6e5;
  --gray-300: #a8bdd0;
  --gray-400: #7a9ab5;
  --gray-500: #5a7a95;
  --gray-600: #3d5a73;
  --gray-700: #2a3f55;
  --dark:     #0b1f3a;
  --radius-xs: 6px;
  --radius:    12px;
  --radius-md: 16px;
  --radius-lg: 24px;
  --shadow-sm: 0 2px 8px rgba(11,31,58,.08);
  --shadow:    0 4px 20px rgba(11,31,58,.10);
  --shadow-md: 0 8px 32px rgba(11,31,58,.12);
  --shadow-lg: 0 16px 48px rgba(11,31,58,.16);
  --shadow-xl: 0 32px 80px rgba(11,31,58,.20);
  --shadow-orange: 0 8px 28px rgba(232,66,10,.35);
  --font: 'Heebo', sans-serif;
  --ease: cubic-bezier(.4,0,.2,1);
  --t: all .22s var(--ease);
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

.employ-hero,.employ-jobs-page,.employ-employers-page,.employ-candidates-page,
.employ-packages-page,.employ-auth-page,.employ-post-job-page,.employ-dashboard,
.employ-categories-section,.employ-latest-jobs,.employ-cta-section,
.employ-single-job,.employ-restricted {
  font-family: var(--font);
  direction: rtl;
  text-align: right;
}

/* ── BUTTONS ── */
.employ-btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 7px;
  padding: 11px 24px; border-radius: var(--radius-xs); font-family: var(--font);
  font-size: 14px; font-weight: 700; cursor: pointer; border: 2px solid transparent;
  text-decoration: none !important; transition: var(--t); white-space: nowrap; line-height: 1.2;
}
.employ-btn-primary {
  background: linear-gradient(135deg, var(--orange) 0%, var(--orange-light) 100%);
  color: var(--white) !important;
  box-shadow: 0 4px 14px rgba(232,66,10,.3);
}
.employ-btn-primary:hover {
  background: linear-gradient(135deg,#c23500,var(--orange));
  transform: translateY(-2px); box-shadow: var(--shadow-orange); color: var(--white) !important;
}
.employ-btn-navy { background: var(--navy); color: var(--white) !important; }
.employ-btn-navy:hover { background: var(--navy-mid); transform: translateY(-2px); box-shadow: 0 6px 20px rgba(11,31,58,.35); }
.employ-btn-outline { background: transparent; border-color: var(--orange); color: var(--orange) !important; }
.employ-btn-outline:hover { background: var(--orange); color: var(--white) !important; box-shadow: var(--shadow-orange); }
.employ-btn-sm { padding: 7px 16px; font-size: 13px; }
.employ-btn-lg { padding: 15px 36px; font-size: 16px; }
.employ-btn-block { width: 100%; }
.employ-btn-danger { background: #c62828; color: #fff !important; }
.employ-btn-white { background: #fff; color: var(--orange) !important; font-weight: 700; }
.employ-btn-outline-white { background: transparent; border-color: rgba(255,255,255,.7); color: #fff !important; }
.employ-btn-outline-white:hover { background: rgba(255,255,255,.15); border-color: #fff; }

/* ── HERO ── */
.employ-hero {
  position: relative;
  background: linear-gradient(150deg, var(--navy) 0%, var(--navy-mid) 45%, var(--navy-light) 100%);
  padding: 88px 24px 72px; overflow: hidden; color: #fff; text-align: center;
}
.employ-hero::before {
  content: '';
  position: absolute; inset: 0;
  background:
    radial-gradient(ellipse 60% 50% at 80% 20%, rgba(232,66,10,.18) 0%, transparent 60%),
    radial-gradient(ellipse 40% 60% at 10% 80%, rgba(21,101,192,.25) 0%, transparent 55%);
  pointer-events: none;
}
.hero-bg-shapes { position: absolute; inset: 0; pointer-events: none; overflow: hidden; }
.shape { position: absolute; border-radius: 50%; }
.shape-1 { width: 600px; height: 600px; top: -250px; right: -150px; background: radial-gradient(circle,rgba(232,66,10,.12) 0%,transparent 70%); animation: shapePulse 8s ease-in-out infinite; }
.shape-2 { width: 400px; height: 400px; bottom: -180px; left: 5%; background: radial-gradient(circle,rgba(21,101,192,.15) 0%,transparent 70%); animation: shapePulse 10s ease-in-out infinite reverse; }
.shape-3 { width: 150px; height: 150px; top: 30%; left: 25%; background: rgba(255,255,255,.03); border: 1px solid rgba(255,255,255,.06); border-radius: var(--radius-md); animation: shapeFloat 12s ease-in-out infinite; }
.shape-4 { width: 80px; height: 80px; top: 15%; right: 30%; background: rgba(232,66,10,.15); border-radius: var(--radius); animation: shapeFloat 9s ease-in-out infinite 2s; }
@keyframes shapePulse { 0%,100%{transform:scale(1);opacity:1} 50%{transform:scale(1.08);opacity:.8} }
@keyframes shapeFloat { 0%,100%{transform:translateY(0) rotate(0deg)} 33%{transform:translateY(-18px) rotate(5deg)} 66%{transform:translateY(10px) rotate(-3deg)} }

.hero-content { position: relative; max-width: 820px; margin: 0 auto; }
.hero-eyebrow {
  display: inline-flex; align-items: center; gap: 8px;
  background: rgba(232,66,10,.2); border: 1px solid rgba(232,66,10,.4);
  border-radius: 50px; padding: 6px 18px; font-size: 13px; font-weight: 700;
  color: #ffa07a; margin-bottom: 24px; letter-spacing: .5px;
}
.hero-eyebrow::before { content: '🔥'; }
.hero-title { font-size: clamp(34px,7vw,62px); font-weight: 900; line-height: 1.12; margin-bottom: 18px; letter-spacing: -1.5px; }
.hero-highlight {
  background: linear-gradient(135deg, #ff8a50 0%, var(--orange) 50%, #c0392b 100%);
  -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text;
}
.hero-subtitle { font-size: 18px; color: rgba(255,255,255,.72); margin-bottom: 44px; font-weight: 400; line-height: 1.6; }

.hero-search-box {
  display: flex; gap: 6px; background: #fff; border-radius: var(--radius-md); padding: 6px;
  max-width: 720px; margin: 0 auto 32px; box-shadow: 0 20px 60px rgba(0,0,0,.25); flex-wrap: wrap;
}
.hero-search-box input, .hero-search-box select {
  flex: 1; min-width: 160px; border: none; outline: none; font-family: var(--font);
  font-size: 15px; font-weight: 500; padding: 12px 18px; background: transparent; color: var(--dark); direction: rtl;
}
.hero-search-box select { border-right: 1px solid var(--gray-100); border-left: 1px solid var(--gray-100); cursor: pointer; }
.hero-search-box .employ-btn { padding: 13px 28px; font-size: 15px; border-radius: 10px; flex-shrink: 0; }

.hero-quick-cats { display: flex; flex-wrap: wrap; gap: 10px; justify-content: center; margin-bottom: 44px; }
.quick-cat {
  padding: 8px 20px; border-radius: 50px; border: 1.5px solid rgba(255,255,255,.22);
  color: rgba(255,255,255,.88) !important; font-size: 13px; font-weight: 600; transition: var(--t);
  text-decoration: none !important; background: rgba(255,255,255,.06);
}
.quick-cat:hover { background: var(--orange); border-color: var(--orange); color: #fff !important; transform: translateY(-2px); box-shadow: var(--shadow-orange); }

.hero-stats { display: flex; justify-content: center; gap: 0; padding-top: 32px; border-top: 1px solid rgba(255,255,255,.12); flex-wrap: wrap; }
.hero-stat { text-align: center; padding: 0 36px; position: relative; }
.hero-stat:not(:last-child)::after { content:''; position:absolute; left:0; top:20%; height:60%; width:1px; background:rgba(255,255,255,.15); }
.hero-stat strong {
  display: block; font-size: 32px; font-weight: 900;
  background: linear-gradient(135deg,#ff8a50,var(--orange)); -webkit-background-clip: text;
  -webkit-text-fill-color: transparent; background-clip: text; margin-bottom: 4px;
}
.hero-stat span { font-size: 13px; color: rgba(255,255,255,.65); font-weight: 500; }

/* ── SECTIONS ── */
.employ-categories-section { padding: 72px 24px; max-width: 1280px; margin: 0 auto; }
.employ-latest-jobs { padding: 0 24px 72px; max-width: 1280px; margin: 0 auto; }

.section-header { display: flex; align-items: flex-end; justify-content: space-between; margin-bottom: 40px; flex-wrap: wrap; gap: 12px; }
.section-tag { display: inline-block; background: var(--orange-pale); color: var(--orange); font-size: 12px; font-weight: 700; padding: 4px 12px; border-radius: 4px; margin-bottom: 8px; letter-spacing: .5px; text-transform: uppercase; }
.section-header h2 { font-size: clamp(22px,4vw,32px); font-weight: 900; color: var(--dark); letter-spacing: -.5px; line-height: 1.2; }
.section-header p { color: var(--gray-400); font-size: 15px; margin-top: 6px; }
.view-all { color: var(--orange); font-weight: 700; text-decoration: none; font-size: 14px; display: flex; align-items: center; gap: 6px; white-space: nowrap; transition: var(--t); }
.view-all:hover { gap: 10px; }

/* ── CATEGORIES GRID ── */
.categories-grid { display: grid; grid-template-columns: repeat(auto-fill,minmax(155px,1fr)); gap: 14px; }
.category-card {
  display: flex; flex-direction: column; align-items: center; gap: 10px; padding: 28px 16px 22px;
  background: var(--white); border: 2px solid var(--gray-100); border-radius: var(--radius-md);
  text-decoration: none !important; transition: var(--t); cursor: pointer; position: relative; overflow: hidden;
}
.category-card::before {
  content:''; position:absolute; inset:0;
  background: linear-gradient(135deg, var(--orange) 0%, var(--orange-light) 100%);
  opacity: 0; transition: var(--t);
}
.category-card:hover { border-color: var(--orange); box-shadow: var(--shadow-md); transform: translateY(-4px); }
.category-card:hover::before { opacity: 1; }
.cat-icon { font-size: 34px; position: relative; transition: var(--t); }
.cat-name { font-size: 13px; font-weight: 700; color: var(--dark); text-align: center; position: relative; transition: var(--t); }
.cat-count { font-size: 12px; color: var(--gray-400); position: relative; transition: var(--t); }
.category-card:hover .cat-name { color: #fff; }
.category-card:hover .cat-count { color: rgba(255,255,255,.8); }

/* ── JOB CARDS ── */
.jobs-grid { display: grid; grid-template-columns: repeat(auto-fill,minmax(310px,1fr)); gap: 20px; }
.employ-job-card {
  background: var(--white); border: 2px solid var(--gray-100); border-radius: var(--radius-md);
  padding: 22px; transition: var(--t); display: flex; flex-direction: column; gap: 14px;
  position: relative; overflow: hidden;
}
.employ-job-card::after {
  content:''; position:absolute; bottom:0; right:0; left:0; height:3px;
  background: linear-gradient(90deg,var(--orange),var(--sky-light));
  transform: scaleX(0); transform-origin: right; transition: transform .3s var(--ease);
}
.employ-job-card:hover { border-color: var(--orange-border); box-shadow: var(--shadow-md); transform: translateY(-3px); }
.employ-job-card:hover::after { transform: scaleX(1); }
.job-card-header { display: flex; align-items: flex-start; gap: 14px; }
.job-company-logo {
  width: 52px; height: 52px; border-radius: var(--radius);
  background: linear-gradient(135deg, var(--navy) 0%, var(--navy-light) 100%);
  display: flex; align-items: center; justify-content: center;
  font-size: 22px; font-weight: 900; color: #fff; flex-shrink: 0; box-shadow: 0 4px 12px rgba(11,31,58,.2);
}
.job-info { flex: 1; min-width: 0; }
.job-title { font-size: 16px; font-weight: 800; margin-bottom: 5px; line-height: 1.3; }
.job-title a { color: var(--dark) !important; text-decoration: none !important; transition: var(--t); }
.job-title a:hover { color: var(--orange) !important; }
.job-company { font-size: 13px; color: var(--gray-400); font-weight: 500; }
.job-meta { display: flex; flex-wrap: wrap; gap: 7px; }
.job-tag { padding: 5px 12px; border-radius: 50px; font-size: 12px; font-weight: 600; display: inline-flex; align-items: center; gap: 4px; }
.tag-region { background: #e3f2fd; color: #1565c0; }
.tag-type   { background: #e8f5e9; color: #2e7d32; }
.tag-cat    { background: var(--orange-pale); color: var(--orange); }
.job-salary { font-size: 14px; font-weight: 700; color: var(--teal); }
.employ-job-card .employ-btn { align-self: flex-start; margin-top: auto; }

/* ── CTA SECTION ── */
.employ-cta-section { display: grid; grid-template-columns: 1fr 1fr; margin: 0 24px 72px; border-radius: var(--radius-lg); overflow: hidden; box-shadow: var(--shadow-xl); }
.cta-employers {
  background: linear-gradient(145deg, var(--navy) 0%, var(--navy-mid) 50%, #1a3a7a 100%);
  padding: 60px 48px; text-align: center; position: relative; overflow: hidden;
}
.cta-employers::before { content:''; position:absolute; top:-60px; right:-60px; width:200px; height:200px; border-radius:50%; background:rgba(255,255,255,.04); }
.cta-candidates {
  background: linear-gradient(145deg, var(--orange) 0%, #c0392b 50%, #922b21 100%);
  padding: 60px 48px; text-align: center; position: relative; overflow: hidden;
}
.cta-candidates::before { content:''; position:absolute; bottom:-60px; left:-60px; width:200px; height:200px; border-radius:50%; background:rgba(255,255,255,.06); }
.cta-employers h3, .cta-candidates h3 { font-size: 26px; font-weight: 900; color: #fff; margin-bottom: 12px; position: relative; }
.cta-employers p, .cta-candidates p { color: rgba(255,255,255,.8); margin-bottom: 28px; font-size: 15px; line-height: 1.6; position: relative; }
.cta-employers .employ-btn, .cta-candidates .employ-btn { position: relative; }

/* ── JOBS PAGE ── */
.employ-jobs-page { display: grid; grid-template-columns: 290px 1fr; gap: 32px; max-width: 1280px; margin: 40px auto; padding: 0 24px; align-items: start; }
.jobs-filter-sidebar { background: var(--white); border: 2px solid var(--gray-100); border-radius: var(--radius-md); padding: 28px; position: sticky; top: 24px; box-shadow: var(--shadow-sm); }
.jobs-filter-sidebar h3 { font-size: 17px; font-weight: 800; margin-bottom: 24px; color: var(--dark); padding-bottom: 14px; border-bottom: 2px solid var(--gray-100); }
.filter-group { margin-bottom: 20px; }
.filter-group label { display: block; font-size: 12px; font-weight: 700; color: var(--gray-500); margin-bottom: 7px; text-transform: uppercase; letter-spacing: .5px; }
.filter-group input, .filter-group select {
  width: 100%; padding: 11px 14px; border: 2px solid var(--gray-100); border-radius: var(--radius-xs);
  font-family: var(--font); font-size: 14px; font-weight: 500; outline: none; transition: var(--t);
  direction: rtl; color: var(--dark); background: var(--off);
}
.filter-group input:focus, .filter-group select:focus { border-color: var(--orange); background: #fff; box-shadow: 0 0 0 3px rgba(232,66,10,.1); }
.jobs-main-content { min-height: 500px; }
.jobs-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 24px; flex-wrap: wrap; gap: 12px; }
.jobs-header h2 { font-size: 24px; font-weight: 800; color: var(--dark); }
.jobs-count { color: var(--gray-400); font-size: 14px; background: var(--gray-50); padding: 6px 14px; border-radius: 50px; font-weight: 600; }
.employ-no-results { text-align: center; padding: 80px 40px; color: var(--gray-400); }
.employ-pagination { display: flex; gap: 8px; justify-content: center; margin-top: 40px; flex-wrap: wrap; }
.employ-pagination button { width: 40px; height: 40px; border-radius: var(--radius-xs); border: 2px solid var(--gray-100); background: #fff; cursor: pointer; font-family: var(--font); font-size: 14px; font-weight: 700; transition: var(--t); color: var(--gray-600); }
.employ-pagination button.active, .employ-pagination button:hover { background: var(--orange); color: #fff; border-color: var(--orange); transform: translateY(-2px); box-shadow: var(--shadow-orange); }

/* ── PAGE HERO MINI ── */
.page-hero-mini {
  background: linear-gradient(150deg, var(--navy) 0%, var(--navy-mid) 60%, var(--navy-light) 100%);
  color: #fff; text-align: center; padding: 64px 24px; margin-bottom: 52px; position: relative; overflow: hidden;
}
.page-hero-mini::before { content:''; position:absolute; inset:0; background:radial-gradient(ellipse 50% 80% at 90% 50%,rgba(232,66,10,.15) 0%,transparent 60%); }
.page-hero-mini h1 { font-size: clamp(28px,5vw,44px); font-weight: 900; margin-bottom: 12px; position: relative; letter-spacing: -1px; }
.page-hero-mini p { font-size: 16px; color: rgba(255,255,255,.7); position: relative; }

/* ── EMPLOYERS / CANDIDATES ── */
.employ-employers-page, .employ-candidates-page { max-width: 1280px; margin: 0 auto; padding: 0 24px; }
.employers-grid, .candidates-grid { display: grid; grid-template-columns: repeat(auto-fill,minmax(260px,1fr)); gap: 24px; margin-bottom: 72px; }
.employer-card, .candidate-card {
  background: #fff; border: 2px solid var(--gray-100); border-radius: var(--radius-md);
  padding: 32px 24px; text-align: center; transition: var(--t); position: relative; overflow: hidden;
}
.employer-card::after, .candidate-card::after {
  content:''; position:absolute; top:0; right:0; left:0; height:4px;
  background: linear-gradient(90deg,var(--orange),var(--sky-light));
  transform: scaleX(0); transition: transform .3s var(--ease);
}
.employer-card:hover, .candidate-card:hover { border-color: var(--orange-border); box-shadow: var(--shadow-md); transform: translateY(-4px); }
.employer-card:hover::after, .candidate-card:hover::after { transform: scaleX(1); }
.employer-logo, .candidate-avatar {
  width: 76px; height: 76px; border-radius: 50%;
  background: linear-gradient(135deg, var(--navy) 0%, var(--navy-light) 100%);
  display: flex; align-items: center; justify-content: center;
  font-size: 30px; font-weight: 900; color: #fff; margin: 0 auto 18px; box-shadow: 0 8px 24px rgba(11,31,58,.2);
}
.employer-card h3, .candidate-card h3 { font-size: 18px; font-weight: 800; margin-bottom: 8px; color: var(--dark); }
.employer-card p, .candidate-card p { font-size: 14px; color: var(--gray-400); margin-bottom: 14px; line-height: 1.6; }
.employer-jobs-count { display: inline-block; background: var(--orange-pale); color: var(--orange); padding: 5px 14px; border-radius: 50px; font-size: 13px; font-weight: 700; margin-bottom: 16px; }

/* ── AUTH ── */
.employ-auth-page {
  min-height: 80vh; display: flex; align-items: center; justify-content: center;
  padding: 48px 20px; background: linear-gradient(150deg, var(--gray-50) 0%, #e8eef7 100%);
}
.auth-card {
  background: #fff; border-radius: var(--radius-lg); padding: 52px 44px; width: 100%;
  max-width: 480px; box-shadow: var(--shadow-xl); border: 2px solid var(--gray-100); position: relative; overflow: hidden;
}
.auth-card::before { content:''; position:absolute; top:0; right:0; left:0; height:5px; background:linear-gradient(90deg,var(--orange),var(--orange-light),var(--sky-light)); }
.auth-card-wide { max-width: 580px; }
.auth-logo { text-align: center; margin-bottom: 36px; }
.auth-logo h2 { font-size: 26px; font-weight: 900; color: var(--dark); margin-bottom: 6px; }
.auth-logo p { color: var(--gray-400); font-size: 15px; }
.auth-switch { text-align: center; margin-top: 18px; font-size: 14px; color: var(--gray-500); }
.auth-switch a { color: var(--orange); font-weight: 700; text-decoration: none; }
.role-selector { display: flex; gap: 12px; margin-bottom: 30px; }
.role-btn { flex: 1; padding: 16px; border: 2px solid var(--gray-100); border-radius: var(--radius); background: var(--off); font-family: var(--font); font-size: 14px; font-weight: 700; cursor: pointer; transition: var(--t); color: var(--gray-600); }
.role-btn.active { border-color: var(--orange); background: var(--orange-pale); color: var(--orange); box-shadow: 0 4px 12px rgba(232,66,10,.15); }

/* ── FORMS ── */
.employ-form { display: flex; flex-direction: column; gap: 18px; }
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.form-group { display: flex; flex-direction: column; gap: 7px; }
.form-group label { font-size: 13px; font-weight: 700; color: var(--gray-600); }
.form-group input, .form-group select, .form-group textarea {
  padding: 13px 16px; border: 2px solid var(--gray-100); border-radius: var(--radius-xs);
  font-family: var(--font); font-size: 15px; font-weight: 500; outline: none; transition: var(--t);
  direction: rtl; color: var(--dark); background: var(--off);
}
.form-group textarea { resize: vertical; min-height: 150px; }
.form-group input:focus, .form-group select:focus, .form-group textarea:focus { border-color: var(--orange); background: #fff; box-shadow: 0 0 0 3px rgba(232,66,10,.1); }

/* ── POST JOB PAGE ── */
.employ-post-job-page { max-width: 820px; margin: 0 auto; padding: 0 24px 72px; }
.post-job-form-wrap { background: #fff; border: 2px solid var(--gray-100); border-radius: var(--radius-lg); padding: 44px; box-shadow: var(--shadow-md); position: relative; overflow: hidden; }
.post-job-form-wrap::before { content:''; position:absolute; top:0; right:0; left:0; height:5px; background:linear-gradient(90deg,var(--orange),var(--orange-light),var(--sky-light)); }

/* ── PACKAGES ── */
.employ-packages-page { max-width: 1100px; margin: 0 auto; padding: 0 24px 72px; }
.packages-grid { display: grid; grid-template-columns: repeat(auto-fit,minmax(300px,1fr)); gap: 28px; margin-bottom: 48px; }
.package-card { background: #fff; border: 2px solid var(--gray-100); border-radius: var(--radius-lg); overflow: hidden; transition: var(--t); position: relative; }
.package-card:hover { box-shadow: var(--shadow-lg); transform: translateY(-6px); }
.package-card.recommended { border-color: var(--orange); box-shadow: 0 0 0 4px rgba(232,66,10,.1),var(--shadow-md); }
.recommended-badge { position:absolute; top:20px; left:20px; background:linear-gradient(135deg,#f59e0b,#e8420a); color:#fff; font-size:11px; font-weight:800; padding:5px 14px; border-radius:50px; letter-spacing:.5px; text-transform:uppercase; box-shadow:0 4px 12px rgba(232,66,10,.4); }
.package-header { padding: 36px 28px 28px; text-align: center; color: #fff; }
.package-header h3 { font-size: 13px; font-weight: 800; letter-spacing: 1.5px; text-transform: uppercase; opacity: .85; margin-bottom: 20px; }
.package-price { display: flex; align-items: baseline; justify-content: center; gap: 4px; margin-bottom: 8px; }
.price-amount { font-size: 54px; font-weight: 900; line-height: 1; }
.price-currency { font-size: 22px; font-weight: 700; }
.package-header > p { font-size: 13px; opacity: .75; }
.package-features { padding: 28px 28px 0; }
.package-features ul { list-style: none; display: flex; flex-direction: column; gap: 12px; margin-bottom: 28px; }
.package-features li { font-size: 14px; color: var(--gray-700); padding: 8px 0; border-bottom: 1px solid var(--gray-50); display: flex; align-items: center; gap: 10px; }
.package-features li::before { content: '✓'; color: var(--teal); font-weight: 900; flex-shrink: 0; }
.package-card .employ-btn { width: calc(100% - 56px); margin: 0 28px 28px; }

/* ── DASHBOARD ── */
.employ-dashboard { max-width: 1100px; margin: 40px auto; padding: 0 24px 72px; }
.dashboard-header {
  display: flex; align-items: center; gap: 20px;
  background: linear-gradient(150deg, var(--navy) 0%, var(--navy-light) 100%);
  border-radius: var(--radius-lg); padding: 28px 32px; margin-bottom: 28px; color: #fff; position: relative; overflow: hidden;
}
.dashboard-header::before { content:''; position:absolute; left:-40px; top:-40px; width:180px; height:180px; border-radius:50%; background:rgba(255,255,255,.04); }
.dashboard-avatar {
  width: 68px; height: 68px; border-radius: 50%;
  background: linear-gradient(135deg, var(--orange), var(--orange-light));
  display: flex; align-items: center; justify-content: center; font-size: 26px; font-weight: 900; color: #fff; flex-shrink: 0; position: relative; box-shadow: 0 6px 20px rgba(232,66,10,.4);
}
.dashboard-user-info { flex: 1; position: relative; }
.dashboard-user-info h2 { font-size: 22px; font-weight: 800; color: #fff; margin-bottom: 4px; }
.dashboard-user-info p { color: rgba(255,255,255,.65); font-size: 14px; }
.dashboard-header .employ-btn { position: relative; flex-shrink: 0; }

.dashboard-stats { display: grid; grid-template-columns: repeat(auto-fit,minmax(190px,1fr)); gap: 16px; margin-bottom: 28px; }
.stat-card { background: #fff; border: 2px solid var(--gray-100); border-radius: var(--radius-md); padding: 26px 20px; text-align: center; transition: var(--t); position: relative; overflow: hidden; }
.stat-card:hover { box-shadow: var(--shadow-md); transform: translateY(-2px); }
.stat-card.stat-highlight { border-color: var(--orange-border); background: var(--orange-pale); }
.stat-card::after { content:''; position:absolute; bottom:0; right:0; left:0; height:3px; background:linear-gradient(90deg,var(--orange),var(--sky-light)); }
.stat-number { display: block; font-size: 40px; font-weight: 900; color: var(--navy); line-height: 1.1; margin-bottom: 6px; }
.stat-card.stat-highlight .stat-number { color: var(--orange); }
.stat-label { font-size: 13px; color: var(--gray-400); font-weight: 600; }

.package-status { display: flex; align-items: center; gap: 16px; background: #f0fdf4; border: 2px solid #86efac; border-radius: var(--radius); padding: 16px 22px; margin-bottom: 28px; flex-wrap: wrap; }
.package-status strong { color: #166534; font-size: 15px; }
.package-status span { color: var(--gray-600); font-size: 13px; }
.package-alert { background: #fff7ed; border: 2px solid var(--orange-border); border-radius: var(--radius); padding: 16px 22px; margin-bottom: 28px; font-size: 14px; }
.package-alert a { color: var(--orange); font-weight: 700; text-decoration: none; }

.dashboard-tabs { display: flex; gap: 4px; background: var(--gray-50); border: 2px solid var(--gray-100); border-radius: var(--radius); padding: 5px; margin-bottom: 28px; }
.tab-btn { flex: 1; padding: 11px 18px; border: none; border-radius: var(--radius-xs); background: transparent; font-family: var(--font); font-size: 14px; font-weight: 700; color: var(--gray-500); cursor: pointer; transition: var(--t); }
.tab-btn.active { background: #fff; color: var(--orange); box-shadow: var(--shadow-sm); }
.tab-btn:hover:not(.active) { color: var(--dark); background: var(--gray-100); }
.tab-content.hidden { display: none; }

.admin-job-row { display: flex; align-items: center; justify-content: space-between; gap: 16px; padding: 18px 20px; background: #fff; border: 2px solid var(--gray-100); border-radius: var(--radius); margin-bottom: 10px; transition: var(--t); flex-wrap: wrap; }
.admin-job-row:hover { border-color: var(--orange-border); box-shadow: var(--shadow-sm); }
.admin-job-info h4 { font-size: 15px; font-weight: 700; margin-bottom: 4px; }
.admin-job-info h4 a { color: var(--dark) !important; text-decoration: none !important; }
.admin-job-info h4 a:hover { color: var(--orange) !important; }
.admin-job-info span { font-size: 12px; color: var(--gray-400); }
.admin-job-actions { display: flex; gap: 8px; align-items: center; flex-wrap: wrap; }
.app-count { background: var(--orange-pale); color: var(--orange); padding: 5px 14px; border-radius: 50px; font-size: 13px; font-weight: 700; }

.application-card { background: #fff; border: 2px solid var(--gray-100); border-radius: var(--radius-md); padding: 22px; margin-bottom: 14px; transition: var(--t); }
.application-card:hover { border-color: var(--orange-border); box-shadow: var(--shadow-sm); }
.applicant-info { display: flex; gap: 16px; margin-bottom: 16px; }
.applicant-avatar { width: 52px; height: 52px; border-radius: 50%; background: linear-gradient(135deg,var(--teal),var(--sky-light)); display: flex; align-items: center; justify-content: center; font-size: 20px; font-weight: 800; color: #fff; flex-shrink: 0; }
.applicant-info h4 { font-size: 16px; font-weight: 800; margin-bottom: 4px; color: var(--dark); }
.applicant-info p { font-size: 13px; color: var(--gray-400); margin-bottom: 3px; }
.job-ref { color: var(--orange) !important; font-weight: 700; font-size: 12px !important; }
.cover-letter { background: var(--off); border-right: 3px solid var(--orange); border-radius: 0 var(--radius-xs) var(--radius-xs) 0; padding: 14px 18px; margin-bottom: 16px; font-size: 14px; color: var(--gray-700); line-height: 1.7; }
.app-actions { display: flex; align-items: center; gap: 12px; flex-wrap: wrap; }
.app-status { padding: 6px 16px; border-radius: 50px; font-size: 12px; font-weight: 700; }
.status-pending   { background: #fff8e1; color: #e65100; }
.status-reviewed  { background: #e3f2fd; color: #1565c0; }
.status-interview { background: #e8f5e9; color: #2e7d32; }
.status-accepted  { background: #e8f5e9; color: #1b5e20; }
.status-rejected  { background: #fce4ec; color: #b71c1c; }
.status-select { padding: 7px 14px; border: 2px solid var(--gray-100); border-radius: var(--radius-xs); font-family: var(--font); font-size: 13px; font-weight: 600; outline: none; cursor: pointer; direction: rtl; background: var(--off); transition: var(--t); }
.status-select:focus { border-color: var(--orange); }

.app-job-info h4 a { color: var(--dark) !important; text-decoration: none !important; font-weight: 800; }
.app-job-info h4 a:hover { color: var(--orange) !important; }
.app-date { font-size: 12px !important; color: var(--gray-300) !important; }

.resume-section { max-width: 520px; }
.resume-current { background: #e8f5e9; border: 2px solid #a5d6a7; border-radius: var(--radius); padding: 20px 24px; margin-bottom: 24px; display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 12px; }
.resume-current p { color: var(--green); font-weight: 700; }
.resume-upload h3 { font-size: 18px; font-weight: 800; margin-bottom: 8px; color: var(--dark); }
.resume-upload > p { color: var(--gray-400); font-size: 14px; margin-bottom: 18px; }
.resume-upload input[type="file"] { display: block; margin-bottom: 14px; font-family: var(--font); font-size: 14px; color: var(--gray-600); }

/* Messages */
#profile-message,#login-message,#register-message,#job-post-message,#purchase-message,#upload-message {
  margin-top: 14px; padding: 13px 18px; border-radius: var(--radius-xs); font-size: 14px; font-weight: 600; display: none; border-right: 4px solid;
}
.message-success { background: #e8f5e9; color: #2e7d32; border-right-color: #2e7d32; display: flex !important; align-items: center; gap: 8px; }
.message-error   { background: #fce4ec; color: #b71c1c; border-right-color: #b71c1c; display: flex !important; align-items: center; gap: 8px; }

.employ-empty { text-align: center; padding: 60px 40px; color: var(--gray-400); font-size: 16px; }
.employ-empty a { color: var(--orange); font-weight: 700; text-decoration: none; }
.employ-restricted { text-align: center; padding: 72px 24px; color: var(--gray-500); font-size: 15px; }
.employ-restricted a { color: var(--orange); font-weight: 700; text-decoration: none; }

/* ── RESPONSIVE ── */
@media (max-width: 1024px) { .employ-jobs-page { grid-template-columns: 260px 1fr; gap: 24px; } }
@media (max-width: 768px) {
  .employ-jobs-page { grid-template-columns: 1fr; }
  .jobs-filter-sidebar { position: static; }
  .employ-cta-section { grid-template-columns: 1fr; }
  .cta-employers, .cta-candidates { padding: 44px 28px; }
  .form-row { grid-template-columns: 1fr; }
  .auth-card { padding: 36px 24px; }
  .post-job-form-wrap { padding: 28px 20px; }
  .packages-grid { grid-template-columns: 1fr; max-width: 400px; margin: 0 auto 48px; }
  .hero-search-box { flex-direction: column; }
  .dashboard-header { flex-wrap: wrap; }
}
@media (max-width: 480px) {
  .employ-hero { padding: 64px 16px 52px; }
  .hero-stats { flex-direction: column; gap: 16px; padding-top: 24px; }
  .hero-stat::after { display: none; }
  .categories-grid { grid-template-columns: repeat(3,1fr); gap: 10px; }
  .category-card { padding: 18px 10px 14px; }
  .cat-icon { font-size: 26px; }
  .cat-name { font-size: 11px; }
  .jobs-grid { grid-template-columns: 1fr; }
}
