/*
Theme Name: Jobs1 Custom Theme
Theme URI: https://jobs1.net
Description: Custom child theme for jobs1.net — based on Astra. Implements the bahr-aljobs design system with gold/dark identity, sticky nav, and clean job cards.
Author: jobs1.net
Author URI: https://jobs1.net
Template: astra
Version: 1.0.0
Text Domain: jobs1-theme
Tags: arabic, rtl, custom
*/

:root{
  --gold:#0EA5E9;
  --gold-dark:#0284C7;
  --gold-darker:#075985;
  --gold-50:#E0F2FE;
  --gold-100:#BAE6FD;
  --gold-200:#7DD3FC;
  --header-bg:#1B2D5C;
  --header-down:#0d1a3d;
  --ink:#1c1917;
  --ink-soft:#44403c;
  --muted:#78716c;
  --line:#e7e5e4;
  --bg:#f5f5f4;
  --card:#ffffff;
  --radius:8px;
  --radius-sm:6px;
  --radius-lg:14px;
  --shadow:0 1px 3px rgba(15,23,42,.08), 0 1px 2px rgba(15,23,42,.04);
  --shadow-md:0 4px 12px rgba(15,23,42,.10);
  --trans:.18s ease;
}

/* ===== Reset for Astra default styling ===== */
body.wp-theme-astra,
body{
  font-family:Tahoma,"Cairo","Segoe UI",system-ui,-apple-system,sans-serif !important;
  background:var(--bg) !important;
  color:var(--ink) !important;
  line-height:1.6 !important;
  -webkit-font-smoothing:antialiased;
  margin:0;
  padding:0;
}
*{box-sizing:border-box;}
img{max-width:100%; height:auto; display:block;}
a{color:inherit; text-decoration:none;}

/* ===== Hide Astra's default header/footer (we replace them) ===== */
.site-header,
header.site-header,
.site-content > header,
footer.site-footer{
  display:none !important;
}

/* But our own custom-header / custom-footer always visible */
.jw-site-header{display:block;}

/* ===== Custom Header (yellow brand bar) ===== */
.jw-site-header{
  background:var(--header-bg);
  padding:18px 0;
  text-align:center;
  position:relative;
  width:100%;
}
.jw-site-header::after{
  content:"";
  position:absolute;
  bottom:-3px;
  left:0; right:0;
  height:3px;
  background:linear-gradient(90deg, var(--gold-dark), var(--gold-darker), var(--gold-dark));
}
.jw-brand{
  display:inline-flex;
  align-items:center;
  gap:14px;
  color:#fff;
  text-decoration:none;
}
.jw-brand-logo{
  width:54px; height:54px;
  background:#fff;
  border-radius:14px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  color:var(--gold);
  font-size:28px;
  font-weight:900;
  box-shadow:0 4px 14px rgba(0,0,0,.15);
}
.jw-brand-logo-img{
  width:56px; height:56px;
  border-radius:14px;
  background:#fff;
  padding:6px;
  object-fit:contain;
  box-shadow:0 4px 14px rgba(0,0,0,.18);
  transition:transform .22s ease;
}
.jw-brand:hover .jw-brand-logo-img{
  transform:scale(1.05);
}
.jw-brand-name{
  font-size:30px;
  font-weight:900;
  letter-spacing:-.5px;
  text-shadow:0 2px 6px rgba(0,0,0,.12);
  color:#fff;
}

/* ===== Sticky dark nav with category icons ===== */
.jw-nav{
  background:var(--header-down);
  position:sticky;
  top:0;
  z-index:100;
  border-bottom:3px solid var(--gold);
  box-shadow:0 4px 12px rgba(0,0,0,.10);
}
.jw-nav-container{
  max-width:1280px;
  margin:0 auto;
  padding:0 16px;
}
.jw-nav-items{
  display:flex;
  flex-wrap:wrap;
  justify-content:center;
  gap:4px;
  padding:6px 0;
  list-style:none;
  margin:0;
}
.jw-nav-items li{margin:0;}
.jw-nav-item{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:10px 14px;
  border-radius:8px;
  color:#e2e8f0;
  font-weight:600;
  font-size:14px;
  transition:background var(--trans), color var(--trans);
  text-decoration:none;
}
.jw-nav-item:hover{
  background:rgba(201,162,39,.18);
  color:#fff;
}
.jw-nav-item.active,
.jw-nav-item.current-menu-item{
  background:var(--gold);
  color:#fff;
}
.jw-nav-item i{font-size:13px;}

