/* ═══════════════════════════════════════════════════════════
   Wuzaf Jobs PRO — Stylesheet v8
   RTL · Arabic · Mobile-first
   ═══════════════════════════════════════════════════════════ */
:root {
  --wz-primary: #2563eb; --wz-primary-dk: #1d4ed8; --wz-primary-lt: #eff6ff;
  --wz-success: #16a34a; --wz-success-lt: #f0fdf4;
  --wz-warning: #d97706; --wz-warning-lt: #fffbeb;
  --wz-danger: #dc2626;  --wz-danger-lt: #fef2f2;
  --wz-info: #0891b2;    --wz-info-lt: #ecfeff;
  --wz-purple: #7c3aed;  --wz-purple-lt: #f5f3ff;
  --wz-border: #e5e7eb; --wz-border-dk: #d1d5db;
  --wz-bg: #f9fafb; --wz-card: #fff; --wz-card-hover: #f8faff;
  --wz-text: #111827; --wz-text-sm: #6b7280; --wz-text-xs: #9ca3af;
  --wz-radius: 12px; --wz-radius-sm: 7px; --wz-radius-lg: 16px;
  --wz-shadow: 0 1px 3px rgba(0,0,0,.07),0 1px 2px rgba(0,0,0,.04);
  --wz-shadow-md: 0 4px 16px rgba(0,0,0,.09);
  --wz-shadow-lg: 0 8px 32px rgba(0,0,0,.12);
  --wz-font: system-ui,-apple-system,'Segoe UI',sans-serif;
}

/* ── Base ── */
[dir="rtl"], .wz-jobs-page, .wz-dash-page, .wz-job-detail-page,
.wz-auth-page, .wz-page, .wz-companies-page {
  direction: rtl; font-family: var(--wz-font); color: var(--wz-text);
}
.wz-page { max-width: 920px; margin: 0 auto; padding: 28px 16px; }

