/*
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:#C9A227;
  --gold-dark:#a78519;
  --gold-darker:#856812;
  --gold-50:#fef7e0;
  --gold-100:#fdeec3;
  --gold-200:#f9dc89;
  --header-bg:#C9A227;
  --header-down:#0f172a;
  --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 ===== */
.jw-pagination{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:12px;
  margin:32px 0;
  flex-wrap:wrap;
}
.jw-pagination .spacer{flex:1;}
.jw-page-btn-nav{
  display:inline-flex;
  align-items:center;
  gap:8px;
  background:var(--gold);
  color:#fff;
  border:none;
  padding:11px 24px;
  border-radius:var(--radius);
  font-family:inherit;
  font-weight:800;
  font-size:14px;
  cursor:pointer;
  text-decoration:none;
  box-shadow:0 4px 12px rgba(201,162,39,.28);
  transition:transform var(--trans), box-shadow var(--trans), background var(--trans);
}
.jw-page-btn-nav:hover{
  background:var(--gold-dark);
  transform:translateY(-1px);
  box-shadow:0 6px 16px rgba(201,162,39,.36);
  color:#fff;
}
.jw-page-btn-nav.disabled{
  background:var(--line);
  color:var(--muted);
  pointer-events:none;
  box-shadow:none;
  opacity:.65;
}

/* ===== 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 ===== */
.jw-site-footer{
  background:var(--header-down);
  color:#cbd5e1;
  padding:48px 16px 24px;
  margin-top:48px;
  border-top:3px solid var(--gold);
}
.jw-footer-grid{
  max-width:1280px;
  margin:0 auto;
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  gap:32px;
}
@media (max-width:768px){.jw-footer-grid{grid-template-columns:repeat(2, 1fr);}}
@media (max-width:480px){.jw-footer-grid{grid-template-columns:1fr;}}
.jw-footer-col h4{
  color:#fff; font-size:15px; font-weight:800; margin-bottom:14px;
  padding-bottom:8px; position:relative;
}
.jw-footer-col h4::after{
  content:""; position:absolute; bottom:0; left:0;
  width:32px; height:2px; background:var(--gold); border-radius:2px;
}
[dir="rtl"] .jw-footer-col h4::after{left:auto; right:0;}
.jw-footer-col ul{list-style:none; padding:0; margin:0;}
.jw-footer-col ul li{padding:5px 0;}
.jw-footer-col ul li a{
  color:#cbd5e1; font-size:14px;
  transition:color var(--trans), padding-inline-start var(--trans);
  display:inline-flex; align-items:center; gap:6px;
}
.jw-footer-col ul li a:hover{color:var(--gold); padding-inline-start:6px;}
.jw-footer-col p{font-size:14px; color:#94a3b8; line-height:1.85;}
.jw-social-icons{display:flex; gap:8px; margin-top:12px;}
.jw-social-icons a{
  width:38px; height:38px;
  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; transition:all var(--trans);
}
.jw-social-icons a:hover{
  background:var(--gold); color:#fff; border-color:var(--gold);
  transform:translateY(-2px);
}
.jw-footer-bottom{
  max-width:1280px;
  margin:32px auto 0;
  padding-top:18px;
  border-top:1px solid rgba(255,255,255,.08);
  text-align:center;
  font-size:13px;
  color:#94a3b8;
}
.jw-footer-bottom strong{color:var(--gold);}

/* ===== 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;}

/* Pagination */
.jw-pagination{margin:32px 0 24px; display:flex; justify-content:center;}
.jw-pagination nav{display:flex; gap:6px; flex-wrap:wrap;}
.jw-pagination a, .jw-pagination span{
  padding:8px 14px; border-radius:6px;
  background:#fff; color:var(--ink-soft);
  border:1px solid var(--line); font-weight:600;
  font-size:14px; text-decoration:none;
  transition:all var(--trans);
}
.jw-pagination a:hover{background:var(--gold-50); border-color:var(--gold-200);}
.jw-pagination .bg-gray-200, .jw-pagination [aria-current="page"] span{
  background:var(--gold); color:#fff; border-color:var(--gold);
}

/* Course / Result meta grid */
.jw-course-meta{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(200px, 1fr));
  gap:12px;
  background:linear-gradient(135deg, #fef7e0, #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,#fef7e0,#fff);
  border:2px dashed #f9dc89;
  border-radius:8px;
  padding:18px 14px;
  text-align:center;
  color:#a78519;
  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;}