/* ===== Search section ===== */
.jw-search-section{
  background:#fff;
  padding:18px 16px;
  border-bottom:1px solid var(--line);
}
.jw-search-form{
  max-width:720px;
  margin:0 auto;
  display:flex;
  background:#fff;
  border:2px solid var(--line);
  border-radius:999px;
  overflow:hidden;
  transition:border-color var(--trans), box-shadow var(--trans);
}
.jw-search-form:focus-within{
  border-color:var(--gold);
  box-shadow:0 0 0 4px rgba(201,162,39,.15);
}
.jw-search-input{
  flex:1;
  border:none;
  outline:none;
  padding:14px 22px;
  font-family:inherit;
  font-size:15px;
  background:transparent;
  color:var(--ink);
}
.jw-search-input::placeholder{color:#a8a29e;}
.jw-search-button{
  background:var(--gold);
  color:#fff;
  border:none;
  padding:0 26px;
  display:inline-flex;
  align-items:center;
  gap:8px;
  cursor:pointer;
  font-family:inherit;
  font-weight:700;
  font-size:14px;
  transition:background var(--trans);
}
.jw-search-button:hover{background:var(--gold-dark);}

/* ===== Layout container ===== */
.jw-page-wrap{
  position:relative;
  max-width:1500px;
  margin:0 auto;
}
.jw-main{
  max-width:1100px;
  margin:0 auto;
  padding:24px 16px;
}
body.single .jw-main,
body.page .jw-main{max-width:900px;}

/* ===== Side ads (sticky skyscrapers) ===== */
.jw-side-ad{
  position:absolute;
  top:24px;
  width:170px;
  z-index:5;
}
.jw-side-ad.right-ad{right:8px;}
.jw-side-ad.left-ad{left:8px;}
.jw-side-ad-inner{
  position:sticky;
  top:80px;
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--radius);
  overflow:hidden;
  box-shadow:var(--shadow);
}
.jw-side-ad-header{
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding:6px 8px;
  border-bottom:1px solid var(--line);
  background:#fafaf9;
  font-size:11px;
  color:var(--muted);
}
.jw-side-ad-icon{
  width:16px; height:16px;
  border-radius:50%;
  background:var(--gold-50);
  color:var(--gold-dark);
  display:inline-flex;
  align-items:center;
  justify-content:center;
  font-size:10px;
}
.jw-side-ad-close{cursor:pointer; color:var(--muted); padding:2px 6px; font-size:14px;}
.jw-side-ad-body{
  padding:12px 8px;
  text-align:center;
  min-height:600px;
  display:flex;
  flex-direction:column;
  gap:12px;
  align-items:center;
  color:var(--muted);
  font-size:12px;
}
.jw-side-ad-body i{font-size:36px; color:var(--gold); margin-bottom:8px;}
.jw-side-ad-label{font-weight:700; color:var(--ink); font-size:13px;}
.jw-side-ad-size{font-size:10px; opacity:.7;}
@media (max-width:1280px){.jw-side-ad{display:none;}}

/* ===== Section title ===== */
.jw-section-title{
  text-align:center;
  font-size:18px;
  font-weight:800;
  color:var(--ink);
  margin-bottom:18px;
  position:relative;
  padding-bottom:12px;
}
.jw-section-title::after{
  content:"";
  position:absolute;
  bottom:0;
  left:50%;
  transform:translateX(-50%);
  width:60px;
  height:3px;
  background:var(--gold);
  border-radius:2px;
}

/* ===== Ad banner ===== */
.jw-ad-banner{
  max-width:728px;
  margin:0 auto 20px;
  background:#fafaf9;
  border:1px dashed var(--line);
  border-radius:var(--radius);
  padding:14px;
  text-align:center;
  color:#a8a29e;
  font-size:12px;
  min-height:90px;
  display:flex;
  align-items:center;
  justify-content:center;
  flex-direction:column;
}
.jw-ad-banner small{display:block; opacity:.7; margin-top:4px;}

/* ===== Job cards grid ===== */
.jw-jobs-grid{
  display:grid;
  grid-template-columns:repeat(2, 1fr);
  gap:14px;
}
@media (max-width:640px){
  .jw-jobs-grid{grid-template-columns:1fr;}
}
.jw-job-card{
  background:var(--card);
  border-radius:var(--radius-sm);
  box-shadow:var(--shadow);
  padding:12px;
  transition:transform var(--trans), box-shadow var(--trans), border-color var(--trans);
  display:flex;
  flex-direction:row;
  align-items:center;
  gap:12px;
  border:1px solid transparent;
}
.jw-job-card:hover{
  transform:translateY(-2px);
  box-shadow:var(--shadow-md);
  border-color:var(--gold-200);
}
.jw-job-logo{
  flex-shrink:0;
  width:80px; height:80px;
  border:1px dashed var(--line);
  border-radius:var(--radius-sm);
  background:#fafaf9;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:6px;
}
.jw-job-logo img{
  max-width:100%;
  max-height:100%;
  object-fit:contain;
}
.jw-job-content{flex:1; min-width:0;}
.jw-job-title{
  font-size:15px;
  font-weight:700;
  color:var(--ink);
  line-height:1.5;
  margin:0 0 8px 0;
  display:-webkit-box;
  -webkit-line-clamp:3;
  -webkit-box-orient:vertical;
  overflow:hidden;
}
.jw-job-title a{
  color:var(--ink);
  text-decoration:none;
  transition:color var(--trans);
}
.jw-job-card:hover .jw-job-title a{color:var(--gold-dark);}
.jw-job-meta{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:10px;
  font-size:12px;
  color:var(--muted);
  flex-wrap:nowrap;
}
.jw-job-meta-item{
  display:inline-flex;
  align-items:center;
  gap:5px;
  font-weight:600;
  min-width:0;
}
.jw-job-meta-item i{
  color:var(--gold-dark);
  font-size:11px;
  flex-shrink:0;
}
.jw-job-meta-item.org{flex:1; min-width:0; max-width:65%;}
.jw-job-meta-item.org a{
  color:var(--ink-soft);
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
  display:block;
  transition:color var(--trans);
}
.jw-job-meta-item.org a:hover{color:var(--gold-dark);}
.jw-job-meta-item.time{flex-shrink:0; max-width:35%;}