/* ── Alerts ── */
.wz-alert { display: flex; align-items: flex-start; gap: 10px; padding: 12px 16px; border-radius: var(--wz-radius-sm); margin-bottom: 16px; font-size: .9em; }
.wz-alert p, .wz-alert > * { margin: 0; }
.wz-alert > span { flex-shrink: 0; font-weight: 700; }
.wz-alert--error   { background: var(--wz-danger-lt);  border: 1px solid #fecaca; color: #991b1b; }
.wz-alert--success { background: var(--wz-success-lt); border: 1px solid #bbf7d0; color: #166534; }
.wz-alert--info    { background: var(--wz-primary-lt); border: 1px solid #bfdbfe; color: #1e40af; }
.wz-alert--warning { background: var(--wz-warning-lt); border: 1px solid #fde68a; color: #92400e; }

/* ── Buttons ── */
.wz-btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 6px;
  padding: 9px 20px; border-radius: var(--wz-radius-sm); font-size: .9em;
  font-weight: 600; cursor: pointer; text-decoration: none; border: none;
  transition: all .15s; line-height: 1.3; white-space: nowrap;
}
.wz-btn--primary  { background: var(--wz-primary); color: #fff; }
.wz-btn--primary:hover { background: var(--wz-primary-dk); color: #fff; }
.wz-btn--outline  { background: transparent; color: var(--wz-primary); border: 1.5px solid var(--wz-primary); }
.wz-btn--outline:hover { background: var(--wz-primary-lt); }
.wz-btn--ghost    { background: transparent; color: var(--wz-text-sm); border: 1.5px solid var(--wz-border); }
.wz-btn--ghost:hover { background: var(--wz-bg); }
.wz-btn--success  { background: var(--wz-success); color: #fff; }
.wz-btn--danger   { background: var(--wz-danger); color: #fff; }
.wz-btn--info     { background: var(--wz-info); color: #fff; }
.wz-btn--applied  { background: var(--wz-success-lt); color: var(--wz-success); border: 1px solid #bbf7d0; cursor: default; }
.wz-btn--block    { width: 100%; }
.wz-btn--sm       { padding: 5px 13px; font-size: .82em; }
.wz-btn--lg       { padding: 12px 28px; font-size: .97em; }
.wz-btn--icon     { padding: 7px 11px; gap: 4px; font-size: .82em; border: 1.5px solid var(--wz-border); background: #fff; color: var(--wz-text-sm); }
.wz-btn--icon:hover, .wz-btn--icon.is-saved { border-color: var(--wz-primary); color: var(--wz-primary); background: var(--wz-primary-lt); }
.wz-btn--search   { padding: 10px 22px; }
.wz-btn--danger.wz-btn--ghost { color: var(--wz-danger); border-color: #fecaca; }
.wz-btn--danger.wz-btn--ghost:hover { background: var(--wz-danger-lt); }

/* ── Badges ── */
.wz-badge { display: inline-block; padding: 3px 10px; border-radius: 20px; font-size: .73em; font-weight: 700; }
.wz-badge--employer  { background: #dbeafe; color: #1e40af; }
.wz-badge--jobseeker { background: #dcfce7; color: #166534; }
.wz-badge--company   { background: #f3f4f6; color: #374151; }
.wz-badge--admin     { background: #fce7f3; color: #9d174d; }
.wz-badge--success   { background: #dcfce7; color: #166534; }
.wz-badge--warning   { background: #fef9c3; color: #854d0e; }
.wz-badge--error     { background: #fee2e2; color: #991b1b; }
.wz-badge--info      { background: #cffafe; color: #164e63; }
.wz-badge--purple    { background: #ede9fe; color: #5b21b6; }
.wz-badge--muted     { background: #f3f4f6; color: #6b7280; }
.wz-badge--xs        { font-size: .65em; padding: 2px 7px; }
.wz-verified-badge   { display: inline-flex; align-items: center; gap: 2px; background: var(--wz-primary); color: #fff; border-radius: 20px; padding: 2px 7px; font-size: .7em; font-weight: 700; }
.wz-verified-badge--lg { font-size: .8em; padding: 3px 10px; }

/* ── Avatar ── */
.wz-avatar {
  display: inline-flex; align-items: center; justify-content: center;
  flex-shrink: 0; overflow: hidden; color: #fff; font-weight: 800;
}

/* ── Forms ── */
.wz-form { direction: rtl; }
.wz-form__grid { display: grid; gap: 14px; margin-bottom: 4px; }
.wz-form__grid--2 { grid-template-columns: 1fr 1fr; }
.wz-form__grid--3 { grid-template-columns: 1fr 1fr 1fr; }
@media(max-width:640px) { .wz-form__grid--2, .wz-form__grid--3 { grid-template-columns: 1fr; } }
.wz-form__field { display: flex; flex-direction: column; gap: 5px; margin-bottom: 14px; }
.wz-form__field label { font-size: .875em; font-weight: 600; color: var(--wz-text); }
.wz-form__field input, .wz-form__field select, .wz-form__field textarea {
  padding: 9px 12px; border: 1.5px solid var(--wz-border); border-radius: var(--wz-radius-sm);
  font-size: .93em; width: 100%; box-sizing: border-box; background: #fff;
  transition: border-color .15s, box-shadow .15s; font-family: var(--wz-font);
}
.wz-form__field input:focus, .wz-form__field select:focus, .wz-form__field textarea:focus {
  outline: none; border-color: var(--wz-primary); box-shadow: 0 0 0 3px rgba(37,99,235,.1);
}
.wz-form__hint { font-size: .78em; color: var(--wz-text-sm); }
.wz-form__row-split { display: flex; justify-content: space-between; align-items: center; margin-bottom: 14px; }
.wz-form__actions { display: flex; gap: 12px; margin-top: 8px; }
.wz-form-section { border: 1px solid var(--wz-border); border-radius: var(--wz-radius); padding: 20px 22px; margin-bottom: 18px; background: var(--wz-card); }
.wz-form-section__head { font-size: .92em; font-weight: 700; color: var(--wz-text); margin-bottom: 16px; padding-bottom: 10px; border-bottom: 2px solid var(--wz-primary); display: flex; align-items: center; gap: 10px; }
.wz-step-num { background: var(--wz-primary); color: #fff; width: 24px; height: 24px; border-radius: 50%; display: inline-flex; align-items: center; justify-content: center; font-size: .78em; font-weight: 800; flex-shrink: 0; }
.wz-req { color: var(--wz-danger); }
.wz-check { display: flex; align-items: center; gap: 7px; cursor: pointer; font-size: .9em; }
.wz-link { color: var(--wz-primary); text-decoration: none; } .wz-link:hover { text-decoration: underline; }
.wz-link-sm { font-size: .85em; color: var(--wz-primary); text-decoration: none; }
.wz-text-muted { color: var(--wz-text-sm); } .wz-text-sm { font-size: .85em; }
.wz-text-green { color: var(--wz-success); font-weight: 600; }
.wz-text-center { text-align: center; }

/* ── Auth ── */
.wz-auth-page { max-width: 580px; margin: 0 auto; padding: 32px 16px; }
.wz-auth-box { background: var(--wz-card); border: 1px solid var(--wz-border); border-radius: var(--wz-radius-lg); padding: 36px 32px; box-shadow: var(--wz-shadow-md); }
.wz-auth-box--sm { max-width: 440px; margin: 0 auto; }
.wz-auth-box__head { text-align: center; margin-bottom: 24px; }
.wz-auth-box__icon { font-size: 2.4em; display: block; width: 68px; height: 68px; border-radius: 50%; background: var(--wz-primary-lt); display: flex; align-items: center; justify-content: center; margin: 0 auto 14px; }
.wz-auth-box__head h1 { font-size: 1.45em; font-weight: 800; margin: 0 0 6px; }
.wz-auth-box__head p  { color: var(--wz-text-sm); margin: 0; font-size: .9em; }
.wz-auth-box__switch  { text-align: center; margin-top: 18px; color: var(--wz-text-sm); font-size: .88em; }
.wz-auth-box__alts    { display: flex; gap: 10px; margin-top: 18px; }
.wz-auth-alt-btn      { flex: 1; text-align: center; padding: 10px; border-radius: var(--wz-radius-sm); background: var(--wz-bg); border: 1.5px solid var(--wz-border); text-decoration: none; color: var(--wz-text); font-size: .88em; font-weight: 600; transition: all .15s; }
.wz-auth-alt-btn:hover { border-color: var(--wz-primary); color: var(--wz-primary); background: var(--wz-primary-lt); }

/* ── Content Card ── */
.wz-content-card { background: var(--wz-card); border: 1px solid var(--wz-border); border-radius: var(--wz-radius); padding: 24px; box-shadow: var(--wz-shadow); }
.wz-content-card__header { margin-bottom: 20px; padding-bottom: 14px; border-bottom: 1px solid var(--wz-border); }
.wz-content-card__header h1, .wz-content-card__header h2 { margin: 0 0 5px; }
.wz-content-card__header p { margin: 0; color: var(--wz-text-sm); font-size: .9em; }
.wz-post-job-card { background: var(--wz-card); border: 1px solid var(--wz-border); border-radius: var(--wz-radius); padding: 28px; box-shadow: var(--wz-shadow); max-width: 900px; margin: 0 auto; }
.wz-post-job-card__header { margin-bottom: 22px; padding-bottom: 14px; border-bottom: 1px solid var(--wz-border); }

/* ── Jobs Page ── */
.wz-jobs-page { max-width: 1140px; margin: 0 auto; padding: 24px 16px; font-family: var(--wz-font); }

/* Hero Bar */
.wz-hero-bar { background: linear-gradient(135deg, #1e3a8a 0%, #2563eb 55%, #4f46e5 100%); border-radius: var(--wz-radius-lg); padding: 34px 28px 28px; margin-bottom: 18px; color: #fff; }
.wz-hero-bar__title { font-size: 1.9em; font-weight: 800; margin: 0 0 5px; }
.wz-hero-bar__sub   { opacity: .8; margin: 0 0 18px; font-size: .93em; }
.wz-search-bar { display: flex; gap: 10px; flex-wrap: wrap; background: rgba(255,255,255,.14); border-radius: var(--wz-radius-sm); padding: 10px; }
.wz-search-bar__input-wrap, .wz-search-bar__city-wrap { flex: 1; min-width: 160px; position: relative; }
.wz-search-bar__input-wrap input, .wz-search-bar__city-wrap select {
  width: 100%; border: none; background: #fff; border-radius: 7px; padding: 10px 12px 10px 34px; font-size: .93em; outline: none; box-sizing: border-box;
}
.wz-search-bar__city-wrap select { padding-left: 12px; }
.wz-search-bar__icon { position: absolute; top: 50%; right: 10px; transform: translateY(-50%); opacity: .45; pointer-events: none; }

/* Categories Row */
.wz-categories-row { display: flex; flex-wrap: wrap; gap: 7px; margin-bottom: 18px; overflow-x: auto; }
.wz-cat-chip { display: inline-flex; align-items: center; gap: 5px; padding: 6px 14px; border-radius: 20px; font-size: .83em; font-weight: 600; text-decoration: none; background: var(--wz-card); border: 1.5px solid var(--wz-border); color: var(--wz-text-sm); transition: all .15s; white-space: nowrap; }
.wz-cat-chip:hover { border-color: var(--wz-primary); color: var(--wz-primary); }
.wz-cat-chip.is-active { background: var(--wz-primary); border-color: var(--wz-primary); color: #fff; }
.wz-cat-chip__count { background: rgba(0,0,0,.1); border-radius: 20px; padding: 1px 6px; font-size: .85em; }
.wz-cat-chip.is-active .wz-cat-chip__count { background: rgba(255,255,255,.25); }

/* Layout */
.wz-jobs-layout { display: grid; grid-template-columns: 256px 1fr; gap: 20px; align-items: start; }
@media(max-width:880px) { .wz-jobs-layout { grid-template-columns: 1fr; } }

/* Filter Panel */
.wz-filter-panel { background: var(--wz-card); border: 1px solid var(--wz-border); border-radius: var(--wz-radius); overflow: hidden; position: sticky; top: 20px; box-shadow: var(--wz-shadow); }
.wz-filter-panel__header { display: flex; justify-content: space-between; align-items: center; padding: 12px 16px; background: var(--wz-bg); border-bottom: 1px solid var(--wz-border); font-weight: 700; font-size: .9em; }
.wz-filter-clear { font-size: .78em; color: var(--wz-danger); text-decoration: none; font-weight: 600; }
.wz-filter-group { padding: 13px 16px; border-bottom: 1px solid var(--wz-border); }
.wz-filter-group:last-of-type { border-bottom: none; }
.wz-filter-group__title { font-size: .73em; font-weight: 700; color: var(--wz-text-sm); text-transform: uppercase; letter-spacing: .05em; margin: 0 0 9px; }
.wz-filter-opt { display: flex; align-items: center; gap: 7px; padding: 7px 9px; border-radius: 7px; cursor: pointer; font-size: .87em; transition: background .1s; margin-bottom: 2px; }
.wz-filter-opt input[type=radio] { display: none; }
.wz-filter-opt em { margin-right: auto; background: var(--wz-bg); color: var(--wz-text-sm); border-radius: 20px; padding: 1px 7px; font-size: .78em; font-style: normal; font-weight: 600; }
.wz-filter-opt:hover { background: var(--wz-bg); }
.wz-filter-opt.is-active { background: var(--wz-primary-lt); color: var(--wz-primary); font-weight: 600; }
.wz-filter-opt.is-active em { background: rgba(37,99,235,.12); color: var(--wz-primary); }
.wz-date-chips { display: flex; flex-wrap: wrap; gap: 5px; }
.wz-date-chip { padding: 4px 10px; border: 1.5px solid var(--wz-border); border-radius: 20px; font-size: .78em; text-decoration: none; color: var(--wz-text-sm); transition: all .12s; }
.wz-date-chip:hover { border-color: var(--wz-primary); color: var(--wz-primary); }
.wz-date-chip.is-active { background: var(--wz-primary); border-color: var(--wz-primary); color: #fff; font-weight: 600; }
.wz-select--sm { padding: 5px 10px; border: 1.5px solid var(--wz-border); border-radius: var(--wz-radius-sm); font-size: .85em; }

/* Results Bar */
.wz-results-bar { display: flex; justify-content: space-between; align-items: center; margin-bottom: 12px; flex-wrap: wrap; gap: 8px; }
.wz-results-bar__count { font-size: .88em; color: var(--wz-text-sm); } .wz-results-bar__count strong { color: var(--wz-text); font-size: 1.15em; }
.wz-results-bar__sort  { display: flex; align-items: center; gap: 7px; font-size: .83em; color: var(--wz-text-sm); }
.wz-active-tags { display: flex; flex-wrap: wrap; gap: 6px; margin-bottom: 10px; }
.wz-active-tag { display: inline-flex; align-items: center; gap: 5px; background: var(--wz-primary-lt); color: var(--wz-primary); border: 1px solid #bfdbfe; border-radius: 20px; padding: 3px 10px; font-size: .78em; font-weight: 600; }
.wz-active-tag a { color: inherit; text-decoration: none; opacity: .6; font-size: 1.1em; }
.wz-active-tag a:hover { opacity: 1; }

/* Job Card */
.wz-jobs-list { display: flex; flex-direction: column; gap: 10px; }
.wz-job-card {
  display: grid; grid-template-columns: 54px 1fr auto;
  gap: 14px; align-items: center; background: var(--wz-card);
  border: 1px solid var(--wz-border); border-radius: var(--wz-radius);
  padding: 16px 18px; transition: box-shadow .18s, transform .18s, border-color .18s;
  position: relative;
}
.wz-job-card:hover { box-shadow: var(--wz-shadow-md); transform: translateY(-1px); border-color: #bfdbfe; }
.wz-job-card--featured { border-color: #fde68a; background: linear-gradient(to bottom left,#fffbeb,#fff); }
.wz-job-card--closed { opacity: .65; }
.wz-job-card__logo { flex-shrink: 0; }
.wz-job-card__body { min-width: 0; }
.wz-job-card__head { display: flex; justify-content: space-between; align-items: flex-start; gap: 10px; margin-bottom: 7px; }
.wz-job-card__title { font-size: 1em; font-weight: 700; margin: 0 0 3px; line-height: 1.3; }
.wz-job-card__title a { color: inherit; text-decoration: none; }
.wz-job-card__title a:hover, .wz-job-card:hover .wz-job-card__title a { color: var(--wz-primary); text-decoration: underline; }
.wz-job-card__company { font-size: .83em; color: var(--wz-text-sm); display: flex; align-items: center; gap: 4px; }
.wz-job-card__company a { color: inherit; text-decoration: none; } .wz-job-card__company a:hover { color: var(--wz-primary); }
.wz-job-card__meta { display: flex; flex-wrap: wrap; gap: 10px; font-size: .8em; color: var(--wz-text-sm); }
.wz-job-card__salary { color: #92400e; font-weight: 600; }
.wz-job-card__date   { color: var(--wz-text-xs); }
.wz-job-card__actions { flex-shrink: 0; display: flex; flex-direction: column; align-items: flex-end; gap: 6px; }
.wz-job-card__feat-badge { position: absolute; top: 12px; left: 12px; background: #f59e0b; color: #fff; font-size: .68em; font-weight: 700; padding: 2px 8px; border-radius: 20px; }
.wz-job-card__new-badge  { position: absolute; top: 12px; left: 12px; background: var(--wz-success); color: #fff; font-size: .68em; font-weight: 700; padding: 2px 8px; border-radius: 20px; }
.wz-job-card--featured .wz-job-card__new-badge { left: 80px; }
.wz-type-badge { padding: 3px 9px; border-radius: 20px; font-size: .72em; font-weight: 700; white-space: nowrap; }
.wz-type-badgefulltime, .wz-type-badgefull_time { background: #dcfce7; color: #166534; }
.wz-type-badgeparttime, .wz-type-badgepart_time { background: #fef9c3; color: #854d0e; }
.wz-type-badgeremote     { background: #ede9fe; color: #5b21b6; }
.wz-type-badgecontract   { background: #fce7f3; color: #9d174d; }
.wz-type-badgeinternship { background: #e0f2fe; color: #0369a1; }
.wz-type-badgefreelance  { background: #fff7ed; color: #c2410c; }
@media(max-width:560px){ .wz-job-card { grid-template-columns: 40px 1fr; } .wz-job-card__actions { grid-column: 1/-1; flex-direction: row; justify-content: flex-end; } }

/* No Results */
.wz-no-results { text-align: center; padding: 60px 20px; color: var(--wz-text-sm); }
.wz-no-results__icon { font-size: 3em; margin-bottom: 12px; }
.wz-no-results h3 { margin: 0 0 10px; color: var(--wz-text); }
.wz-empty { text-align: center; padding: 60px 20px; color: var(--wz-text-sm); }
.wz-empty__icon { font-size: 3em; margin-bottom: 12px; }
.wz-empty h3 { margin: 0 0 10px; color: var(--wz-text); }

/* Pagination */
.wz-pagination { display: flex; gap: 5px; justify-content: center; margin-top: 24px; flex-wrap: wrap; }
.wz-pagination__btn { padding: 7px 14px; border: 1.5px solid var(--wz-border); border-radius: var(--wz-radius-sm); text-decoration: none; color: var(--wz-text-sm); font-size: .88em; font-weight: 600; transition: all .14s; }
.wz-pagination__btn:hover { border-color: var(--wz-primary); color: var(--wz-primary); }
.wz-pagination__btn--active { background: var(--wz-primary); border-color: var(--wz-primary); color: #fff; }

/* ── Job Detail Page ── */
.wz-job-detail-page { max-width: 1100px; margin: 0 auto; padding: 24px 16px; font-family: var(--wz-font); }
.wz-breadcrumb { display: flex; align-items: center; gap: 7px; font-size: .84em; color: var(--wz-text-sm); margin-bottom: 18px; flex-wrap: wrap; }
.wz-breadcrumb a { color: var(--wz-primary); text-decoration: none; } .wz-breadcrumb a:hover { text-decoration: underline; }
.wz-job-detail-layout { display: grid; grid-template-columns: 1fr 300px; gap: 22px; align-items: start; }
@media(max-width:860px) { .wz-job-detail-layout { grid-template-columns: 1fr; } }

.wz-job-detail-header { display: grid; grid-template-columns: 74px 1fr auto; gap: 18px; align-items: flex-start; background: var(--wz-card); border: 1px solid var(--wz-border); border-radius: var(--wz-radius); padding: 22px; margin-bottom: 14px; box-shadow: var(--wz-shadow); }
@media(max-width:640px){ .wz-job-detail-header { grid-template-columns: 56px 1fr; } .wz-job-detail-header__cta { display: none; } }
.wz-job-detail-header h1 { font-size: 1.5em; font-weight: 800; margin: 0 0 6px; line-height: 1.25; }
.wz-job-detail-header__company { font-size: .92em; color: var(--wz-text-sm); display: flex; align-items: center; gap: 7px; margin-bottom: 12px; }
.wz-link--co { color: var(--wz-text); text-decoration: none; font-weight: 600; } .wz-link--co:hover { color: var(--wz-primary); }
.wz-job-detail-header__tags { display: flex; flex-wrap: wrap; gap: 7px; }
.wz-rating-mini { background: #fffbeb; color: #92400e; border-radius: 20px; padding: 2px 9px; font-size: .78em; font-weight: 700; }

.wz-dtag { display: inline-flex; align-items: center; gap: 4px; background: var(--wz-bg); color: var(--wz-text-sm); border: 1px solid var(--wz-border); border-radius: 20px; padding: 4px 11px; font-size: .79em; white-space: nowrap; }
.wz-dtag--salary { background: #fffbeb; color: #92400e; border-color: #fde68a; font-weight: 700; }
.wz-dtag--date   { color: var(--wz-text-xs); }
.wz-dtag--expire { background: #fef2f2; color: #991b1b; border-color: #fecaca; }

.wz-info-bar { display: grid; grid-template-columns: repeat(auto-fill,minmax(130px,1fr)); gap: 10px; background: var(--wz-bg); border: 1px solid var(--wz-border); border-radius: var(--wz-radius); padding: 14px 18px; margin-bottom: 14px; }
.wz-info-bar__item { display: flex; flex-direction: column; gap: 3px; }
.wz-info-bar__icon { font-size: 1.1em; } .wz-info-bar__lbl { font-size: .7em; color: var(--wz-text-sm); text-transform: uppercase; letter-spacing: .04em; font-weight: 600; }
.wz-info-bar__val { font-size: .9em; font-weight: 700; }

.wz-job-section { background: var(--wz-card); border: 1px solid var(--wz-border); border-radius: var(--wz-radius); padding: 20px 22px; margin-bottom: 12px; box-shadow: var(--wz-shadow); }
.wz-job-section h2 { font-size: 1.05em; font-weight: 700; margin: 0 0 12px; padding-bottom: 9px; border-bottom: 1px solid var(--wz-border); display: flex; align-items: center; gap: 8px; }
.wz-prose { white-space: pre-line; line-height: 1.8; font-size: .93em; }
.wz-checklist { padding-right: 18px; margin: 0; }
.wz-checklist li { padding: 5px 0; font-size: .92em; line-height: 1.6; border-bottom: 1px dashed var(--wz-border); }
.wz-checklist li:last-child { border-bottom: none; }
.wz-skills-tags { display: flex; flex-wrap: wrap; gap: 7px; }
.wz-skill-tag { background: var(--wz-primary-lt); color: var(--wz-primary); border: 1px solid #bfdbfe; border-radius: 20px; padding: 4px 12px; font-size: .82em; font-weight: 600; }

.wz-apply-section { border-color: var(--wz-primary); }
.wz-apply-gate { text-align: center; padding: 20px; } .wz-apply-gate__btns { display: flex; gap: 12px; justify-content: center; margin-top: 12px; }
.wz-apply-form .wz-form__field textarea { min-height: 130px; }
.wz-apply-cv-info { background: var(--wz-success-lt); border: 1px solid #bbf7d0; border-radius: var(--wz-radius-sm); padding: 10px 14px; font-size: .87em; margin-bottom: 14px; }

.wz-related-jobs { display: grid; grid-template-columns: repeat(2,1fr); gap: 10px; }
@media(max-width:560px) { .wz-related-jobs { grid-template-columns: 1fr; } }
.wz-related-job-card { display: flex; align-items: center; gap: 10px; background: var(--wz-bg); border: 1px solid var(--wz-border); border-radius: var(--wz-radius-sm); padding: 10px 13px; text-decoration: none; color: inherit; transition: all .15s; }
.wz-related-job-card:hover { border-color: var(--wz-primary); background: var(--wz-primary-lt); }
.wz-related-job-card div { display: flex; flex-direction: column; gap: 2px; min-width: 0; }
.wz-related-job-card strong { font-size: .88em; font-weight: 700; }
.wz-related-job-card span { font-size: .78em; color: var(--wz-text-sm); }

/* Sidebar Widgets */
.wz-job-detail-sidebar { display: flex; flex-direction: column; gap: 14px; }
.wz-sidebar-widget { background: var(--wz-card); border: 1px solid var(--wz-border); border-radius: var(--wz-radius); padding: 16px 18px; box-shadow: var(--wz-shadow); }
.wz-sidebar-widget h3 { font-size: .92em; font-weight: 700; margin: 0 0 12px; padding-bottom: 9px; border-bottom: 1px solid var(--wz-border); }
.wz-sidebar-widget--cta { border-color: var(--wz-primary); }
.wz-deadline-bar { display: flex; justify-content: space-between; align-items: center; background: #fef2f2; border: 1px solid #fecaca; border-radius: 6px; padding: 7px 11px; margin-top: 10px; font-size: .82em; color: #991b1b; }
.wz-summary-list { list-style: none; padding: 0; margin: 0; }
.wz-summary-list li { display: flex; justify-content: space-between; align-items: center; padding: 7px 0; border-bottom: 1px solid var(--wz-border); font-size: .87em; gap: 8px; }
.wz-summary-list li:last-child { border-bottom: none; }
.wz-summary-list li span { color: var(--wz-text-sm); }
.wz-summary-list li strong { font-weight: 600; text-align: left; }
.wz-co-mini { display: flex; gap: 10px; align-items: flex-start; margin-bottom: 10px; }
.wz-co-mini > div { display: flex; flex-direction: column; gap: 3px; }
.wz-co-mini strong { font-size: .9em; font-weight: 700; display: flex; align-items: center; gap: 4px; }
.wz-co-mini span  { font-size: .8em; color: var(--wz-text-sm); }
.wz-co-mini__desc { font-size: .83em; color: var(--wz-text-sm); line-height: 1.6; margin: 8px 0 0; }
.wz-share-btns { display: flex; gap: 7px; flex-wrap: wrap; }
.wz-share-btn { flex: 1; padding: 8px 10px; border-radius: var(--wz-radius-sm); text-align: center; font-size: .82em; font-weight: 600; text-decoration: none; cursor: pointer; border: 1.5px solid var(--wz-border); background: #fff; color: var(--wz-text-sm); transition: all .15s; }
.wz-share-btn--wa { background: #dcfce7; border-color: #bbf7d0; color: #166534; }
.wz-share-btn--li { background: #dbeafe; border-color: #bfdbfe; color: #1e40af; }

/* ── Dashboard ── */
.wz-dash-page { max-width: 1060px; margin: 0 auto; padding: 24px 16px; font-family: var(--wz-font); }
.wz-dash-header { display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 14px; background: var(--wz-card); border: 1px solid var(--wz-border); border-radius: var(--wz-radius); padding: 18px 22px; margin-bottom: 16px; box-shadow: var(--wz-shadow); }
.wz-dash-header__user { display: flex; align-items: center; gap: 14px; }
.wz-dash-header__avatar-img { border-radius: 50% !important; }
.wz-dash-header__info h2 { margin: 0 0 5px; font-size: 1.2em; }
.wz-dash-header__badges { display: flex; flex-wrap: wrap; gap: 6px; }
.wz-dash-header__actions { display: flex; gap: 9px; flex-wrap: wrap; }
.wz-notif-btn { position: relative; padding: 8px 13px; border: 1.5px solid var(--wz-border); border-radius: var(--wz-radius-sm); background: #fff; cursor: pointer; font-size: .88em; }
.wz-notif-badge { position: absolute; top: -5px; left: -5px; background: var(--wz-danger); color: #fff; border-radius: 50%; width: 18px; height: 18px; font-size: .68em; display: flex; align-items: center; justify-content: center; font-weight: 700; }

.wz-stats-grid { display: grid; grid-template-columns: repeat(6,1fr); gap: 12px; margin-bottom: 16px; }
@media(max-width:900px) { .wz-stats-grid { grid-template-columns: repeat(3,1fr); } }
@media(max-width:500px) { .wz-stats-grid { grid-template-columns: repeat(2,1fr); } }
.wz-stat-card { background: var(--wz-card); border: 1px solid var(--wz-border); border-radius: var(--wz-radius); padding: 16px; text-align: center; box-shadow: var(--wz-shadow); }
.wz-stat-card--green  { border-top: 3px solid var(--wz-success); }
.wz-stat-card--amber  { border-top: 3px solid var(--wz-warning); }
.wz-stat-card--red    { border-top: 3px solid var(--wz-danger); }
.wz-stat-card--blue   { border-top: 3px solid var(--wz-primary); }
.wz-stat-card--purple { border-top: 3px solid var(--wz-purple); }
.wz-stat-card__n { display: block; font-size: 2em; font-weight: 800; }
.wz-stat-card__l { font-size: .75em; color: var(--wz-text-sm); margin-top: 3px; display: block; }

.wz-tabs-nav { display: flex; border-bottom: 2px solid var(--wz-border); margin-bottom: 18px; gap: 0; overflow-x: auto; }
.wz-tab-btn { padding: 10px 20px; background: none; border: none; border-bottom: 2px solid transparent; margin-bottom: -2px; color: var(--wz-text-sm); font-weight: 600; font-size: .88em; cursor: pointer; white-space: nowrap; transition: all .15s; display: flex; align-items: center; gap: 6px; font-family: var(--wz-font); }
.wz-tab-btn:hover { color: var(--wz-primary); }
.wz-tab-btn.is-active { color: var(--wz-primary); border-bottom-color: var(--wz-primary); }
.wz-tab-panel { display: none; }
.wz-tab-panel.is-active { display: block; }

.wz-panel-actions { margin-bottom: 14px; display: flex; gap: 9px; }
.wz-job-panel { background: var(--wz-card); border: 1px solid var(--wz-border); border-radius: var(--wz-radius); padding: 18px; margin-bottom: 14px; box-shadow: var(--wz-shadow); }
.wz-job-panel__header { display: flex; flex-wrap: wrap; gap: 10px; align-items: center; justify-content: space-between; margin-bottom: 14px; padding-bottom: 10px; border-bottom: 1px solid var(--wz-border); }
.wz-job-panel__title-row { display: flex; flex-wrap: wrap; align-items: center; gap: 8px; flex: 1; }
.wz-job-panel__title-link { font-weight: 700; font-size: 1em; color: var(--wz-text); text-decoration: none; } .wz-job-panel__title-link:hover { color: var(--wz-primary); }
.wz-job-panel__counts { display: flex; gap: 7px; align-items: center; flex-wrap: wrap; font-size: .83em; }
.wz-job-panel__actions { display: flex; gap: 7px; align-items: center; flex-wrap: wrap; }
.wz-table-wrap { overflow-x: auto; }
.wz-table { width: 100%; border-collapse: collapse; font-size: .87em; direction: rtl; }
.wz-table th, .wz-table td { padding: 10px 12px; text-align: right; border-bottom: 1px solid var(--wz-border); }
.wz-table th { background: var(--wz-bg); font-weight: 700; color: var(--wz-text-sm); font-size: .8em; text-transform: uppercase; }
.wz-table tr:hover td { background: #fafafa; }
.wz-table-actions { display: flex; gap: 5px; align-items: center; flex-wrap: wrap; }
.wz-row--shortlisted { background: #fffbeb; }
.wz-details summary { cursor: pointer; }
.wz-details__body { margin-top: 8px; padding: 10px; background: var(--wz-bg); border-radius: var(--wz-radius-sm); font-size: .85em; line-height: 1.6; max-width: 360px; }

/* Overview grid */
.wz-overview-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; }
@media(max-width:640px) { .wz-overview-grid { grid-template-columns: 1fr; } }
.wz-overview-card { background: var(--wz-card); border: 1px solid var(--wz-border); border-radius: var(--wz-radius); padding: 18px; box-shadow: var(--wz-shadow); }
.wz-overview-card h3 { margin: 0 0 14px; font-size: .95em; font-weight: 700; }
.wz-overview-job-row { display: flex; justify-content: space-between; align-items: center; gap: 8px; padding: 8px 0; border-bottom: 1px solid var(--wz-border); font-size: .87em; }
.wz-overview-job-row:last-child { border-bottom: none; }
.wz-overview-app-row { display: flex; align-items: center; gap: 10px; padding: 8px 0; border-bottom: 1px solid var(--wz-border); }
.wz-overview-app-row:last-child { border-bottom: none; }
.wz-overview-app-row__info { display: flex; flex-direction: column; gap: 2px; flex: 1; min-width: 0; font-size: .87em; }

/* Notifications */
.wz-notif-item { display: flex; justify-content: space-between; align-items: flex-start; padding: 12px 14px; border-radius: var(--wz-radius-sm); border: 1px solid var(--wz-border); margin-bottom: 8px; background: var(--wz-card); gap: 12px; }
.wz-notif-item--unread { background: var(--wz-primary-lt); border-color: #bfdbfe; }
.wz-notif-item__content { flex: 1; min-width: 0; }
.wz-notif-item__title { font-size: .88em; font-weight: 600; color: var(--wz-text); text-decoration: none; display: block; }
.wz-notif-item__title:hover { color: var(--wz-primary); }
.wz-notif-item__msg { font-size: .82em; color: var(--wz-text-sm); margin: 3px 0 0; }
.wz-notif-item__time { font-size: .78em; color: var(--wz-text-xs); white-space: nowrap; flex-shrink: 0; }

/* Profile completion bar */
.wz-profile-bar { background: var(--wz-card); border: 1px solid var(--wz-border); border-radius: var(--wz-radius-sm); padding: 12px 16px; margin-bottom: 14px; }
.wz-profile-bar__info { display: flex; justify-content: space-between; align-items: center; margin-bottom: 8px; font-size: .87em; }
.wz-progress-bar { height: 6px; background: var(--wz-border); border-radius: 20px; overflow: hidden; }
.wz-progress-bar__fill { height: 100%; background: linear-gradient(to left,var(--wz-primary),#60a5fa); border-radius: 20px; transition: width .4s; }

/* Profile layout */
.wz-profile-layout { display: grid; grid-template-columns: 220px 1fr; gap: 18px; align-items: start; }
@media(max-width:680px) { .wz-profile-layout { grid-template-columns: 1fr; } }
.wz-profile-card { background: var(--wz-card); border: 1px solid var(--wz-border); border-radius: var(--wz-radius); padding: 22px; text-align: center; box-shadow: var(--wz-shadow); }
.wz-profile-card h3 { margin: 8px 0 6px; font-size: 1em; font-weight: 700; }
.wz-profile-card__headline { color: var(--wz-text-sm); font-size: .85em; margin: 0 0 12px; }
.wz-profile-card__contact { display: flex; flex-direction: column; gap: 5px; margin-bottom: 12px; }
.wz-profile-card__contact p, .wz-profile-card__contact a { font-size: .83em; color: var(--wz-text-sm); text-decoration: none; margin: 0; }
.wz-profile-card__link { color: var(--wz-primary); }
.wz-profile-card__completion { margin-top: 14px; font-size: .82em; color: var(--wz-text-sm); }
.wz-cv-current { background: var(--wz-success-lt); border: 1px solid #bbf7d0; border-radius: var(--wz-radius-sm); padding: 10px 14px; font-size: .87em; margin-bottom: 10px; }

/* Companies Page */
.wz-companies-page { max-width: 1100px; margin: 0 auto; padding: 24px 16px; font-family: var(--wz-font); }
.wz-companies-hero { background: linear-gradient(135deg,#0f172a,#1e3a8a 60%,#1e40af); border-radius: var(--wz-radius-lg); padding: 32px 28px; margin-bottom: 20px; color: #fff; }
.wz-companies-hero h1 { font-size: 1.9em; font-weight: 800; margin: 0 0 6px; }
.wz-companies-hero p  { opacity: .8; margin: 0 0 18px; }
.wz-search-bar--co input { padding-left: 12px; }
.wz-companies-grid { display: grid; grid-template-columns: repeat(auto-fill,minmax(270px,1fr)); gap: 16px; }
.wz-co-card { display: flex; gap: 14px; background: var(--wz-card); border: 1px solid var(--wz-border); border-radius: var(--wz-radius); padding: 18px; text-decoration: none; color: inherit; transition: box-shadow .18s,transform .18s,border-color .18s; }
.wz-co-card:hover { box-shadow: var(--wz-shadow-md); transform: translateY(-2px); border-color: #bfdbfe; }
.wz-co-card__logo { flex-shrink: 0; }
.wz-co-card__info { flex: 1; min-width: 0; display: flex; flex-direction: column; gap: 5px; }
.wz-co-card__info h3 { font-size: .95em; font-weight: 700; margin: 0; display: flex; align-items: center; gap: 5px; }
.wz-co-card__tagline { font-size: .8em; color: var(--wz-text-sm); margin: 0; }
.wz-co-card__meta { display: flex; flex-wrap: wrap; gap: 8px; font-size: .78em; color: var(--wz-text-sm); }
.wz-co-card__footer { display: flex; gap: 10px; align-items: center; margin-top: 4px; }
.wz-co-card__jobs-count { background: var(--wz-primary-lt); color: var(--wz-primary); padding: 3px 9px; border-radius: 20px; font-size: .78em; font-weight: 600; }
.wz-co-card__rating { color: #d97706; font-weight: 600; font-size: .82em; }
.wz-co-card__desc { font-size: .82em; color: var(--wz-text-sm); line-height: 1.5; margin: 0; }

/* Company Profile */
.wz-co-profile-page { max-width: 1080px; margin: 0 auto; padding: 24px 16px; font-family: var(--wz-font); }
.wz-co-profile-header { background: var(--wz-card); border: 1px solid var(--wz-border); border-radius: var(--wz-radius); overflow: hidden; margin-bottom: 18px; box-shadow: var(--wz-shadow); }
.wz-co-profile-header__cover { height: 160px; background: linear-gradient(135deg,var(--wz-primary),var(--wz-purple)); background-size: cover; background-position: center; }
.wz-co-profile-header__info { display: flex; gap: 18px; align-items: flex-start; padding: 18px 22px; flex-wrap: wrap; }
.wz-co-profile-header__logo { margin-top: -40px; border: 3px solid #fff; border-radius: var(--wz-radius); box-shadow: var(--wz-shadow-md); flex-shrink: 0; background: #fff; }
.wz-co-profile-header__details { flex: 1; min-width: 200px; }
.wz-co-profile-header__details h1 { font-size: 1.5em; font-weight: 800; margin: 0 0 7px; display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.wz-co-profile-header__tagline { color: var(--wz-text-sm); font-size: .9em; margin: 0 0 10px; }
.wz-co-profile-header__meta { display: flex; flex-wrap: wrap; gap: 10px; font-size: .83em; color: var(--wz-text-sm); }
.wz-co-profile-layout { display: grid; grid-template-columns: 1fr 260px; gap: 20px; align-items: start; }
@media(max-width:760px) { .wz-co-profile-layout { grid-template-columns: 1fr; } }
.wz-co-job-item { display: flex; justify-content: space-between; align-items: center; gap: 14px; padding: 12px 0; border-bottom: 1px solid var(--wz-border); }
.wz-co-job-item:last-child { border-bottom: none; }
.wz-co-job-item__title { font-weight: 600; font-size: .9em; color: var(--wz-text); text-decoration: none; display: block; margin-bottom: 4px; } .wz-co-job-item__title:hover { color: var(--wz-primary); }
.wz-co-job-item__meta { display: flex; gap: 10px; font-size: .8em; color: var(--wz-text-sm); flex-wrap: wrap; }

/* Reviews */
.wz-reviews-summary { display: flex; align-items: center; gap: 16px; padding: 18px; background: var(--wz-bg); border-radius: var(--wz-radius-sm); margin-bottom: 16px; }
.wz-reviews-summary__score { font-size: 3em; font-weight: 800; }
.wz-stars-big { color: #f59e0b; font-size: 1.4em; }
.wz-review-card { background: var(--wz-card); border: 1px solid var(--wz-border); border-radius: var(--wz-radius); padding: 14px; margin-bottom: 10px; }
.wz-review-card__header { display: flex; align-items: center; gap: 10px; margin-bottom: 8px; }
.wz-review-card__avatar { width: 36px; height: 36px; border-radius: 50%; background: var(--wz-primary); color: #fff; display: flex; align-items: center; justify-content: center; font-weight: 700; font-size: .9em; flex-shrink: 0; }
.wz-review-card__stars { color: #f59e0b; }
.wz-review-card__title { font-weight: 600; margin: 0 0 5px; }

/* Star select widget */
.wz-star-select { display: flex; flex-direction: row-reverse; justify-content: flex-end; gap: 4px; }
.wz-star-select input[type=radio] { display: none; }
.wz-star-select label { cursor: pointer; font-size: 2em; color: #d1d5db; transition: color .15s; }
.wz-star-select input:checked ~ label, .wz-star-select label:hover, .wz-star-select label:hover ~ label { color: #f59e0b; }

/* ═══════════════════════════════════════════════════════════
   Jobseeker Profile Page
   ═══════════════════════════════════════════════════════════ */
.wz-profile-page { max-width: 960px; margin: 0 auto; padding: 24px 16px; font-family: var(--wz-font); }

/* Header / Cover */
.wz-seeker-header { background: var(--wz-card); border: 1px solid var(--wz-border); border-radius: var(--wz-radius-lg); overflow: hidden; margin-bottom: 18px; box-shadow: var(--wz-shadow-md); }
.wz-seeker-header__cover { height: 140px; background: linear-gradient(130deg,#1e3a8a,#2563eb 55%,#4f46e5); }
.wz-seeker-header__body { display: flex; align-items: flex-start; gap: 18px; padding: 16px 22px 20px; flex-wrap: wrap; }
.wz-seeker-header__photo-wrap { position: relative; margin-top: -50px; flex-shrink: 0; }
.wz-seeker-header__photo { border: 3px solid #fff; border-radius: 50% !important; box-shadow: var(--wz-shadow-md); }
.wz-photo-change-btn { position: absolute; bottom: 2px; right: 2px; width: 28px; height: 28px; background: var(--wz-primary); color: #fff; border: 2px solid #fff; border-radius: 50%; display: flex; align-items: center; justify-content: center; cursor: pointer; padding: 0; transition: background .15s; }
.wz-photo-change-btn:hover { background: var(--wz-primary-dk); }
.wz-seeker-header__info { flex: 1; min-width: 200px; padding-top: 6px; }
.wz-seeker-header__info h1 { font-size: 1.45em; font-weight: 800; margin: 0 0 5px; }
.wz-seeker-header__headline { color: var(--wz-text-sm); font-size: .93em; margin: 0 0 10px; }
.wz-seeker-header__meta { display: flex; flex-wrap: wrap; gap: 10px; font-size: .83em; color: var(--wz-text-sm); }
.wz-seeker-meta-link { color: var(--wz-primary); text-decoration: none; } .wz-seeker-meta-link:hover { text-decoration: underline; }
.wz-seeker-header__joined { color: var(--wz-text-xs); }
.wz-seeker-header__actions { display: flex; gap: 9px; flex-wrap: wrap; padding-top: 6px; }

/* Profile completion */
.wz-profile-completion-bar { background: var(--wz-card); border: 1px solid var(--wz-border); border-radius: var(--wz-radius-sm); padding: 12px 18px; margin-bottom: 16px; }
.wz-profile-completion-bar__info { display: flex; justify-content: space-between; align-items: center; margin-bottom: 8px; font-size: .88em; }

/* Profile layout */
.wz-profile-layout-2col { display: grid; grid-template-columns: 1fr 300px; gap: 18px; align-items: start; }
@media(max-width:780px) { .wz-profile-layout-2col { grid-template-columns: 1fr; } }

/* Profile sections */
.wz-profile-section { background: var(--wz-card); border: 1px solid var(--wz-border); border-radius: var(--wz-radius); padding: 20px 22px; margin-bottom: 14px; box-shadow: var(--wz-shadow); }
.wz-profile-section--highlight { border-color: var(--wz-primary); background: var(--wz-primary-lt); }
.wz-profile-section h2 { font-size: 1.05em; font-weight: 700; margin: 0 0 14px; padding-bottom: 9px; border-bottom: 1px solid var(--wz-border); display: flex; align-items: center; gap: 8px; }
.wz-profile-section--highlight h2 { border-bottom-color: rgba(37,99,235,.2); }

/* Timeline */
.wz-timeline { display: flex; flex-direction: column; gap: 0; }
.wz-timeline__item { display: flex; gap: 14px; position: relative; padding-bottom: 16px; }
.wz-timeline__item:last-child { padding-bottom: 0; }
.wz-timeline__item::before { content: ''; position: absolute; right: 6px; top: 20px; bottom: 0; width: 2px; background: var(--wz-border); }
.wz-timeline__item:last-child::before { display: none; }
.wz-timeline__dot { width: 14px; height: 14px; border-radius: 50%; background: var(--wz-primary); flex-shrink: 0; margin-top: 4px; border: 2px solid var(--wz-primary-lt); z-index: 1; }
.wz-timeline__item p { margin: 0; font-size: .9em; line-height: 1.6; color: var(--wz-text); }

/* ─── Photo Modal ───────────────────────────────────────── */
.wz-photo-modal { position: fixed; inset: 0; background: rgba(0,0,0,.5); z-index: 99999; display: flex; align-items: center; justify-content: center; padding: 16px; }
.wz-photo-modal__box { background: var(--wz-card); border-radius: var(--wz-radius-lg); width: 100%; max-width: 420px; box-shadow: var(--wz-shadow-lg); overflow: hidden; }
.wz-photo-modal__head { display: flex; justify-content: space-between; align-items: center; padding: 16px 20px; border-bottom: 1px solid var(--wz-border); }
.wz-photo-modal__head h3 { margin: 0; font-size: 1em; }
.wz-photo-modal__close { background: none; border: none; cursor: pointer; font-size: 1.2em; color: var(--wz-text-sm); padding: 0 4px; line-height: 1; }
.wz-photo-modal__close:hover { color: var(--wz-danger); }
.wz-photo-modal__body { padding: 24px 20px; text-align: center; }
.wz-photo-preview { margin: 0 auto 18px; width: 120px; height: 120px; border-radius: 50%; overflow: hidden; border: 3px solid var(--wz-border); display: flex; align-items: center; justify-content: center; background: var(--wz-bg); }
.wz-photo-preview img { width: 120px; height: 120px; object-fit: cover; border-radius: 50%; }
.wz-photo-modal__actions { display: flex; gap: 10px; justify-content: center; }

/* ─── Jobseekers Directory ──────────────────────────────── */
.wz-seekers-page { max-width: 1080px; margin: 0 auto; padding: 24px 16px; font-family: var(--wz-font); }
.wz-seekers-hero { background: linear-gradient(130deg,#1e3a8a,#2563eb 55%,#7c3aed); border-radius: var(--wz-radius-lg); padding: 32px 28px 26px; margin-bottom: 18px; color: #fff; }
.wz-seekers-hero h1 { font-size: 1.85em; font-weight: 800; margin: 0 0 5px; }
.wz-seekers-hero p  { opacity: .8; margin: 0 0 18px; font-size: .92em; }

.wz-seekers-filters { display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 12px; background: var(--wz-card); border: 1px solid var(--wz-border); border-radius: var(--wz-radius-sm); padding: 13px 16px; margin-bottom: 16px; }
.wz-filter-inline { display: flex; align-items: center; gap: 7px; font-size: .86em; color: var(--wz-text-sm); }
.wz-filter-input-sm { padding: 6px 10px; border: 1.5px solid var(--wz-border); border-radius: var(--wz-radius-sm); font-size: .86em; background: #fff; }

.wz-seekers-grid { display: grid; grid-template-columns: repeat(auto-fill,minmax(260px,1fr)); gap: 16px; }
.wz-seeker-card { background: var(--wz-card); border: 1px solid var(--wz-border); border-radius: var(--wz-radius); padding: 18px; box-shadow: var(--wz-shadow); transition: box-shadow .18s,transform .18s; }
.wz-seeker-card:hover { box-shadow: var(--wz-shadow-md); transform: translateY(-1px); }
.wz-seeker-card__header { display: flex; gap: 12px; align-items: center; margin-bottom: 12px; }
.wz-seeker-card__photo-link { flex-shrink: 0; }
.wz-seeker-card__photo { border-radius: 50% !important; }
.wz-seeker-card__name-wrap { flex: 1; min-width: 0; }
.wz-seeker-card__name { font-weight: 700; font-size: .95em; color: var(--wz-text); text-decoration: none; display: block; margin-bottom: 2px; } .wz-seeker-card__name:hover { color: var(--wz-primary); }
.wz-seeker-card__headline { font-size: .82em; color: var(--wz-text-sm); margin: 0 0 5px; }
.wz-seeker-card__meta { display: flex; flex-wrap: wrap; gap: 5px; font-size: .78em; color: var(--wz-text-sm); align-items: center; }
.wz-seeker-card__about { font-size: .83em; color: var(--wz-text-sm); line-height: 1.55; margin: 0 0 10px; }
.wz-seeker-card__skills { display: flex; flex-wrap: wrap; gap: 5px; margin-bottom: 12px; }
.wz-skill-tag--sm { font-size: .73em; padding: 2px 8px; }
.wz-skill-tag--more { background: var(--wz-bg); color: var(--wz-text-sm); border: 1px solid var(--wz-border); border-radius: 20px; padding: 2px 8px; font-size: .73em; }
.wz-seeker-card__actions { display: flex; gap: 7px; flex-wrap: wrap; border-top: 1px solid var(--wz-border); padding-top: 11px; }

/* ─── User Photo (global override) ─────────────────────── */
.wz-user-photo { display: block; object-fit: cover; }

/* ═══════════════════════════════════════════════════════════
   Messages System
   ═══════════════════════════════════════════════════════════ */
.wz-messages-page { max-width: 1060px; margin: 0 auto; padding: 20px 16px; font-family: var(--wz-font); }
.wz-messages-layout { display: grid; grid-template-columns: 280px 1fr; gap: 0; border: 1px solid var(--wz-border); border-radius: var(--wz-radius); overflow: hidden; background: var(--wz-card); box-shadow: var(--wz-shadow-md); min-height: 580px; }
@media(max-width:680px) { .wz-messages-layout { grid-template-columns: 1fr; } }

/* Threads Sidebar */
.wz-messages-sidebar { border-left: 1px solid var(--wz-border); background: var(--wz-bg); display: flex; flex-direction: column; }
.wz-messages-sidebar__header { padding: 16px 16px 12px; border-bottom: 1px solid var(--wz-border); }
.wz-messages-sidebar__header h2 { margin: 0; font-size: 1em; font-weight: 700; display: flex; align-items: center; }

.wz-thread-item { display: flex; align-items: center; gap: 11px; padding: 13px 15px; border-bottom: 1px solid var(--wz-border); text-decoration: none; color: inherit; transition: background .12s; cursor: pointer; }
.wz-thread-item:hover { background: var(--wz-card); }
.wz-thread-item.is-active { background: var(--wz-card); border-right: 3px solid var(--wz-primary); }
.wz-thread-item.is-unread { background: var(--wz-primary-lt); }
.wz-thread-item.is-unread:hover { background: #dbeafe; }
.wz-thread-item__info { flex: 1; min-width: 0; }
.wz-thread-item__name { font-size: .88em; font-weight: 700; display: flex; align-items: center; gap: 6px; margin-bottom: 2px; }
.wz-thread-item__badge { background: var(--wz-primary); color: #fff; border-radius: 20px; padding: 1px 6px; font-size: .7em; font-weight: 800; }
.wz-thread-item__preview { font-size: .78em; color: var(--wz-text-sm); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.wz-thread-item__time { font-size: .72em; color: var(--wz-text-xs); margin-top: 3px; }

/* Main Area */
.wz-messages-main { display: flex; flex-direction: column; min-height: 580px; }
.wz-messages-main__header { display: flex; align-items: center; gap: 12px; padding: 14px 18px; border-bottom: 1px solid var(--wz-border); background: var(--wz-bg); }
.wz-messages-main__header strong { font-size: .95em; font-weight: 700; }

.wz-messages-list { flex: 1; overflow-y: auto; padding: 18px; display: flex; flex-direction: column; gap: 12px; max-height: 420px; }
.wz-messages-empty { text-align: center; color: var(--wz-text-sm); padding: 40px 20px; font-size: .9em; }

/* Bubbles */
.wz-message-bubble { display: flex; gap: 8px; align-items: flex-end; max-width: 75%; }
.wz-message-bubble--me   { align-self: flex-end; flex-direction: row-reverse; }
.wz-message-bubble--them { align-self: flex-start; }
.wz-message-bubble__photo { flex-shrink: 0; border-radius: 50% !important; margin-bottom: 2px; }
.wz-message-bubble__content { display: flex; flex-direction: column; gap: 3px; }
.wz-message-bubble__text { padding: 10px 14px; border-radius: 16px; font-size: .9em; line-height: 1.55; word-break: break-word; }
.wz-message-bubble--me   .wz-message-bubble__text { background: var(--wz-primary); color: #fff; border-bottom-left-radius: 4px; }
.wz-message-bubble--them .wz-message-bubble__text { background: var(--wz-bg); border: 1px solid var(--wz-border); color: var(--wz-text); border-bottom-right-radius: 4px; }
.wz-message-bubble__time { font-size: .7em; color: var(--wz-text-xs); padding: 0 4px; }
.wz-message-bubble--me .wz-message-bubble__time { text-align: left; }

/* Compose */
.wz-messages-compose { padding: 14px 16px; border-top: 1px solid var(--wz-border); background: var(--wz-bg); display: flex; gap: 10px; align-items: flex-end; }
.wz-messages-compose__subject { width: 100%; padding: 8px 12px; border: 1.5px solid var(--wz-border); border-radius: var(--wz-radius-sm); font-size: .88em; margin-bottom: 8px; }
.wz-messages-compose__input { flex: 1; padding: 9px 12px; border: 1.5px solid var(--wz-border); border-radius: var(--wz-radius-sm); font-size: .9em; resize: none; font-family: var(--wz-font); transition: border-color .15s; min-height: 60px; }
.wz-messages-compose__input:focus { outline: none; border-color: var(--wz-primary); box-shadow: 0 0 0 3px rgba(37,99,235,.1); }

/* New conversation */
.wz-messages-new { flex: 1; display: flex; align-items: center; justify-content: center; padding: 30px; }
.wz-messages-new__card { text-align: center; max-width: 420px; width: 100%; }
.wz-messages-new__card h3 { font-size: 1.1em; margin: 12px 0 6px; }
.wz-messages-new__card .wz-messages-compose { flex-direction: column; background: transparent; border-top: none; padding: 0; }
.wz-messages-new__card .wz-messages-compose__input { width: 100%; box-sizing: border-box; }

/* Empty state */
.wz-messages-empty-state { flex: 1; display: flex; flex-direction: column; align-items: center; justify-content: center; padding: 40px 20px; text-align: center; color: var(--wz-text-sm); }
.wz-messages-empty-state h3 { color: var(--wz-text); margin-bottom: 8px; }

/* ═══════════════════════════════════════════════════════════
   Seeker Card in employer apps table (avatar)
   ═══════════════════════════════════════════════════════════ */
.wz-seeker-header__photo { display: block; border-radius: 50% !important; }

/* ═══════════════════════════════════════════════════════════
   Misc improvements
   ═══════════════════════════════════════════════════════════ */
.wz-form__field input[type="file"] {
  padding: 8px 10px; background: var(--wz-bg); cursor: pointer;
  border-style: dashed;
}
.wz-form__field input[type="file"]:hover { border-color: var(--wz-primary); }

/* Print-friendly CV */
@media print {
  .wz-dash-header__actions, .wz-tabs-nav, .wz-seeker-header__actions,
  .wz-photo-change-btn, [data-wuzaf-photo-trigger] { display: none !important; }
  .wz-profile-page { max-width: 100%; padding: 0; }
}