/* ===== All jobs CTA ===== */
.jw-all-jobs-cta{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  width:100%;
  margin:24px 0;
  padding:16px 24px;
  background:linear-gradient(135deg, var(--gold) 0%, var(--gold-dark) 100%);
  color:#fff;
  border:none;
  border-radius:var(--radius);
  font-family:inherit;
  font-size:16px;
  font-weight:800;
  cursor:pointer;
  text-decoration:none;
  box-shadow:0 6px 16px rgba(201,162,39,.30);
  transition:transform var(--trans), box-shadow var(--trans), background var(--trans);
}
.jw-all-jobs-cta:hover{
  background:linear-gradient(135deg, var(--gold-dark) 0%, var(--gold-darker) 100%);
  transform:translateY(-2px);
  box-shadow:0 10px 22px rgba(201,162,39,.40);
  color:#fff;
}

/* ===== Pagination — gold buttons on opposite edges (السابق يمين / التالي يسار) ===== */
.jw-pagination{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:14px;
  margin:48px 0 20px;
  flex-wrap:wrap;
}
.jw-pagination .spacer{display:none;}
.jw-page-btn-nav{
  display:inline-flex;
  align-items:center;
  gap:8px;
  background:var(--gold);
  color:#fff;
  border:none;
  padding:11px 24px;
  border-radius:8px;
  font-family:inherit;
  font-weight:700;
  font-size:14px;
  cursor:pointer;
  text-decoration:none;
  box-shadow:0 3px 10px rgba(201,162,39,.25);
  transition:background var(--trans), transform var(--trans), box-shadow var(--trans);
}
.jw-page-btn-nav:hover{
  background:var(--gold-dark);
  color:#fff;
  transform:translateY(-2px);
  box-shadow:0 5px 14px rgba(201,162,39,.35);
}
.jw-page-btn-nav.disabled{
  background:#e7e5e4;
  color:#a8a29e;
  pointer-events:none;
  box-shadow:none;
  opacity:.85;
}
.jw-page-btn-nav i{font-size:13px;}

/* ===== Single post (job detail) ===== */
.jw-job-hero{
  text-align:center;
  margin-bottom:20px;
}
.jw-job-hero-logo{
  width:180px; height:180px;
  margin:24px auto 18px;
  background:#fff;
  border-radius:50%;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:12px;
  box-shadow:0 8px 24px rgba(15,23,42,.12), 0 2px 6px rgba(15,23,42,.06);
  border:4px solid #fff;
}
.jw-job-hero-logo img{
  max-width:100%;
  max-height:100%;
  object-fit:contain;
  border-radius:50%;
}
.jw-job-title-h1{
  font-size:28px;
  font-weight:900;
  color:var(--header-down);
  line-height:1.55;
  margin:0 auto 18px;
  max-width:760px;
  padding:0 12px;
  letter-spacing:-.01em;
}
.jw-job-body{
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--radius-lg);
  box-shadow:var(--shadow);
  margin-bottom:20px;
  overflow:hidden;
}
.jw-job-bar{
  display:flex;
  justify-content:space-between;
  align-items:center;
  background:var(--header-down);
  color:#fff;
  padding:11px 18px;
  font-size:13px;
  font-weight:700;
}
.jw-job-bar a{color:var(--gold-200); text-decoration:none;}
.jw-job-bar a:hover{color:var(--gold-100);}
.jw-job-bar > div{display:inline-flex; align-items:center; gap:6px;}
.jw-job-bar i{font-size:12px;}
.jw-job-byline-row{
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding:12px 22px;
  border-bottom:1px dashed var(--line);
  background:linear-gradient(180deg, var(--gold-50) 0%, #fff 100%);
  font-size:13px;
  color:var(--ink-soft);
}
.jw-job-byline-row .author{display:inline-flex; align-items:center; gap:6px;}
.jw-job-byline-row .author strong{color:var(--gold-dark); font-weight:800;}
.jw-job-byline-row .when{display:inline-flex; align-items:center; gap:6px; color:var(--muted); font-weight:600;}
.jw-job-byline-row .when i{color:var(--gold-dark);}
.jw-job-body-content{padding:24px 30px 28px;}
.jw-job-body-content h2{
  font-size:19px; font-weight:800; color:var(--ink);
  margin:24px 0 12px; padding-inline-start:12px;
  border-inline-start:4px solid var(--gold); line-height:1.5;
}
.jw-job-body-content h2:first-child{margin-top:0;}
.jw-job-body-content h3{font-size:16px; font-weight:700; color:var(--ink); margin:18px 0 8px;}
.jw-job-body-content p{font-size:15px; line-height:1.95; color:var(--ink-soft); margin-bottom:14px;}
.jw-job-body-content ul, .jw-job-body-content ol{padding-inline-start:22px; margin-bottom:14px;}
.jw-job-body-content li{margin-bottom:8px; line-height:1.85; color:var(--ink-soft); font-size:15px;}
.jw-job-body-content ul li::marker{color:var(--gold); font-size:1.1em;}
.jw-job-body-content ol li::marker{color:var(--gold-dark); font-weight:800;}
.jw-job-body-content strong{color:var(--ink);}
.jw-job-body-content a{color:var(--gold-dark); font-weight:600; border-bottom:1px solid var(--gold-200);}
.jw-job-body-content a:hover{border-bottom-color:var(--gold);}
.jw-job-body-content blockquote{
  background:linear-gradient(135deg, var(--gold-50) 0%, #fff 100%);
  border-inline-start:4px solid var(--gold);
  border-radius:0 var(--radius-sm) var(--radius-sm) 0;
  padding:14px 18px;
  margin:20px 0;
  font-style:italic;
}
.jw-job-body-content table{width:100%; border-collapse:separate; border-spacing:0; border:1px solid var(--line); border-radius:var(--radius-sm); overflow:hidden; margin:14px 0; font-size:14px;}
.jw-job-body-content table tr:nth-child(even){background:#fafaf9;}
.jw-job-body-content table td{padding:10px 14px; border-bottom:1px solid var(--line);}
.jw-job-body-content table td:first-child{font-weight:700; color:var(--ink); background:var(--gold-50);}

/* ===== Page hero (about/contact/etc) ===== */
.jw-page-hero{
  text-align:center;
  background:linear-gradient(135deg, var(--gold-50) 0%, #fff 100%);
  border:1px solid var(--gold-200);
  border-radius:var(--radius-lg);
  padding:36px 24px;
  margin-bottom:24px;
  position:relative;
  overflow:hidden;
}
.jw-page-hero::before{
  content:""; position:absolute; top:0; left:0; right:0; height:4px;
  background:linear-gradient(90deg, var(--gold-200), var(--gold), var(--gold-dark), var(--gold), var(--gold-200));
}
.jw-page-hero-icon{
  width:80px; height:80px; margin:0 auto 14px; background:var(--gold); color:#fff;
  border-radius:50%; display:flex; align-items:center; justify-content:center;
  font-size:34px; box-shadow:0 8px 20px rgba(201,162,39,.30);
}
.jw-page-hero h1{font-size:30px; font-weight:900; color:var(--header-down); margin-bottom:10px; letter-spacing:-.01em;}
.jw-page-hero p{font-size:15px; color:var(--ink-soft); max-width:600px; margin:0 auto; line-height:1.85;}

.jw-content-card{
  background:#fff; border:1px solid var(--line); border-radius:var(--radius-lg);
  padding:30px 32px; box-shadow:var(--shadow); margin-bottom:20px;
}
.jw-content-card h2, .jw-content-card h3, .jw-content-card h4{
  font-weight:800; color:var(--ink); margin-top:24px; margin-bottom:12px;
}
.jw-content-card h2{
  font-size:20px; padding-inline-start:14px; border-inline-start:4px solid var(--gold);
}
.jw-content-card p{font-size:15px; line-height:1.95; color:var(--ink-soft); margin-bottom:14px;}
.jw-content-card ul, .jw-content-card ol{padding-inline-start:22px; margin-bottom:14px;}
.jw-content-card li{margin-bottom:8px; line-height:1.85; color:var(--ink-soft); font-size:15px;}
.jw-content-card ul li::marker{color:var(--gold);}
.jw-content-card ol li::marker{color:var(--gold-dark); font-weight:800;}
.jw-content-card strong{color:var(--ink);}
.jw-content-card a{color:var(--gold-dark); border-bottom:1px solid var(--gold-200);}
.jw-content-card a:hover{border-bottom-color:var(--gold);}

/* ===== Footer (4-column grid — ewdifh-style) ===== */
.jw-site-footer{
  background:var(--header-down);
  color:#cbd5e1;
  padding:28px 16px 16px;
  margin-top:36px;
  border-top:3px solid var(--gold);
}
.jw-footer-grid{
  max-width:1100px;
  margin:0 auto 22px;
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  gap:24px 32px;
}
.jw-footer-col{
  display:flex;
  flex-direction:column;
  gap:10px;
  text-align:center;
}
.jw-footer-col a{
  color:#cbd5e1;
  font-size:13.5px;
  font-weight:500;
  text-decoration:none;
  transition:color var(--trans);
  padding:2px 0;
}
.jw-footer-col a:hover{color:var(--gold);}
.jw-footer-socials{
  display:flex;
  justify-content:center;
  gap:10px;
  margin:0 auto 18px;
  max-width:1100px;
  padding-top:18px;
  border-top:1px solid rgba(255,255,255,.08);
}
.jw-footer-socials a{
  width:32px; height:32px;
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.10);
  border-radius:50%;
  display:inline-flex; align-items:center; justify-content:center;
  color:#cbd5e1; font-size:13px;
  transition:all var(--trans);
}
.jw-footer-socials a:hover{
  background:var(--gold); color:#fff; border-color:var(--gold);
}
.jw-footer-bottom{
  max-width:1100px;
  margin:0 auto;
  padding-top:12px;
  border-top:1px solid rgba(255,255,255,.08);
  text-align:center;
  font-size:12.5px;
  color:#94a3b8;
}
.jw-footer-bottom strong{color:var(--gold);}
@media (max-width:768px){
  .jw-footer-grid{grid-template-columns:repeat(2, 1fr); gap:14px 18px;}
  .jw-footer-col{gap:8px;}
  .jw-footer-col a{font-size:13px;}
}
@media (max-width:480px){
  .jw-site-footer{padding:18px 12px 10px;}
  .jw-footer-grid{
    grid-template-columns:repeat(2, 1fr);
    gap:6px 14px;
    margin-bottom:14px;
  }
  .jw-footer-col{gap:5px; text-align:start;}
  .jw-footer-col a{
    font-size:12.5px;
    padding:3px 0;
    line-height:1.4;
  }
  .jw-footer-socials{
    margin:0 auto 10px;
    padding-top:10px;
    gap:8px;
  }
  .jw-footer-socials a{width:30px; height:30px; font-size:12px;}
  .jw-footer-bottom{
    padding-top:10px;
    font-size:11.5px;
  }
}

/* ===== 404 page ===== */
.jw-404{text-align:center; padding:80px 20px;}
.jw-404 h1{font-size:96px; color:var(--gold); margin:0; line-height:1;}
.jw-404 h2{font-size:24px; color:var(--ink); margin:14px 0 18px;}
.jw-404 p{color:var(--muted); font-size:15px; margin-bottom:24px;}
.jw-404 .home-btn{
  display:inline-flex; align-items:center; gap:8px;
  background:var(--gold); color:#fff;
  padding:12px 28px; border-radius:999px;
  font-weight:700; text-decoration:none;
  transition:background var(--trans);
}
.jw-404 .home-btn:hover{background:var(--gold-dark);}

::selection{background:var(--gold-100); color:var(--ink);}
*:focus-visible{outline:2px solid var(--gold); outline-offset:2px;}

/* Mobile tweaks */
@media (max-width:600px){
  .jw-job-hero-logo{width:140px; height:140px;}
  .jw-job-title-h1{font-size:21px;}
  .jw-job-body-content{padding:18px;}
  .jw-content-card{padding:20px;}
  .jw-page-hero{padding:24px 18px;}
  .jw-page-hero h1{font-size:24px;}
}

/* ===== Job Repeater Blocks (tasks/requirements/skills/benefits) ===== */
.jw-job-block{
  background:#fff;
  border:1px solid var(--line);
  border-radius:12px;
  padding:22px 24px;
  margin:22px 0;
  box-shadow:var(--shadow);
}
.jw-job-block-title{
  display:flex; align-items:center; gap:10px;
  font-size:18px; font-weight:800; color:var(--ink);
  margin:0 0 16px 0; padding-bottom:12px;
  border-bottom:2px solid var(--gold-100);
}
.jw-job-block-title i{
  color:var(--gold); font-size:20px;
  width:36px; height:36px;
  background:var(--gold-50);
  border-radius:50%;
  display:inline-flex; align-items:center; justify-content:center;
}
.jw-job-list{
  list-style:none; padding:0; margin:0;
}
.jw-job-list li{
  position:relative;
  padding:10px 36px 10px 0;
  color:var(--ink-soft);
  font-size:15px; line-height:1.85;
  border-bottom:1px dashed var(--line);
}
.jw-job-list li:last-child{border-bottom:none;}
.jw-job-list li::before{
  content:"\f00c";
  font-family:"Font Awesome 6 Free"; font-weight:900;
  position:absolute; right:0; top:13px;
  color:var(--gold);
  width:22px; height:22px;
  background:var(--gold-50);
  border-radius:50%;
  display:inline-flex; align-items:center; justify-content:center;
  font-size:11px;
}

/* Skills chips */
.jw-skill-chips{display:flex; flex-wrap:wrap; gap:8px;}
.jw-skill-chip{
  display:inline-flex; align-items:center;
  background:var(--gold-50);
  color:var(--gold-darker);
  padding:7px 16px;
  border-radius:999px;
  font-size:13.5px; font-weight:600;
  border:1px solid var(--gold-100);
  transition:all var(--trans);
}
.jw-skill-chip:hover{
  background:var(--gold);
  color:#fff;
  border-color:var(--gold-dark);
  transform:translateY(-1px);
}

/* Benefits grid */
.jw-benefits-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill, minmax(240px, 1fr));
  gap:14px;
}
.jw-benefit-card{
  display:flex; align-items:flex-start; gap:14px;
  background:linear-gradient(135deg, var(--gold-50), #fff);
  border:1px solid var(--gold-100);
  border-radius:12px;
  padding:16px;
  transition:all var(--trans);
}
.jw-benefit-card:hover{
  transform:translateY(-3px);
  box-shadow:var(--shadow-md);
  border-color:var(--gold-200);
}
.jw-benefit-icon{
  flex-shrink:0;
  width:44px; height:44px;
  background:var(--gold);
  color:#fff;
  border-radius:10px;
  display:inline-flex; align-items:center; justify-content:center;
  font-size:18px;
  box-shadow:0 4px 10px rgba(201,162,39,.22);
}
.jw-benefit-text h4{
  margin:0 0 4px 0;
  font-size:14.5px; font-weight:800;
  color:var(--ink);
}
.jw-benefit-text p{
  margin:0;
  font-size:13px; color:var(--muted);
  line-height:1.6;
}
@media (max-width:600px){
  .jw-job-block{padding:16px 18px;}
  .jw-job-block-title{font-size:16px;}
  .jw-benefits-grid{grid-template-columns:1fr;}
}

/* ===== Article-specific styles ===== */
.jw-empty{
  text-align:center; padding:60px 20px;
  background:#fff; border:1px dashed var(--line);
  border-radius:12px;
}
.jw-empty i{font-size:48px; color:var(--gold); opacity:.6;}
.jw-empty h2{margin:18px 0 8px; color:var(--ink); font-size:20px;}
.jw-empty p{color:var(--muted); font-size:14px;}

/* (legacy numeric pagination removed — using prev/next style above) */

/* ===== Unified apply box (single CTA at bottom of every job) ===== */
.jw-apply-box{
  background:linear-gradient(135deg, #E0F2FE, #fff);
  border:2px solid #7DD3FC;
  border-radius:14px;
  padding:24px;
  margin:28px 0 12px;
  text-align:center;
}
.jw-apply-title{
  margin:0 0 8px 0;
  color:#1c1917;
  font-size:18px;
  font-weight:800;
}
.jw-apply-sub{
  margin:0 0 16px 0;
  color:#44403c;
  font-size:14px;
}
.jw-apply-actions{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  justify-content:center;
  align-items:center;
}
.jw-apply-btn{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:12px 28px;
  border-radius:999px;
  font-weight:800;
  text-decoration:none;
  font-size:14.5px;
  transition:transform var(--trans), box-shadow var(--trans), background var(--trans);
  direction:ltr; /* keep email left-to-right inside the button when needed */
  unicode-bidi:plaintext;
}
.jw-apply-btn.primary{
  background:#0EA5E9;
  color:#fff;
  box-shadow:0 4px 12px rgba(201,162,39,.30);
}
.jw-apply-btn.primary:hover{
  background:#0284C7;
  color:#fff;
  transform:translateY(-2px);
  box-shadow:0 6px 16px rgba(201,162,39,.40);
}
.jw-apply-btn.email{
  background:#fff;
  color:#1c1917;
  border:1.5px solid #0EA5E9;
}
.jw-apply-btn.email:hover{
  background:#E0F2FE;
  color:#1c1917;
  transform:translateY(-2px);
}
@media (max-width:480px){
  .jw-apply-btn{padding:11px 18px; font-size:13.5px;}
  .jw-apply-btn span{word-break:break-all;}
}

/* Course / Result meta grid */
.jw-course-meta{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(200px, 1fr));
  gap:12px;
  background:linear-gradient(135deg, #E0F2FE, #fff);
  border:1px solid var(--gold-100);
  border-radius:12px;
  padding:18px 20px;
  margin:0 0 24px 0;
}
.jw-course-meta > div{
  display:flex; align-items:center; gap:8px;
  color:var(--ink-soft); font-size:14.5px;
}
.jw-course-meta i{color:var(--gold); width:20px; text-align:center;}
.jw-course-meta strong{color:var(--ink); margin-inline-end:4px;}

.jw-badge-free{
  display:inline-flex; align-items:center; gap:6px;
  background:linear-gradient(135deg, #10b981, #059669);
  color:#fff; padding:6px 14px; border-radius:999px;
  font-size:13px; font-weight:800;
  box-shadow:0 2px 8px rgba(16,185,129,.3);
}

.jw-btn-primary{
  display:inline-flex; align-items:center; gap:8px;
  background:var(--gold); color:#fff;
  padding:12px 28px; border-radius:999px;
  font-weight:800; text-decoration:none;
  box-shadow:0 4px 12px rgba(201,162,39,.30);
  transition:all var(--trans);
}
.jw-btn-primary:hover{
  background:var(--gold-dark);
  transform:translateY(-2px);
  box-shadow:0 6px 16px rgba(201,162,39,.40);
}

/* Table of contents */
.jw-toc{
  list-style:decimal; margin:0; padding-inline-start:24px;
  counter-reset:item;
}
.jw-toc li{
  margin-bottom:8px; color:var(--ink-soft);
  font-size:15px; line-height:1.7;
}
.jw-toc a{color:var(--gold-darker); text-decoration:none; font-weight:600;}
.jw-toc a:hover{color:var(--gold-dark); text-decoration:underline;}

/* Article-card image fallback */
.jw-card-fallback{
  width:100%; height:100%;
  background:linear-gradient(135deg, var(--gold-50), var(--gold-100));
  display:flex; align-items:center; justify-content:center;
  color:var(--gold); font-size:48px;
}

/* ===== Contact form ===== */
.jw-contact-form{display:flex;flex-direction:column;gap:16px;margin-top:14px;}
.jw-form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px;}
@media(max-width:600px){.jw-form-row{grid-template-columns:1fr;}}
.jw-form-field{display:flex;flex-direction:column;gap:6px;}
.jw-form-field label{font-weight:700;color:var(--ink);font-size:14px;}
.jw-form-field input,.jw-form-field textarea,.jw-form-field select{
  width:100%; padding:10px 14px;
  border:1px solid var(--line); border-radius:8px;
  font-family:inherit; font-size:14.5px;
  background:#fff; color:var(--ink);
  transition:all .18s;
}
.jw-form-field input:focus,.jw-form-field textarea:focus{
  outline:none; border-color:var(--gold); box-shadow:0 0 0 3px var(--gold-50);
}
.jw-form-field textarea{resize:vertical;min-height:120px;}

/* ===== Ad slot styling ===== */
.jw-ad-slot{margin:18px 0;text-align:center;}
.jw-ad-label{display:block;font-size:11px;color:var(--muted);margin-top:4px;text-transform:uppercase;letter-spacing:.5px;}
.jw-ad-placeholder{
  background:linear-gradient(135deg,#E0F2FE,#fff);
  border:2px dashed #7DD3FC;
  border-radius:8px;
  padding:18px 14px;
  text-align:center;
  color:#0284C7;
  font-weight:700;
  font-size:14px;
}
.jw-ad-placeholder small{display:block;color:var(--muted);font-weight:400;font-size:11.5px;margin-top:4px;}

/* ===== Companies grid ===== */
.jw-companies-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill, minmax(260px, 1fr));
  gap:18px;
  margin:24px 0;
}
.jw-company-card{
  display:flex; align-items:center; gap:14px;
  background:#fff; border:1px solid var(--line);
  border-radius:12px; padding:16px;
  text-decoration:none; color:inherit;
  transition:all var(--trans);
}
.jw-company-card:hover{
  transform:translateY(-3px);
  box-shadow:var(--shadow-md);
  border-color:var(--gold-200);
}
.jw-company-logo{
  width:64px; height:64px;
  flex-shrink:0;
  border-radius:10px;
  overflow:hidden;
  background:#E0F2FE;
  display:flex; align-items:center; justify-content:center;
}
.jw-company-logo img{width:100%; height:100%; object-fit:contain;}
.jw-company-logo-fallback{
  width:100%; height:100%;
  display:flex; align-items:center; justify-content:center;
  color:var(--gold);
  font-size:28px;
}
.jw-company-logo-fallback.large{font-size:64px;}
.jw-company-info{flex:1; min-width:0;}
.jw-company-name{
  font-size:15.5px; font-weight:800;
  color:var(--ink);
  margin:0 0 4px 0;
  display:flex; align-items:center; gap:6px;
}
.jw-company-industry{
  font-size:12.5px; color:var(--muted);
  margin:0 0 8px 0;
}
.jw-company-meta{
  display:flex; gap:12px;
  font-size:12px; color:var(--gold-darker);
  font-weight:700;
}
.jw-company-jobs-count{
  background:var(--gold-50);
  padding:3px 8px; border-radius:6px;
  display:inline-flex; gap:4px; align-items:center;
}

/* ===== Company hero — slim centered card (logo top → name → jobs count) ===== */
.jw-company-hero{
  background:linear-gradient(180deg, #E0F2FE 0%, #fff 100%);
  border:1px solid var(--gold-100);
  border-radius:12px;
  padding:18px 16px;
  margin:18px 0;
  display:flex;
  flex-direction:column;
  align-items:center;
  text-align:center;
  gap:10px;
}
.jw-company-hero-logo{
  width:84px; height:84px;
  border-radius:14px;
  background:#fff;
  border:1px solid var(--gold-100);
  display:flex; align-items:center; justify-content:center;
  padding:8px;
  box-shadow:0 2px 8px rgba(0,0,0,.06);
}
.jw-company-hero-logo img{width:100%; height:100%; object-fit:contain;}
.jw-company-hero-info{display:flex; flex-direction:column; align-items:center; gap:6px;}
.jw-company-hero-name{
  font-size:18px;
  font-weight:800;
  color:var(--ink);
  margin:0;
  line-height:1.4;
}
.jw-company-hero-industry{
  font-size:13px;
  color:var(--gold-darker);
  font-weight:600;
  margin:0;
}
.jw-company-hero-jobs-count{
  display:inline-flex; align-items:center; gap:6px;
  font-size:13px;
  color:var(--ink-soft);
  font-weight:600;
}
.jw-company-hero-jobs-count i{color:var(--gold);}
.jw-company-hero-extras{
  display:flex; flex-wrap:wrap; gap:10px 14px;
  justify-content:center;
  font-size:12.5px; color:var(--muted);
  margin-top:4px;
}
.jw-company-hero-extras i{color:var(--gold); margin-inline-end:3px;}
.jw-company-website{
  background:var(--gold);
  color:#fff !important;
  padding:4px 10px; border-radius:999px;
  text-decoration:none; font-weight:700;
  font-size:12px;
}
.jw-company-website:hover{background:var(--gold-dark);}
.jw-company-hero-description{
  color:var(--ink-soft);
  line-height:1.7;
  font-size:13.5px;
  margin:6px 0 0;
  max-width:640px;
}

/* ===== Error pages (404, 500, 503) ===== */
.jw-error-page{
  text-align:center;
  padding:40px 20px;
  max-width:900px;
  margin:0 auto;
}
.jw-error-icon{
  font-size:64px;
  color:var(--gold);
  margin-bottom:14px;
}
.jw-error-code{
  font-size:120px;
  font-weight:900;
  color:var(--gold-dark);
  line-height:1;
  margin:0;
  letter-spacing:-4px;
  text-shadow:0 6px 16px rgba(201,162,39,.18);
}
.jw-error-title{
  font-size:30px;
  font-weight:800;
  color:var(--ink);
  margin:14px 0 10px 0;
}
.jw-error-message{
  color:var(--ink-soft);
  font-size:16px;
  line-height:1.7;
  margin:0 0 28px 0;
}
.jw-error-actions{
  display:flex;
  gap:14px;
  justify-content:center;
  flex-wrap:wrap;
  margin-bottom:36px;
}
.jw-btn-secondary{
  display:inline-flex;
  align-items:center;
  gap:8px;
  background:#fff;
  color:var(--ink);
  border:1.5px solid var(--line);
  padding:11px 24px;
  border-radius:999px;
  font-weight:700;
  font-size:14.5px;
  text-decoration:none;
  transition:all var(--trans);
}
.jw-btn-secondary:hover{
  border-color:var(--gold);
  color:var(--gold-dark);
}

.jw-error-suggestions{
  background:#fff;
  border:1px solid var(--line);
  border-radius:14px;
  padding:24px;
  margin:24px 0;
  text-align:right;
}
.jw-error-suggestions h2{
  font-size:18px;
  font-weight:800;
  color:var(--ink);
  margin:0 0 16px 0;
  display:flex;
  align-items:center;
  gap:8px;
}
.jw-error-suggestions h2 i{color:var(--gold);}
.jw-error-links{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
}
.jw-error-link-pill{
  display:inline-flex;
  align-items:center;
  gap:6px;
  background:var(--gold-50);
  color:var(--gold-darker);
  padding:8px 16px;
  border-radius:999px;
  font-size:13.5px;
  font-weight:700;
  text-decoration:none;
  border:1px solid var(--gold-100);
  transition:all var(--trans);
}
.jw-error-link-pill:hover{
  background:var(--gold);
  color:#fff;
  border-color:var(--gold-dark);
  transform:translateY(-2px);
}

.jw-error-latest{
  margin:24px 0;
  text-align:right;
}
.jw-error-latest h2{
  font-size:18px;
  font-weight:800;
  color:var(--ink);
  margin:0 0 16px 0;
  display:flex;
  align-items:center;
  gap:8px;
}
.jw-error-latest h2 i{color:#ef4444;}

.jw-error-help{
  margin-top:28px;
  color:var(--muted);
  font-size:13.5px;
}
.jw-error-help a{
  color:var(--gold-dark);
  font-weight:700;
}
.jw-error-help a:hover{text-decoration:underline;}

/* ===========================================================
   RESPONSIVE — phones, tablets
   =========================================================== */

/* Hamburger button — hidden on desktop */
.jw-nav-toggle{
  display:none;
  align-items:center;
  gap:8px;
  background:transparent;
  border:1px solid rgba(255,255,255,.18);
  color:#fff;
  font-family:inherit;
  font-weight:700;
  font-size:14px;
  padding:8px 14px;
  border-radius:8px;
  cursor:pointer;
  transition:background var(--trans), border-color var(--trans);
}
.jw-nav-toggle:hover{background:rgba(201,162,39,.18); border-color:var(--gold);}
.jw-nav-toggle.open{background:var(--gold); border-color:var(--gold-dark);}
.jw-nav-toggle i{font-size:16px;}

/* ---------- Tablet & below (≤ 1024px) ---------- */
@media (max-width:1024px){
  .jw-page-wrap{padding:0 4px;}
  .jw-main{padding:18px 12px;}
  .jw-brand-name{font-size:24px;}
  .jw-brand-logo-img{width:48px; height:48px;}
}

/* ---------- Mobile (≤ 768px) ---------- */
@media (max-width:768px){
  /* Header */
  .jw-site-header{padding:12px 0;}
  .jw-brand{gap:10px;}
  .jw-brand-name{font-size:20px;}
  .jw-brand-logo-img{width:42px; height:42px;}

  /* Nav: hamburger + collapsible vertical menu */
  .jw-nav-container{
    padding:8px 12px;
    display:flex;
    align-items:center;
    justify-content:flex-start;
  }
  .jw-nav-toggle{display:inline-flex;}
  .jw-nav-items{
    display:none;
    position:absolute;
    inset-inline-start:0;
    inset-inline-end:0;
    top:100%;
    background:var(--header-down);
    flex-direction:column;
    align-items:stretch;
    padding:8px 12px 14px;
    gap:4px;
    border-top:1px solid rgba(255,255,255,.08);
    box-shadow:0 8px 24px rgba(0,0,0,.25);
    max-height:calc(100vh - 70px);
    overflow-y:auto;
    z-index:99;
  }
  .jw-nav-items.open{display:flex;}
  .jw-nav-item{
    width:100%;
    padding:12px 14px;
    font-size:15px;
    border-radius:10px;
    justify-content:flex-start;
  }
  .jw-nav-item i{font-size:15px; width:20px; text-align:center;}

  /* Main padding */
  .jw-main{padding:14px 10px;}
  .jw-page-wrap{padding:0;}

  /* Search */
  .jw-search-section{padding:12px 10px;}
  .jw-search-input{padding:12px 16px; font-size:14px;}
  .jw-search-button{padding:0 18px; font-size:13px;}
  .jw-search-button span{display:none;}

  /* Job cards already 1-col under 640 — also tighten the card */
  .jw-job-card{padding:10px; gap:10px;}
  .jw-job-logo{width:64px; height:64px;}
  .jw-job-title{font-size:14.5px; -webkit-line-clamp:3;}
  .jw-job-meta{font-size:11.5px; flex-wrap:wrap; gap:6px;}

  /* Section title */
  .jw-section-title{font-size:16px; padding:0 8px;}

  /* Disable sticky nav so dropdown doesn't get stuck */
  .jw-nav{position:relative;}
}

/* ---------- Small phones (≤ 480px) ---------- */
@media (max-width:480px){
  .jw-brand-name{font-size:17px;}
  .jw-brand-logo-img{width:38px; height:38px;}
  .jw-site-header{padding:10px 0;}

  .jw-job-card{flex-direction:row; padding:10px; gap:10px;}
  .jw-job-logo{width:56px; height:56px;}
  .jw-job-title{font-size:13.5px; line-height:1.45;}
  .jw-job-meta{font-size:11px;}
  .jw-job-meta-item i{font-size:10px;}

  .jw-search-input{padding:10px 14px; font-size:13.5px;}
  .jw-search-button{padding:0 14px;}

  .jw-section-title{font-size:15px;}
}

/* ---------- Tablet portrait jobs grid (768-1024) keep 2 cols, tighter padding ---------- */
@media (min-width:641px) and (max-width:1024px){
  .jw-jobs-grid{gap:10px;}
  .jw-job-card{padding:11px; gap:10px;}
  .jw-job-logo{width:70px; height:70px;}
  .jw-job-title{font-size:14.5px;}
}

/* Make sure nothing overflows horizontally on small screens */
html, body{max-width:100%; overflow-x:hidden;}
img, video{max-width:100%; height:auto;}

